2008-06-18 17:08:48 +02:00
# ifndef ASM_X86__SETUP_H
# define ASM_X86__SETUP_H
2007-10-23 22:37:24 +02:00
# define COMMAND_LINE_SIZE 2048
2008-01-30 13:31:11 +01:00
# ifndef __ASSEMBLY__
2008-02-11 17:16:03 -02:00
/* Interrupt control for vSMPowered x86_64 systems */
void vsmp_init ( void ) ;
2008-07-10 17:30:40 +02:00
# ifdef CONFIG_X86_VISWS
extern void visws_early_detect ( void ) ;
2008-07-10 16:53:21 +02:00
extern int is_visws_box ( void ) ;
2008-07-10 17:30:40 +02:00
# else
static inline void visws_early_detect ( void ) { }
2008-07-10 16:53:21 +02:00
static inline int is_visws_box ( void ) { return 0 ; }
2008-07-10 17:30:40 +02:00
# endif
/*
* Any setup quirks to be performed ?
*/
2008-07-19 18:01:16 -07:00
struct mpc_config_processor ;
struct mpc_config_bus ;
struct mp_config_oemtable ;
2008-07-19 02:07:25 -07:00
struct x86_quirks {
2008-07-19 18:02:26 -07:00
int ( * arch_pre_time_init ) ( void ) ;
2008-07-19 02:07:25 -07:00
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 ) ;
2008-07-19 18:01:16 -07:00
int * mpc_record ;
int ( * mpc_apic_id ) ( struct mpc_config_processor * m ) ;
void ( * mpc_oem_bus_info ) ( struct mpc_config_bus * m , char * name ) ;
void ( * mpc_oem_pci_bus ) ( struct mpc_config_bus * m ) ;
void ( * smp_read_mpc_oem ) ( struct mp_config_oemtable * oemtable ,
unsigned short oemsize ) ;
2008-07-19 02:07:25 -07:00
} ;
extern struct x86_quirks * x86_quirks ;
2008-07-10 17:30:40 +02:00
2008-01-30 13:31:11 +01:00
# ifndef CONFIG_PARAVIRT
# define paravirt_post_allocator_init() do {} while (0)
# endif
# endif /* __ASSEMBLY__ */
2007-10-11 11:20:03 +02:00
# ifdef __KERNEL__
2007-10-23 22:37:24 +02:00
# 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)
2007-10-23 22:37:25 +02:00
# endif /* __i386__ */
# define PARAM_SIZE 4096 /* sizeof(struct boot_params) */
2007-10-23 22:37:24 +02:00
# define OLD_CL_MAGIC 0xA33F
2007-10-23 22:37:25 +02:00
# define OLD_CL_ADDRESS 0x020 /* Relative to real mode data */
2007-10-23 22:37:24 +02:00
# define NEW_CL_POINTER 0x228 /* Relative to real mode data */
# ifndef __ASSEMBLY__
# include <asm/bootparam.h>
2007-10-23 22:37:25 +02:00
# ifndef _SETUP
2007-10-23 22:37:24 +02:00
/*
* 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)
2008-06-18 17:27:08 -07:00
# ifdef __i386__
2008-05-29 12:56:36 -07:00
void __init i386_start_kernel ( void ) ;
2008-06-21 15:39:41 -07:00
extern void probe_roms ( void ) ;
2008-01-30 13:31:11 +01:00
2008-05-29 12:56:36 -07:00
extern unsigned long init_pg_tables_start ;
extern unsigned long init_pg_tables_end ;
2007-10-23 22:37:24 +02:00
2008-06-25 00:19:09 -04:00
# else
2008-07-08 15:06:42 -07:00
void __init x86_64_init_pda ( void ) ;
2008-06-25 00:19:09 -04:00
void __init x86_64_start_kernel ( char * real_mode ) ;
2008-06-25 00:19:18 -04:00
void __init x86_64_start_reservations ( char * real_mode_data ) ;
2007-10-23 22:37:24 +02:00
# endif /* __i386__ */
2007-10-23 22:37:25 +02:00
# endif /* _SETUP */
2007-10-23 22:37:24 +02:00
# endif /* __ASSEMBLY__ */
# endif /* __KERNEL__ */
2008-06-18 17:08:48 +02:00
# endif /* ASM_X86__SETUP_H */