mirror of
https://github.com/torvalds/linux.git
synced 2025-01-01 15:51:46 +00:00
f9ba70535d
The specifications that talk about E820 map doesn't have an upper limit on the number of e820 entries. But, today's kernel has a hard limit of 32. With increase in memory size, we are seeing the number of E820 entries reaching close to 32. Patch below bumps the number upto 128. The patch changes the location of EDDBUF in zero-page (as it comes after E820). As, EDDBUF is not used by boot loaders, this patch should not have any effect on bootloader-setup code interface. Patch covers both i386 and x86-64. Tested on: * grub booting bzImage * lilo booting bzImage with EDID info enabled * pxeboot of bzImage Side-effect: bss increases by ~ 2K and init.data increases by ~7.5K on all systems, due to increase in size of static arrays. Signed-off-by: Venkatesh Pallipadi <venkatesh.pallipadi@intel.com> Signed-off-by: Andrew Morton <akpm@osdl.org> Signed-off-by: Linus Torvalds <torvalds@osdl.org>
61 lines
1.7 KiB
C
61 lines
1.7 KiB
C
/*
|
|
* structures and definitions for the int 15, ax=e820 memory map
|
|
* scheme.
|
|
*
|
|
* In a nutshell, setup.S populates a scratch table in the
|
|
* empty_zero_block that contains a list of usable address/size
|
|
* duples. setup.c, this information is transferred into the e820map,
|
|
* and in init.c/numa.c, that new information is used to mark pages
|
|
* reserved or not.
|
|
*/
|
|
#ifndef __E820_HEADER
|
|
#define __E820_HEADER
|
|
|
|
#include <linux/mmzone.h>
|
|
|
|
#define E820MAP 0x2d0 /* our map */
|
|
#define E820MAX 128 /* number of entries in E820MAP */
|
|
#define E820NR 0x1e8 /* # entries in E820MAP */
|
|
|
|
#define E820_RAM 1
|
|
#define E820_RESERVED 2
|
|
#define E820_ACPI 3 /* usable as RAM once ACPI tables have been read */
|
|
#define E820_NVS 4
|
|
|
|
#define HIGH_MEMORY (1024*1024)
|
|
|
|
#define LOWMEMSIZE() (0x9f000)
|
|
|
|
#ifndef __ASSEMBLY__
|
|
struct e820entry {
|
|
u64 addr; /* start of memory segment */
|
|
u64 size; /* size of memory segment */
|
|
u32 type; /* type of memory segment */
|
|
} __attribute__((packed));
|
|
|
|
struct e820map {
|
|
int nr_map;
|
|
struct e820entry map[E820MAX];
|
|
};
|
|
|
|
extern unsigned long find_e820_area(unsigned long start, unsigned long end,
|
|
unsigned size);
|
|
extern void add_memory_region(unsigned long start, unsigned long size,
|
|
int type);
|
|
extern void setup_memory_region(void);
|
|
extern void contig_e820_setup(void);
|
|
extern unsigned long e820_end_of_ram(void);
|
|
extern void e820_reserve_resources(void);
|
|
extern void e820_print_map(char *who);
|
|
extern int e820_mapped(unsigned long start, unsigned long end, unsigned type);
|
|
|
|
extern void e820_bootmem_free(pg_data_t *pgdat, unsigned long start,unsigned long end);
|
|
extern void e820_setup_gap(void);
|
|
|
|
extern void __init parse_memopt(char *p, char **end);
|
|
|
|
extern struct e820map e820;
|
|
#endif/*!__ASSEMBLY__*/
|
|
|
|
#endif/*__E820_HEADER*/
|