Removed kernel_args::str initialization, since it is no longer there.
Added a kMaxKernelSize constant to be able to change that limit a bit easier. git-svn-id: file:///srv/svn/repos/haiku/trunk/current@9415 a95241bf-73f2-0310-859d-f6bbb57e9c96
This commit is contained in:
parent
a3a0808085
commit
1e25c041ec
@ -1,7 +1,7 @@
|
|||||||
/*
|
/*
|
||||||
** Copyright 2004, Axel Dörfler, axeld@pinc-software.de. All rights reserved.
|
** Copyright 2004, Axel Dörfler, axeld@pinc-software.de. All rights reserved.
|
||||||
** Based on code written by Travis Geiselbrecht for NewOS.
|
** Based on code written by Travis Geiselbrecht for NewOS.
|
||||||
** Distributed under the terms of the OpenBeOS License.
|
** Distributed under the terms of the Haiku License.
|
||||||
*/
|
*/
|
||||||
|
|
||||||
|
|
||||||
@ -32,7 +32,7 @@
|
|||||||
* on. The kernel is mapped at 0x80000000, all other stuff mapped by the
|
* on. The kernel is mapped at 0x80000000, all other stuff mapped by the
|
||||||
* loader (kernel args, modules, driver settings, ...) comes after
|
* loader (kernel args, modules, driver settings, ...) comes after
|
||||||
* 0x81000000 which means that there is currently only 1 MB reserved for
|
* 0x81000000 which means that there is currently only 1 MB reserved for
|
||||||
* the kernel itself.
|
* the kernel itself (see kMaxKernelSize).
|
||||||
*/
|
*/
|
||||||
|
|
||||||
//#define TRACE_MMU
|
//#define TRACE_MMU
|
||||||
@ -55,6 +55,7 @@ struct extended_memory {
|
|||||||
};
|
};
|
||||||
|
|
||||||
static const uint32 kDefaultPageFlags = 0x03; // present, R/W
|
static const uint32 kDefaultPageFlags = 0x03; // present, R/W
|
||||||
|
static const size_t kMaxKernelSize = 0x100000; // 1 MB for the kernel
|
||||||
|
|
||||||
// working page directory and page table
|
// working page directory and page table
|
||||||
static uint32 *sPageDirectory = 0;
|
static uint32 *sPageDirectory = 0;
|
||||||
@ -62,7 +63,8 @@ static uint32 *sPageTable = 0;
|
|||||||
// this points to the most recently added kernel page table
|
// this points to the most recently added kernel page table
|
||||||
|
|
||||||
static addr_t sNextPhysicalAddress = 0x110000;
|
static addr_t sNextPhysicalAddress = 0x110000;
|
||||||
static addr_t sNextVirtualAddress = KERNEL_BASE + 0x100000;
|
static addr_t sNextVirtualAddress = KERNEL_BASE + kMaxKernelSize;
|
||||||
|
static addr_t sMaxVirtualAddress = KERNEL_BASE + 0x400000;
|
||||||
|
|
||||||
|
|
||||||
static addr_t
|
static addr_t
|
||||||
@ -268,7 +270,7 @@ mmu_allocate(void *virtualAddress, size_t size)
|
|||||||
addr_t address = (addr_t)virtualAddress;
|
addr_t address = (addr_t)virtualAddress;
|
||||||
|
|
||||||
// is the address within the valid range?
|
// is the address within the valid range?
|
||||||
if (address < KERNEL_BASE || address + size >= KERNEL_BASE + 0x100000)
|
if (address < KERNEL_BASE || address + size >= KERNEL_BASE + kMaxKernelSize)
|
||||||
return NULL;
|
return NULL;
|
||||||
|
|
||||||
for (uint32 i = 0; i < size; i++) {
|
for (uint32 i = 0; i < size; i++) {
|
||||||
@ -494,9 +496,6 @@ mmu_init(void)
|
|||||||
gKernelArgs.num_physical_allocated_ranges++;
|
gKernelArgs.num_physical_allocated_ranges++;
|
||||||
}
|
}
|
||||||
|
|
||||||
gKernelArgs.str = NULL;
|
|
||||||
// ToDo: what was this intended for?
|
|
||||||
|
|
||||||
gKernelArgs.arch_args.page_hole = 0xffc00000;
|
gKernelArgs.arch_args.page_hole = 0xffc00000;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
Loading…
Reference in New Issue
Block a user