[kaffe] Help with Heap Allocation Functions

Tony Wyatt wyattaw at optushome.com.au
Sat Feb 8 15:16:02 PST 2003


Greetings, fellow kaffe drinkers.

I am trying to make kaffe 1.0.7 run on the m68k, under AmigaOS 
3.9. It is supposed to run, but doesn't, for a number of reasons. I 
guess the Amiga configuration has been left untested for some time. 
I am configuring/compiling/testing it in a Geek Gadgets environment, 
using gcc 2.95.2. I have already installed, built and tested gmp-4.1 
successfully, so something works.

First question: I've managed to get the whole kaffe suite to compile 
and build by editing some Makefile's and the config.h file. The 
changes were necessary to repair some syntax errors in the m68k 
Makefiles and correct some processor options. But when I run the 
/test/regression tests, a few run without error, but most trap out with 
the error:
"Failed assertion 'block->avail > 0'"

For HelloWorldApp, the trap happens right after a request for a block 
of size 32776 bytes (the first request > 32768). The address of the 
block returned seems crazy, being in the middle of the range of 
already-allocated memory. Suffice it to say that there is no valid gc-
block in the vicinity.

I have the same build on an x86 Linux machine, and it runs fine. I 
can even compare the memory requests and identify the same 
request on the Linux side - it returns with a reasonable pointer and 
works. I have been trying to compare the behaviour of the two 
systems, but I don't understand the structure of the heap or the 
blocks that are allocated.

As a test, I commented-out the "PREDEFINED_NO_OF_TILES" in 
gc-mem.c and rebuilt it. It then trapped out with the error:
"Failed assertion 'currentjThread == lastThread'"

It would seem likely that there is a 16-bit integer problem here 
somewhere. I have checked the gcc options and the code generated 
in likely places - all seem to use 32-bit arithmetic. Has anyone any 
insight, or is there some in-depth documentation available for this 
area of code (mem/gc-mem.c)?

Second question: Just running HelloWorldApp generates about 
26,000 memory allocation requests during execution. Is this 
extraordinary overhead normal?

cheers

tony wyatt




More information about the kaffe mailing list