On Fri, Jul 04, 2025 at 06:13:30PM -0700, Nicolin Chen wrote:
> +static struct iommufd_access *
> +iommufd_hw_queue_alloc_phys(struct iommu_hw_queue_alloc *cmd,
> +                         struct iommufd_viommu *viommu, phys_addr_t *base_pa)
> +{
> +     struct iommufd_access *access;
> +     struct page **pages;
> +     size_t max_npages;
> +     size_t length;
> +     u64 offset;
> +     size_t i;
> +     int rc;
> +
> +     offset =
> +             cmd->nesting_parent_iova - PAGE_ALIGN(cmd->nesting_parent_iova);

PAGE_ALIGN is ALIGN UP, that is the wrong direction?

It is just:

      offset = cmd->nesting_parent_iova % PAGE_SIZE;

And this is missing:

        *base_pa = (page_to_pfn(pages[0]) << PAGE_SHIFT) + offset;

??

Jason

Reply via email to