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: <4C65193E.4090807@gmail.com> Date: Fri, 13 Aug 2010 12:06:54 +0200 From: Martin Fuzzey <mfuzzey@...il.com> To: Matthieu CASTET <matthieu.castet@...rot.com> CC: Russell King - ARM Linux <linux@....linux.org.uk>, 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" <netdev@...r.kernel.org>, Greg KH <greg@...ah.com> Subject: Re: Problem with non aligned DMA in usbnet on ARM Matthieu CASTET wrote: > memmove is our friend : > the buffer allocated in usbnet got an offset. > All you have to do it remove this offset and memmove the data. That > what I did [1], and why it is better to do it in usb driver. > > > [1] http://article.gmane.org/gmane.linux.usb.general/28700 The problem I see with this approach is that it requires the usb driver to be aware of the device controller's quirks (hence the gadget_dma32()) your patch adds. That appears to be the norm (and maybe unavoidable) on the gadget side but on the host side things aren't supposed to work like that. The expectation for USB hosts is that any properly written usb driver will work with any properly written host controller driver. I don't think it's reasonable to expect driver developers to test their code with all the HCDs, nor expect HCD developers to test their code with all the drivers. So I think a policy needs to be defined to ensure this and enforced in the code. I can see two possible methods: 1) Require that usb drivers submit buffers obtained from kmalloc() and friends with no extra offsets. If they want some other alignment later they can use memmove in the completion handler. Enforce this in the core by checking the buffer pointers are aligned to ARCH_KMALLOC_MINALIGN or 2) Require that usb_submit_urb() accept byte aligned buffers. Enforce this by a new test in usbtest (which all HCDs are expected to pass). Implement it either in individual HCDs that require it or by letting HCDs inform the core of their requirements and have the core do the alignment (as it already does the dma mapping). Of course HCDs that can implement byte aligned transfers (either natively or using tricks such as the one Russell suggested) should do so. I think 2) is the better solution because: a) Solution 1 will impose a runtime overhead even on platforms / HCDs that don't need it (including the most common cases) b) There are more drivers than HCDs Martin -- 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