Acked by: Brian King <brk...@linux.vnet.ibm.com>

Robert Jennings wrote:
> In the VIO bus code the wrappers for dma alloc_coherent and free_coherent
> calls are rounding to IOMMU_PAGE_SIZE.  Taking a look at the underlying
> calls, the actual mapping is promoted to PAGE_SIZE.  Changing the
> rounding in these two functions fixes under-reporting the entitlement
> used by the system.  Without this change, the system could run out of
> entitlement before it believes it has and incur mapping failures at the
> firmware level.
> 
> Also in the VIO bus code, the wrapper for dma map_sg is not exiting in
> an error path where it should.  Rather than fall through to code for the
> success case, this patch adds the return that is needed in the error path.
> 
> Signed-off-by: Robert Jennings <r...@linux.vnet.ibm.com>
> 
> ---
>  arch/powerpc/kernel/vio.c |    7 ++++---
>  1 file changed, 4 insertions(+), 3 deletions(-)
> 
> Index: b/arch/powerpc/kernel/vio.c
> ===================================================================
> --- a/arch/powerpc/kernel/vio.c
> +++ b/arch/powerpc/kernel/vio.c
> @@ -492,14 +492,14 @@ static void *vio_dma_iommu_alloc_coheren
>       struct vio_dev *viodev = to_vio_dev(dev);
>       void *ret;
> 
> -     if (vio_cmo_alloc(viodev, roundup(size, IOMMU_PAGE_SIZE))) {
> +     if (vio_cmo_alloc(viodev, roundup(size, PAGE_SIZE))) {
>               atomic_inc(&viodev->cmo.allocs_failed);
>               return NULL;
>       }
> 
>       ret = dma_iommu_ops.alloc_coherent(dev, size, dma_handle, flag);
>       if (unlikely(ret == NULL)) {
> -             vio_cmo_dealloc(viodev, roundup(size, IOMMU_PAGE_SIZE));
> +             vio_cmo_dealloc(viodev, roundup(size, PAGE_SIZE));
>               atomic_inc(&viodev->cmo.allocs_failed);
>       }
> 
> @@ -513,7 +513,7 @@ static void vio_dma_iommu_free_coherent(
> 
>       dma_iommu_ops.free_coherent(dev, size, vaddr, dma_handle);
> 
> -     vio_cmo_dealloc(viodev, roundup(size, IOMMU_PAGE_SIZE));
> +     vio_cmo_dealloc(viodev, roundup(size, PAGE_SIZE));
>  }
> 
>  static dma_addr_t vio_dma_iommu_map_page(struct device *dev, struct page 
> *page,
> @@ -572,6 +572,7 @@ static int vio_dma_iommu_map_sg(struct d
>       if (unlikely(!ret)) {
>               vio_cmo_dealloc(viodev, alloc_size);
>               atomic_inc(&viodev->cmo.allocs_failed);
> +             return ret;
>       }
> 
>       for (sgl = sglist, count = 0; count < ret; count++, sgl++)
> _______________________________________________
> Linuxppc-dev mailing list
> Linuxppc-dev@ozlabs.org
> https://ozlabs.org/mailman/listinfo/linuxppc-dev


-- 
Brian King
Linux on Power Virtualization
IBM Linux Technology Center


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

Reply via email to