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:
Axel Dörfler 2004-10-19 17:08:31 +00:00
parent a3a0808085
commit 1e25c041ec

View File

@ -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;
} }