DMABOUNCE in pci-rcar
Arnd Bergmann
arnd at arndb.de
Thu Mar 20 14:29:13 EDT 2014
On Thursday 20 March 2014, Ben Dooks wrote:
> On 20/03/14 18:31, Jason Gunthorpe wrote:
> > On Thu, Mar 20, 2014 at 06:25:25PM +0100, Ben Dooks wrote:
> >> So doing:
> >>
> >> static void pci_rcar_fixup(struct pci_dev *dev)
> >> {
> >> if (dev->bus->ops == &rcar_pci_ops) {
> >> dev_info(&dev->dev, "applying new dma mask\n");
> >> dev->dma_mask = DMA_BIT_MASK(31);
> >> }
> >> }
> >>
> >> DECLARE_PCI_FIXUP_EARLY(PCI_ANY_ID, PCI_ANY_ID, pci_rcar_fixup);
> >>
> >> Did not work for me :(
> >
> > Seems like it should work, do you have CONFIG_PCI_QUIRKS turned on?
>
> Yes, see the print happening, just still PCI OHCI dies horribly.
Shouldn't that mask be 30 instead of 31 when you only support DMA
to the first GB?
Another possibility is that 'EARLY' means it gets applied before
the normal mask is set.
Finally, setting the mask itself is not enough. As I mentioned you
also need to use the swiotlb_dma_ops. Did you already implement
those?
Arnd
More information about the linux-arm-kernel
mailing list