Don't allocate the heap with of_claim(), but rather use

platform_allocation_region(). Since the callback stuff doesn't seem to
work, the Open Firmware didn't ask us to allocate memory in turn, and
thus we didn't know about the range that had been mapped and reused it
later.


git-svn-id: file:///srv/svn/repos/haiku/haiku/trunk@15699 a95241bf-73f2-0310-859d-f6bbb57e9c96
This commit is contained in:
Ingo Weinhold 2005-12-28 19:54:19 +00:00
parent f5b6cf65b2
commit ea5b67a88b

View File

@ -3,6 +3,7 @@
* Distributed under the terms of the MIT License. * Distributed under the terms of the MIT License.
*/ */
#include <OS.h>
#include <boot/platform.h> #include <boot/platform.h>
#include <boot/heap.h> #include <boot/heap.h>
@ -23,18 +24,12 @@ platform_init_heap(stage2_args *args, void **_base, void **_top)
{ {
TRACE(("platform_init_heap()\n")); TRACE(("platform_init_heap()\n"));
int memory; *_base = NULL;
if (of_getprop(gChosen, "memory", &memory, sizeof(int)) == OF_FAILED) status_t error = platform_allocate_region(_base, args->heap_size,
return B_ERROR; B_READ_AREA | B_WRITE_AREA);
if (error != B_OK)
return error;
printf("memory = %d\n", memory);
struct of_region available;
int memPackage = of_instance_to_package(memory);
printf("memPackage = %d\n", memPackage);
of_getprop(memPackage, "available", &available, sizeof(struct of_region));
printf("available: base = %p, size = %ld\n", available.base, available.size);
*_base = of_claim(available.base, args->heap_size, 64);
printf("heap base = %p\n", *_base); printf("heap base = %p\n", *_base);
*_top = (void *)((int8 *)*_base + args->heap_size); *_top = (void *)((int8 *)*_base + args->heap_size);
printf("heap top = %p\n", *_top); printf("heap top = %p\n", *_top);
@ -47,6 +42,6 @@ void
platform_release_heap(stage2_args *args, void *base) platform_release_heap(stage2_args *args, void *base)
{ {
if (base != NULL) if (base != NULL)
of_release(base, args->heap_size); platform_free_region(base, args->heap_size);
} }