2005-04-17 02:20:36 +04:00
/*
* structures and definitions for the int 15 , ax = e820 memory map
* scheme .
*
* In a nutshell , arch / i386 / boot / setup . S populates a scratch table
* in the empty_zero_block that contains a list of usable address / size
* duples . In arch / i386 / kernel / setup . c , this information is
* transferred into the e820map , and in arch / i386 / mm / init . c , that
* new information is used to mark pages reserved or not .
*
*/
# ifndef __E820_HEADER
# define __E820_HEADER
# define E820MAP 0x2d0 /* our map */
2005-05-01 19:58:51 +04:00
# define E820MAX 128 /* number of entries in E820MAP */
2005-04-17 02:20:36 +04:00
# define E820NR 0x1e8 /* # entries in E820MAP */
# define E820_RAM 1
# define E820_RESERVED 2
2006-09-26 12:52:38 +04:00
# define E820_ACPI 3
2005-04-17 02:20:36 +04:00
# define E820_NVS 4
# define HIGH_MEMORY (1024*1024)
# ifndef __ASSEMBLY__
2007-07-11 23:18:34 +04:00
struct e820entry {
u64 addr ; /* start of memory segment */
u64 size ; /* size of memory segment */
u32 type ; /* type of memory segment */
} __attribute__ ( ( packed ) ) ;
2005-04-17 02:20:36 +04:00
struct e820map {
2007-07-11 23:18:34 +04:00
u32 nr_map ;
struct e820entry map [ E820MAX ] ;
2005-04-17 02:20:36 +04:00
} ;
extern struct e820map e820 ;
2006-04-07 21:49:27 +04:00
extern int e820_all_mapped ( unsigned long start , unsigned long end ,
unsigned type ) ;
2007-05-02 21:27:11 +04:00
extern int e820_any_mapped ( u64 start , u64 end , unsigned type ) ;
2006-12-07 04:14:06 +03:00
extern void find_max_pfn ( void ) ;
2006-12-07 04:14:06 +03:00
extern void register_bootmem_low_pages ( unsigned long max_low_pfn ) ;
2006-12-22 12:09:54 +03:00
extern void e820_register_memory ( void ) ;
2006-12-07 04:14:06 +03:00
extern void limit_regions ( unsigned long long size ) ;
extern void print_memory_map ( char * who ) ;
2006-04-07 21:49:27 +04:00
2005-04-17 02:20:36 +04:00
# endif /*!__ASSEMBLY__*/
# endif /*__E820_HEADER*/