[Date Prev][Date Next][Thread Prev][Thread Next][Date Index][Thread Index]
Re: [PATCH 1/2] vfio iommu: Use shift operation for 64-bit integer divis
From: |
Alex Williamson |
Subject: |
Re: [PATCH 1/2] vfio iommu: Use shift operation for 64-bit integer division |
Date: |
Tue, 2 Jun 2020 13:54:48 -0600 |
On Wed, 3 Jun 2020 00:12:36 +0530
Kirti Wankhede <kwankhede@nvidia.com> wrote:
> Fixes compilation error with ARCH=i386.
>
> Error fixed by this commit:
> ld: drivers/vfio/vfio_iommu_type1.o: in function `vfio_dma_populate_bitmap':
> >> vfio_iommu_type1.c:(.text+0x666): undefined reference to `__udivdi3'
>
> Fixes: d6a4c185660c (vfio iommu: Implementation of ioctl for dirty pages
> tracking)
>
> Signed-off-by: Kirti Wankhede <kwankhede@nvidia.com>
> Reported-by: kbuild test robot <lkp@intel.com>
> ---
> drivers/vfio/vfio_iommu_type1.c | 3 ++-
> 1 file changed, 2 insertions(+), 1 deletion(-)
>
> diff --git a/drivers/vfio/vfio_iommu_type1.c b/drivers/vfio/vfio_iommu_type1.c
> index 97a29bc04d5d..9d9c8709a24c 100644
> --- a/drivers/vfio/vfio_iommu_type1.c
> +++ b/drivers/vfio/vfio_iommu_type1.c
> @@ -227,11 +227,12 @@ static void vfio_dma_bitmap_free(struct vfio_dma *dma)
> static void vfio_dma_populate_bitmap(struct vfio_dma *dma, size_t pgsize)
> {
> struct rb_node *p;
> + unsigned long pgshift = __ffs(pgsize);
>
> for (p = rb_first(&dma->pfn_list); p; p = rb_next(p)) {
> struct vfio_pfn *vpfn = rb_entry(p, struct vfio_pfn, node);
>
> - bitmap_set(dma->bitmap, (vpfn->iova - dma->iova) / pgsize, 1);
> + bitmap_set(dma->bitmap, (vpfn->iova - dma->iova) >> pgshift, 1);
> }
> }
>
Applied and pushed both to the vfio next branch. Thanks!
Alex