Re: pci_alloc_consistent for small allocations?

Johannes Erdfelt (johannes@erdfelt.com)
Sun, 2 Sep 2001 12:43:22 -0400


On Sun, Sep 02, 2001, Adam J. Richter <adam@yggdrasil.com> wrote:
> In looking at the ieee1394 OHCI driver, I noticed that it
> appears to make 104 calls to pci_alloc_consistent for data structures
> that are 16 or 64 bytes. Currently, on x86, pci_alloc_consistent
> allocates at least one full page per call, so it looks like the
> ohci1394 driver allocates 416kB per controller as a result of these
> data structures.
>
> It is easy enough to change the ohci driver to just
> do a few pci_alloc_consistent calls, but, in grepping through the
> kernel, I see that there are lots of calls to pci_alloc_consistent
> calls requesting small amounts of memory. So, I think it might reduce
> kernel memory consumption to have pci_alloc_consistent do something
> slightly smarter for allocations of less than a page. Two pretty
> simple approaches come to mind:
>
> 1. If it is the case that a side effect of the slab memory allocator
> is that allocations of less than a page (or a certain size) never cross
> page boundaries, then the x86 version of pci_alloc_consistent can just
> use kmalloc/kfree when the size is below a certain amount. Could someone
> tell me if this is the case?
>
> 2. Assuming that is not the case, I have written, but not yet tested,
> a change to pci_alloc_consistent for x86 where sub-page allocations can share
> a single page. The first four bytes of a shared page are used as a
> reference counter. This would be two bytes were it not for alignment
> considerations. This change can only aggregate small allocations when
> they occur in succession. I have attached the patch for illustration, but,
> it could use some better variable naming and, I repeat, I have not tested
> it at all yet. In the middle of working on it, I thought of option #1 and
> figured I should ask on linux-kernel before investing more time in this idea.

Just use pci_pool. We developed the API for USB where we ran into the
same problem.

JE

-
To unsubscribe from this list: send the line "unsubscribe linux-kernel" in
the body of a message to majordomo@vger.kernel.org
More majordomo info at http://vger.kernel.org/majordomo-info.html
Please read the FAQ at http://www.tux.org/lkml/