On Friday 06 July 2007, Timur Tabi wrote:
> Arnd Bergmann wrote:
> 
> > Not sure exactly what arm does here, but it sounds like you want
> > to call remap_pfn_range with the _PAGE_NO_CACHE bit set in the
> > protection flags, and _PAGE_GUARDED not set.
> 
> I always have a hard time with these mapping functions.  Is this right?
> 
> vma->vm_page_prot = __pgprot((pgprot_val(vma->vm_page_prot) | _PAGE_NO_CACHE) 
> & 
> ~_PAGE_GUARDED));
> 
> ret = remap_pfn_range(vma, vma->vm_start, runtime->dma_addr, 
> runtime->dma_bytes, 
> vma->vm_page_prot);
> 
> Alternatively, could I use function snd_pcm_lib_mmap_iomem() 
> (sound/core/pcm_native.c)? 
> It looks like it does the right thing, although it doesn't unset the guarded 
> bit.  If 
> that's wrong, I can submit a patch to unset that bit on PowerPC, but like I 
> said, I can 
> never quite get my head around this mapping stuff.

The guarded bit is disabled by default, so you don't need t remove it, so
the function you quoted should be alright for this purpose. Not sure if you
need the ioremap in there though.

        Arnd <><
_______________________________________________
Linuxppc-dev mailing list
Linuxppc-dev@ozlabs.org
https://ozlabs.org/mailman/listinfo/linuxppc-dev

Reply via email to