On Thu, May 18, 2006 at 10:58:48AM -0700, Chad Reese wrote:
Hello All,
I've spent the last few days trying to get SPARSEMEM to work on a 64bit Mips
kernel. The processor I'm using has large wholes in its memory map.
Memory layout:
0 - 0x10000000 First 256MB
0x410000000 - 0x420000000 Second 256MB
0x20000000 - ? The rest of memory
Up until now I've used the flat memory model and not mapped the 2nd 256MB. This
is rather wasteful for boards with 512MB of memory. SPARSEMEM look like what I
Yep, SPARSEMEM is what you want. BTW, doublecheck your line wrap
settings on your mailer...they're messed up.
need, but I've been unable to get it working. My attempts to configure it always
end with sparse_index_alloc calling alloc_bootmem_node which fails to allocate
4KB. In prom_init I've added memory using add_memory_region.
But where have you added everything else? Where are you registering the
sparsemem and initializing it? It sounds like you are either getting
an invalid node passed into the alloc_bootmem_node or you are calling
the bootmem allocator much later and it is failing.
Are there any reasonably easy to follow implementations of sparsemem? I figure
None that I know of, excpet for the i386, ia64, and powerpc
implementations. i386 is fairly straightforward except for all
the EFI magic.
I'm missing something very basic, but perusal of Mips and the other
architectures haven't helped much.
My baseline is linux-mips 2.6.14.
Any help would be appreciated,
I suggest working back from your bootmem allocation failure to
understand why that is failing.
-Matt