|
[Date Prev][Date Next][Thread Prev][Thread Next][Date Index][Thread Index] [xen master] iommu/arm: Remove code duplication in all IOMMU drivers
commit 481ee6125aa1d5751f52eda677c7bab4719c0ad0
Author: Oleksandr Tyshchenko <oleksandr_tyshchenko@xxxxxxxx>
AuthorDate: Thu Jan 27 21:55:52 2022 +0200
Commit: Julien Grall <jgrall@xxxxxxxxxx>
CommitDate: Mon Jan 31 18:33:31 2022 +0000
iommu/arm: Remove code duplication in all IOMMU drivers
All IOMMU drivers on Arm perform almost the same generic actions in
hwdom_init callback. Move this code to common arch_iommu_hwdom_init()
in order to get rid of code duplication.
Signed-off-by: Oleksandr Tyshchenko <oleksandr_tyshchenko@xxxxxxxx>
Reviewed-by: Volodymyr Babchuk <volodymyr_babchuk@xxxxxxxx>
Acked-by: Rahul Singh <rahul.singh@xxxxxxx>
Acked-by: Julien Grall <jgrall@xxxxxxxxxx>
---
xen/drivers/passthrough/arm/iommu.c | 7 +++++++
xen/drivers/passthrough/arm/ipmmu-vmsa.c | 15 +--------------
xen/drivers/passthrough/arm/smmu-v3.c | 17 +----------------
xen/drivers/passthrough/arm/smmu.c | 17 +----------------
4 files changed, 10 insertions(+), 46 deletions(-)
diff --git a/xen/drivers/passthrough/arm/iommu.c
b/xen/drivers/passthrough/arm/iommu.c
index ee653a9c48..fc453180f0 100644
--- a/xen/drivers/passthrough/arm/iommu.c
+++ b/xen/drivers/passthrough/arm/iommu.c
@@ -134,6 +134,13 @@ void arch_iommu_domain_destroy(struct domain *d)
void __hwdom_init arch_iommu_hwdom_init(struct domain *d)
{
+ /* Set to false options not supported on ARM. */
+ if ( iommu_hwdom_inclusive )
+ printk(XENLOG_WARNING "map-inclusive dom0-iommu option is not
supported on ARM\n");
+ iommu_hwdom_inclusive = false;
+ if ( iommu_hwdom_reserved == 1 )
+ printk(XENLOG_WARNING "map-reserved dom0-iommu option is not supported
on ARM\n");
+ iommu_hwdom_reserved = 0;
}
/*
diff --git a/xen/drivers/passthrough/arm/ipmmu-vmsa.c
b/xen/drivers/passthrough/arm/ipmmu-vmsa.c
index c912120411..d2572bcd30 100644
--- a/xen/drivers/passthrough/arm/ipmmu-vmsa.c
+++ b/xen/drivers/passthrough/arm/ipmmu-vmsa.c
@@ -1329,19 +1329,6 @@ static int ipmmu_iommu_domain_init(struct domain *d)
return 0;
}
-static void __hwdom_init ipmmu_iommu_hwdom_init(struct domain *d)
-{
- /* Set to false options not supported on ARM. */
- if ( iommu_hwdom_inclusive )
- printk(XENLOG_WARNING "ipmmu: map-inclusive dom0-iommu option is not
supported on ARM\n");
- iommu_hwdom_inclusive = false;
- if ( iommu_hwdom_reserved == 1 )
- printk(XENLOG_WARNING "ipmmu: map-reserved dom0-iommu option is not
supported on ARM\n");
- iommu_hwdom_reserved = 0;
-
- arch_iommu_hwdom_init(d);
-}
-
static void ipmmu_iommu_domain_teardown(struct domain *d)
{
struct ipmmu_vmsa_xen_domain *xen_domain = dom_iommu(d)->arch.priv;
@@ -1369,7 +1356,7 @@ static void ipmmu_iommu_domain_teardown(struct domain *d)
static const struct iommu_ops ipmmu_iommu_ops =
{
.init = ipmmu_iommu_domain_init,
- .hwdom_init = ipmmu_iommu_hwdom_init,
+ .hwdom_init = arch_iommu_hwdom_init,
.teardown = ipmmu_iommu_domain_teardown,
.iotlb_flush = ipmmu_iotlb_flush,
.iotlb_flush_all = ipmmu_iotlb_flush_all,
diff --git a/xen/drivers/passthrough/arm/smmu-v3.c
b/xen/drivers/passthrough/arm/smmu-v3.c
index d115df7320..71b022fe7f 100644
--- a/xen/drivers/passthrough/arm/smmu-v3.c
+++ b/xen/drivers/passthrough/arm/smmu-v3.c
@@ -3402,21 +3402,6 @@ static int arm_smmu_iommu_xen_domain_init(struct domain
*d)
}
-static void __hwdom_init arm_smmu_iommu_hwdom_init(struct domain *d)
-{
- /* Set to false options not supported on ARM. */
- if (iommu_hwdom_inclusive)
- printk(XENLOG_WARNING
- "map-inclusive dom0-iommu option is not supported on ARM\n");
- iommu_hwdom_inclusive = false;
- if (iommu_hwdom_reserved == 1)
- printk(XENLOG_WARNING
- "map-reserved dom0-iommu option is not supported on ARM\n");
- iommu_hwdom_reserved = 0;
-
- arch_iommu_hwdom_init(d);
-}
-
static void arm_smmu_iommu_xen_domain_teardown(struct domain *d)
{
struct arm_smmu_xen_domain *xen_domain = dom_iommu(d)->arch.priv;
@@ -3427,7 +3412,7 @@ static void arm_smmu_iommu_xen_domain_teardown(struct
domain *d)
static const struct iommu_ops arm_smmu_iommu_ops = {
.init = arm_smmu_iommu_xen_domain_init,
- .hwdom_init = arm_smmu_iommu_hwdom_init,
+ .hwdom_init = arch_iommu_hwdom_init,
.teardown = arm_smmu_iommu_xen_domain_teardown,
.iotlb_flush = arm_smmu_iotlb_flush,
.iotlb_flush_all = arm_smmu_iotlb_flush_all,
diff --git a/xen/drivers/passthrough/arm/smmu.c
b/xen/drivers/passthrough/arm/smmu.c
index c9dfc4caa0..b186c28dff 100644
--- a/xen/drivers/passthrough/arm/smmu.c
+++ b/xen/drivers/passthrough/arm/smmu.c
@@ -2849,21 +2849,6 @@ static int arm_smmu_iommu_domain_init(struct domain *d)
return 0;
}
-static void __hwdom_init arm_smmu_iommu_hwdom_init(struct domain *d)
-{
- /* Set to false options not supported on ARM. */
- if ( iommu_hwdom_inclusive )
- printk(XENLOG_WARNING
- "map-inclusive dom0-iommu option is not supported on ARM\n");
- iommu_hwdom_inclusive = false;
- if ( iommu_hwdom_reserved == 1 )
- printk(XENLOG_WARNING
- "map-reserved dom0-iommu option is not supported on ARM\n");
- iommu_hwdom_reserved = 0;
-
- arch_iommu_hwdom_init(d);
-}
-
static void arm_smmu_iommu_domain_teardown(struct domain *d)
{
struct arm_smmu_xen_domain *xen_domain = dom_iommu(d)->arch.priv;
@@ -2874,7 +2859,7 @@ static void arm_smmu_iommu_domain_teardown(struct domain
*d)
static const struct iommu_ops arm_smmu_iommu_ops = {
.init = arm_smmu_iommu_domain_init,
- .hwdom_init = arm_smmu_iommu_hwdom_init,
+ .hwdom_init = arch_iommu_hwdom_init,
.add_device = arm_smmu_dt_add_device_generic,
.teardown = arm_smmu_iommu_domain_teardown,
.iotlb_flush = arm_smmu_iotlb_flush,
--
generated by git-patchbot for /home/xen/git/xen.git#master
|
![]() |
Lists.xenproject.org is hosted with RackSpace, monitoring our |