driver memory management

Dan Malek dan at mvista.com
Sun Jan 7 07:55:13 EST 2001


Dan Winkler wrote:
>
> I am having some difficulties allocating memory larger than the memory
> available in cpm_host_alloc, cpm_host_alloc seems to use part of a
> predesignated 4K buffer of memory.


I don't quite understand this collection of words, but I will try
to explain some of this.  The cpm_host_alloc() is intended to be
used only by those devices that require small amounts of memory,
significantly less a page size or so.  Like the UART FIFOs and
things like that.  If you notice other drivers (Ethernet for example)
it allocates its own memory and associates it with the BDs.

> pBuff = kmalloc(TRANSMIT_SIZE, GFP_KERNEL|GFP_DMA);
>
> the only problem with this is when I go to copy data to this location it
> fails i.e.

Yeah, you probably get a big time kernel crash due to a bus fault.

> memcpy(__va(pBuff), pSrc, size)
>
> Any Suggestions as to what might be going on.

Yeah, pBuff is a kernel virtual address from kmalloc.  You don't
use the __va() operation on this type of address.  I don't know why
you need to copy this, but you should simply use:

	memcpy(pBuff, pSrc, size)

and then put __pa(pBuff) in the BD.  Of course, the "right" thing
to do is simply track down the physical pages to pSrc and stuff those
into the BDs without allocating or copying any memory (or preallocate
the buffer using kmalloc and tell the data provider to use that).


	-- Dan

** Sent via the linuxppc-embedded mail list. See http://lists.linuxppc.org/





More information about the Linuxppc-embedded mailing list