iommu/arm-smmu: Convert to domain_alloc_paging()
authorJason Gunthorpe <jgg@nvidia.com>
Thu, 11 Apr 2024 17:12:11 +0000 (14:12 -0300)
committerWill Deacon <will@kernel.org>
Thu, 18 Apr 2024 14:32:38 +0000 (15:32 +0100)
commitd75d7dc26f29141fe31167c5414605d4087f0abb
tree0096a289140a89733bae42edb1e99b78ec6bc364
parente8e4398d53f98be7ac48e0bda9ea6e26df24136d
iommu/arm-smmu: Convert to domain_alloc_paging()

Now that the BLOCKED and IDENTITY behaviors are managed with their own
domains change to the domain_alloc_paging() op.

The check for using_legacy_binding is now redundant,
arm_smmu_def_domain_type() always returns IOMMU_DOMAIN_IDENTITY for this
mode, so the core code will never attempt to create a DMA domain in the
first place.

Since commit a4fdd9762272 ("iommu: Use flush queue capability") the core
code only passes in IDENTITY/BLOCKED/UNMANAGED/DMA domain types. It will
not pass in IDENTITY or BLOCKED if the global statics exist, so the test
for DMA is also redundant now too.

Cc: Dmitry Baryshkov <dmitry.baryshkov@linaro.org>
Signed-off-by: Jason Gunthorpe <jgg@nvidia.com>
Link: https://lore.kernel.org/r/0-v1-3632c65678e0+2f1-smmu_alloc_paging_jgg@nvidia.com
Signed-off-by: Will Deacon <will@kernel.org>
drivers/iommu/arm/arm-smmu/arm-smmu.c