Was: Re: [RFC PATCH] fix problems with NETIF_F_HIGHDMA innetworking, Now: SWIOTLB dynamic allocation

From: Konrad Rzeszutek Wilk
Date: Mon Mar 01 2010 - 11:58:51 EST


On Sun, Feb 28, 2010 at 12:16:28AM -0800, David Miller wrote:
> From: FUJITA Tomonori <fujita.tomonori@xxxxxxxxxxxxx>
> Date: Sun, 28 Feb 2010 03:38:19 +0900
>
> > When I proposed such approach (always use swiotlb) before, IIRC,
> > the objections were:
> >
> > - better to make allocation respect dma_mask. (I don't think that this
> > approach is possible since we don't know which device handles data
> > later when we allocate memory).
>
> And such objects might end up being processed by multiple devices with
> different DMA restrictions.
>
> > - swiotlb is not good for small systems since it allocates too much
> > memory (we can fix this though).
>
> Indeed.

What would be a good mechanism for this? Enumerating all of the PCI
devices to find out which ones are 32-bit and then allocate some chunk
of memory based on the amount of them? say, 1MB per card?

Or maybe a simpler one - figure out how many pages we have an allocate
based on some sliding rule (say, 8MB for under 512MB, 16MB between 512MB
and 2GB, and 32MB for 2GB to 4GB, and after that the full 64MB?)

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