lists.openwall.net | lists / announce owl-users owl-dev john-users john-dev passwdqc-users yescrypt popa3d-users / oss-security kernel-hardening musl sabotage tlsify passwords / crypt-dev xvendor / Bugtraq Full-Disclosure linux-kernel linux-netdev linux-ext4 linux-hardening linux-cve-announce PHC | |
Open Source and information security mailing list archives
| ||
|
Message-ID: <20100811224729.GD827@n2100.arm.linux.org.uk> Date: Wed, 11 Aug 2010 23:47:29 +0100 From: Russell King - ARM Linux <linux@....linux.org.uk> To: Martin Fuzzey <mfuzzey@...il.com> Cc: Gary King <GKing@...dia.com>, "linux-arm-kernel@...ts.infradead.org" <linux-arm-kernel@...ts.infradead.org>, linux-usb <linux-usb@...r.kernel.org>, netdev@...r.kernel.org, Greg KH <greg@...ah.com> Subject: Re: Problem with non aligned DMA in usbnet on ARM On Thu, Aug 12, 2010 at 12:20:07AM +0200, Martin Fuzzey wrote: > [Gary, you forgot to copy -usb and netdev so adding them again to try to > keep this thread joined up] > > Russell King - ARM Linux wrote: > > On Wed, Aug 11, 2010 at 08:54:27AM -0700, Gary King wrote: > > > >> I sent a patch to the list about 2 weeks ago that added support to > >> DMA bounce to bounce for misaligned buffers. We have a similar > >> problem with URB alignment for usbnet on Tegra's HCD: > >> http://lists.arm.linux.org.uk/lurker/message/20100729.005746.b43fa1d9.en.html > > Nice to know someone else has the same problem :) > What is the Tegra hcd? > I can't find it in the kernel sources. > > > We don't want to add support for this to DMA bounce. DMA bounce is already > > a pain in the backside and causes its own set of problems - please let it > > die a long slow but quite death. > > > > If you want to see the kind of pain dmabounce causes, look at this long > > standing and as yet unsolved bug: > > > > http://bugzilla.kernel.org/show_bug.cgi?id=7760 > > Well I don't know the dmabounce code but why is using it likely to cause > OOM problems (at least why more so than copying the buffer in the HCD or > the usb core). The problem in that bug appears to be that there's soo much pressure on the first 64MB of memory that we run out of sufficiently large blocks of memory to be able to satisfy the requirements to do DMA bouncing via the dmabounce code. I don't think anyone got to the bottom of why the DMA zone was exhausted first before the DMA32 zone ran out of pages. However, as something using dma_map_single/dma_map_page has to return a contiguous buffer, we do need to use high order allocations for them - a driver on the other hand can make a decision about whether its possible to break up the buffer into smaller (and therefore easier to allocate) buffers. > In both cases there will be two copies of the buffer in > memory which could I agree be a problem in memory constrained systems. > But if we _do_ want to accept unaligned buffers from usb drivers I can't > see a way round that. One thing we have done in the past (eg, SMC91x network driver on PXA) is to PIO the first couple of bytes to the device, and DMA the remainder - the DMA can't do non-word aligned start addresses. This gives us the benefit of being able to deal with buffers containing IP packets without copying them, while preserving the performance of using DMA. -- To unsubscribe from this list: send the line "unsubscribe netdev" in the body of a message to majordomo@...r.kernel.org More majordomo info at http://vger.kernel.org/majordomo-info.html
Powered by blists - more mailing lists