setup.h 3.7 KB
Newer Older
H
H. Peter Anvin 已提交
1 2
#ifndef _ASM_X86_SETUP_H
#define _ASM_X86_SETUP_H
T
Thomas Gleixner 已提交
3

C
Cyrill Gorcunov 已提交
4 5
#ifdef __KERNEL__

T
Thomas Gleixner 已提交
6 7
#define COMMAND_LINE_SIZE 2048

8
#ifndef __ASSEMBLY__
G
Glauber Costa 已提交
9

I
Ingo Molnar 已提交
10 11 12
/*
 * Any setup quirks to be performed?
 */
13
struct mpc_cpu;
14
struct mpc_bus;
15
struct mpc_oemtable;
I
Ingo Molnar 已提交
16

Y
Yinghai Lu 已提交
17
struct x86_quirks {
18
	int (*arch_pre_time_init)(void);
Y
Yinghai Lu 已提交
19 20 21 22 23 24 25
	int (*arch_time_init)(void);
	int (*arch_pre_intr_init)(void);
	int (*arch_intr_init)(void);
	int (*arch_trap_init)(void);
	char * (*arch_memory_setup)(void);
	int (*mach_get_smp_config)(unsigned int early);
	int (*mach_find_smp_config)(unsigned int reserve);
26 27

	int *mpc_record;
28
	int (*mpc_apic_id)(struct mpc_cpu *m);
29 30
	void (*mpc_oem_bus_info)(struct mpc_bus *m, char *name);
	void (*mpc_oem_pci_bus)(struct mpc_bus *m);
31
	void (*smp_read_mpc_oem)(struct mpc_oemtable *oemtable,
C
Cyrill Gorcunov 已提交
32
				unsigned short oemsize);
33
	int (*setup_ioapic_ids)(void);
Y
Yinghai Lu 已提交
34 35
};

I
Ingo Molnar 已提交
36 37 38 39 40 41 42 43
extern void x86_quirk_pre_intr_init(void);
extern void x86_quirk_intr_init(void);

extern void x86_quirk_trap_init(void);

extern void x86_quirk_pre_time_init(void);
extern void x86_quirk_time_init(void);

44 45
#endif /* __ASSEMBLY__ */

T
Thomas Gleixner 已提交
46 47 48 49 50 51 52 53 54
#ifdef __i386__

#include <linux/pfn.h>
/*
 * Reserved space for vmalloc and iomap - defined in asm/page.h
 */
#define MAXMEM_PFN	PFN_DOWN(MAXMEM)
#define MAX_NONPAE_PFN	(1 << 20)

55 56 57
#endif /* __i386__ */

#define PARAM_SIZE 4096		/* sizeof(struct boot_params) */
T
Thomas Gleixner 已提交
58 59

#define OLD_CL_MAGIC		0xA33F
60
#define OLD_CL_ADDRESS		0x020	/* Relative to real mode data */
T
Thomas Gleixner 已提交
61 62 63 64 65
#define NEW_CL_POINTER		0x228	/* Relative to real mode data */

#ifndef __ASSEMBLY__
#include <asm/bootparam.h>

66
/* Interrupt control for vSMPowered x86_64 systems */
67
#ifdef CONFIG_X86_VSMP
68
void vsmp_init(void);
69 70 71
#else
static inline void vsmp_init(void) { }
#endif
72 73 74 75 76 77 78 79 80 81 82 83 84 85 86 87 88 89

void setup_bios_corruption_check(void);

#ifdef CONFIG_X86_VISWS
extern void visws_early_detect(void);
extern int is_visws_box(void);
#else
static inline void visws_early_detect(void) { }
static inline int is_visws_box(void) { return 0; }
#endif

extern struct x86_quirks *x86_quirks;
extern unsigned long saved_video_mode;

#ifndef CONFIG_PARAVIRT
#define paravirt_post_allocator_init()	do {} while (0)
#endif

90 91
#ifndef _SETUP

T
Thomas Gleixner 已提交
92 93 94 95 96 97 98 99 100 101 102
/*
 * This is set up by the setup-routine at boot-time
 */
extern struct boot_params boot_params;

/*
 * Do NOT EVER look at the BIOS memory size location.
 * It does not work on many machines.
 */
#define LOWMEMSIZE()	(0x9f000)

103 104 105 106
/* exceedingly early brk-like allocator */
extern unsigned long _brk_end;
void *extend_brk(size_t size, size_t align);

107 108 109 110 111 112 113 114 115 116 117 118 119 120 121 122 123 124 125 126 127 128 129
/*
 * Reserve space in the brk section.  The name must be unique within
 * the file, and somewhat descriptive.  The size is in bytes.  Must be
 * used at file scope.
 *
 * (This uses a temp function to wrap the asm so we can pass it the
 * size parameter; otherwise we wouldn't be able to.  We can't use a
 * "section" attribute on a normal variable because it always ends up
 * being @progbits, which ends up allocating space in the vmlinux
 * executable.)
 */
#define RESERVE_BRK(name,sz)						\
	static void __section(.discard) __used			\
	__brk_reservation_fn_##name##__(void) {				\
		asm volatile (						\
			".pushsection .brk_reservation,\"aw\",@nobits;" \
			"__brk_reservation_" #name "__:"		\
			" 1:.skip %c0;"					\
			" .size __brk_reservation_" #name "__, . - 1b;"	\
			" .popsection"					\
			: : "i" (sz));					\
	}

130 131
#ifdef __i386__

132
void __init i386_start_kernel(void);
133
extern void probe_roms(void);
134

135 136
#else
void __init x86_64_start_kernel(char *real_mode);
137 138
void __init x86_64_start_reservations(char *real_mode_data);

T
Thomas Gleixner 已提交
139
#endif /* __i386__ */
140
#endif /* _SETUP */
141 142 143 144 145 146 147
#else
#define RESERVE_BRK(name,sz)				\
	.pushsection .brk_reservation,"aw",@nobits;	\
__brk_reservation_##name##__:				\
1:	.skip sz;					\
	.size __brk_reservation_##name##__,.-1b;	\
	.popsection
T
Thomas Gleixner 已提交
148 149 150
#endif /* __ASSEMBLY__ */
#endif  /*  __KERNEL__  */

H
H. Peter Anvin 已提交
151
#endif /* _ASM_X86_SETUP_H */