[PATCH 09/15] ppc/vio: use dma ops helpers

Grant Likely grant.likely at secretlab.ca
Thu Sep 16 04:33:30 EST 2010


On Wed, Sep 15, 2010 at 12:05 PM, Nishanth Aravamudan <nacc at us.ibm.com> wrote:
> Use the set_dma_ops helper. Instead of modifying vio_dma_mapping_ops,
> just create a trivial wrapper for dma_supported.
>
> Signed-off-by: Milton Miller <miltonm at bga.com>
> Signed-off-by: Nishanth Aravamudan <nacc at us.ibm.com>

Looks right to me.

> ---
>  arch/powerpc/kernel/vio.c |   11 ++++++++---
>  1 files changed, 8 insertions(+), 3 deletions(-)
>
> diff --git a/arch/powerpc/kernel/vio.c b/arch/powerpc/kernel/vio.c
> index d692989..3c3083f 100644
> --- a/arch/powerpc/kernel/vio.c
> +++ b/arch/powerpc/kernel/vio.c
> @@ -602,6 +602,11 @@ static void vio_dma_iommu_unmap_sg(struct device *dev,
>        vio_cmo_dealloc(viodev, alloc_size);
>  }
>
> +static int vio_dma_iommu_dma_supported(struct device *dev, u64 mask)
> +{
> +        return dma_iommu_ops.dma_supported(dev, mask);
> +}
> +
>  struct dma_map_ops vio_dma_mapping_ops = {
>        .alloc_coherent = vio_dma_iommu_alloc_coherent,
>        .free_coherent  = vio_dma_iommu_free_coherent,
> @@ -609,6 +614,7 @@ struct dma_map_ops vio_dma_mapping_ops = {
>        .unmap_sg       = vio_dma_iommu_unmap_sg,
>        .map_page       = vio_dma_iommu_map_page,
>        .unmap_page     = vio_dma_iommu_unmap_page,
> +       .dma_supported  = vio_dma_iommu_dma_supported,
>
>  };
>
> @@ -860,8 +866,7 @@ static void vio_cmo_bus_remove(struct vio_dev *viodev)
>
>  static void vio_cmo_set_dma_ops(struct vio_dev *viodev)
>  {
> -       vio_dma_mapping_ops.dma_supported = dma_iommu_ops.dma_supported;
> -       viodev->dev.archdata.dma_ops = &vio_dma_mapping_ops;
> +       set_dma_ops(&viodev->dev, &vio_dma_mapping_ops);
>  }
>
>  /**
> @@ -1246,7 +1251,7 @@ struct vio_dev *vio_register_device_node(struct device_node *of_node)
>        if (firmware_has_feature(FW_FEATURE_CMO))
>                vio_cmo_set_dma_ops(viodev);
>        else
> -               viodev->dev.archdata.dma_ops = &dma_iommu_ops;
> +               set_dma_ops(&viodev->dev, &dma_iommu_ops);
>        set_iommu_table_base(&viodev->dev, vio_build_iommu_table(viodev));
>        set_dev_node(&viodev->dev, of_node_to_nid(of_node));
>
> --
> 1.7.0.4
>
>



-- 
Grant Likely, B.Sc., P.Eng.
Secret Lab Technologies Ltd.


More information about the Linuxppc-dev mailing list