2019-05-31 15:45:59 +02:00
|
|
|
// Physical memory layout
|
2011-08-07 18:30:34 +02:00
|
|
|
|
2019-05-31 15:45:59 +02:00
|
|
|
// qemu -machine virt is set up like this:
|
|
|
|
// 00001000 -- boot ROM, provided by qemu
|
|
|
|
// 10000000 -- uart0 registers
|
|
|
|
// 80000000 -- boot ROM jumps here in machine mode
|
|
|
|
// unused RAM after 80000000.
|
2011-08-07 18:30:34 +02:00
|
|
|
|
2019-05-31 15:45:59 +02:00
|
|
|
// the kernel uses physical memory thus:
|
|
|
|
// 80000000 -- entry.S, then kernel text and data
|
|
|
|
// end -- start of kernel page allocation area
|
|
|
|
// PHYSTOP -- end RAM used by the kernel
|
2011-08-07 18:30:34 +02:00
|
|
|
|
2019-05-31 15:45:59 +02:00
|
|
|
// registers start here in physical memory.
|
|
|
|
#define UART0 0x10000000L
|
2011-08-07 18:30:34 +02:00
|
|
|
|
2019-05-31 15:45:59 +02:00
|
|
|
// the kernel expects there to be RAM
|
|
|
|
// for use by the kernel and user pages
|
|
|
|
// from physical address 0x80000000 to PHYSTOP.
|
|
|
|
#define KERNBASE 0x80000000L
|
|
|
|
#define PHYSTOP (KERNBASE + 64*1024*1024)
|
|
|
|
|
|
|
|
// map the trampoline page to the highest address,
|
|
|
|
// in both user and kernel space.
|
|
|
|
#define TRAMPOLINE (MAXVA - PGSIZE)
|