Re: [PATCH 8/9] ide: switch to DMA-mapping API

From: Bryan Wu
Date: Wed Jan 02 2008 - 03:34:57 EST


On Dec 28, 2007 3:12 AM, Bartlomiej Zolnierkiewicz <bzolnier@xxxxxxxxx> wrote:
> * pci_map_sg() -> dma_map_sg() in ide_build_sglist().
>
> * pci_unmap_sg() -> dma_unmap_sg() in ide_destroy_dmatable().
>
> There should be no functionality changes caused by this patch except
> for blackfin arch whose dma_[un]map_sg() implementation differs from
> pci_[un]map_sg() one (on s390 arch there is no PCI, on avr32 and h8300
> archs PCI is currently unsupported, on m32r arch PCI support depends
> on BROKEN, on m68k arch PCI support depends on HADES which in turn
> depends on BROKEN, on all other archs dma_[un]map_sg() functionality
> matches with pci_[un]map_sg() one).
>

Thanks a lot for this carefully check with Blackfin.
Please go ahead with this patch change, we plan to remove PCI useless
header file in Blackfin like AVR32

-Bryan

> Cc: Bryan Wu <bryan.wu@xxxxxxxxxx>
> Signed-off-by: Bartlomiej Zolnierkiewicz <bzolnier@xxxxxxxxx>
> ---
> It seems like blackfin arch should be using <asm-generic/pci-dma-compat.h>
> in <asm-blackfin/pci.h> or drivers still using PCI DMA-mapping API instead
> of the generic one won't work but I'll leave this to blackfin gurus...
>
> [ Bryan, could you please take a look? Thanks. ]
>
> drivers/ide/ide-dma.c | 18 +++++++++---------
> 1 file changed, 9 insertions(+), 9 deletions(-)
>
> Index: b/drivers/ide/ide-dma.c
> ===================================================================
> --- a/drivers/ide/ide-dma.c
> +++ b/drivers/ide/ide-dma.c
> @@ -85,6 +85,7 @@
> #include <linux/ide.h>
> #include <linux/delay.h>
> #include <linux/scatterlist.h>
> +#include <linux/dma-mapping.h>
>
> #include <asm/io.h>
> #include <asm/irq.h>
> @@ -175,26 +176,26 @@ static int ide_dma_good_drive(ide_drive_
> * @drive: the drive to build the DMA table for
> * @rq: the request holding the sg list
> *
> - * Perform the PCI mapping magic necessary to access the source or
> - * target buffers of a request via PCI DMA. The lower layers of the
> + * Perform the DMA mapping magic necessary to access the source or
> + * target buffers of a request via DMA. The lower layers of the
> * kernel provide the necessary cache management so that we can
> - * operate in a portable fashion
> + * operate in a portable fashion.
> */
>
> int ide_build_sglist(ide_drive_t *drive, struct request *rq)
> {
> ide_hwif_t *hwif = HWIF(drive);
> - struct pci_dev *pdev = to_pci_dev(hwif->dev);
> struct scatterlist *sg = hwif->sg_table;
>
> ide_map_sg(drive, rq);
>
> if (rq_data_dir(rq) == READ)
> - hwif->sg_dma_direction = PCI_DMA_FROMDEVICE;
> + hwif->sg_dma_direction = DMA_FROM_DEVICE;
> else
> - hwif->sg_dma_direction = PCI_DMA_TODEVICE;
> + hwif->sg_dma_direction = DMA_TO_DEVICE;
>
> - return pci_map_sg(pdev, sg, hwif->sg_nents, hwif->sg_dma_direction);
> + return dma_map_sg(hwif->dev, sg, hwif->sg_nents,
> + hwif->sg_dma_direction);
> }
>
> EXPORT_SYMBOL_GPL(ide_build_sglist);
> @@ -308,9 +309,8 @@ EXPORT_SYMBOL_GPL(ide_build_dmatable);
> void ide_destroy_dmatable (ide_drive_t *drive)
> {
> ide_hwif_t *hwif = drive->hwif;
> - struct pci_dev *pdev = to_pci_dev(hwif->dev);
>
> - pci_unmap_sg(pdev, hwif->sg_table, hwif->sg_nents,
> + dma_unmap_sg(hwif->dev, hwif->sg_table, hwif->sg_nents,
> hwif->sg_dma_direction);
> }
>
> --
> To unsubscribe from this list: send the line "unsubscribe linux-kernel" in
> the body of a message to majordomo@xxxxxxxxxxxxxxx
> More majordomo info at http://vger.kernel.org/majordomo-info.html
> Please read the FAQ at http://www.tux.org/lkml/
>
--
To unsubscribe from this list: send the line "unsubscribe linux-kernel" in
the body of a message to majordomo@xxxxxxxxxxxxxxx
More majordomo info at http://vger.kernel.org/majordomo-info.html
Please read the FAQ at http://www.tux.org/lkml/