memcpy alignment for DEVICE_nGnRnE

Catalin Marinas catalin.marinas at arm.com
Tue Apr 8 04:49:49 PDT 2014


On Tue, Apr 08, 2014 at 01:35:47AM +0100, Michael Bohan wrote:
> On Fri, Feb 21, 2014 at 10:53:08AM +0000, Catalin Marinas wrote:
> > On Fri, Feb 21, 2014 at 09:58:27AM +0000, Zhou Zhu wrote:
> > > We faced one issue using memcpy for memory type DEVICE_nGnRnE 
> > > (pgprot_noncached). If the address is not aligned, exception would 
> > > happen due to the alignment of this type could not be handled by hardware.
> > 
> > Indeed, that's expected. This memory type is the equivalent of Strongly
> > Ordered.
> > 
> > > Is there any plan and ongoing patch to support this or we need to keep 
> > > address aligned for memcpy using pgprot_noncached memory in drivers?
> > 
> > You either change the memory type to pgprot_writecombine() or use the
> > right API (memcpy_toio/memcpy_fromio, these could be further optimised,
> > similar to powerpc for example, but I didn't get there yet).
> 
> How should we handle Device Memory with copy_from_user / copy_to_user?
> Should we follow the same scheme and create
> copy_from_user_io / copy_to_user_io, or rather enforce that the stock
> routines handle alignment?

We have generic copy_from_user_toio() and copy_to_user_fromio(). Are
these what you need? As with the memcpy_(to|from)io, they can be further
optimised.

-- 
Catalin



More information about the linux-arm-kernel mailing list