[PATCH] IOMMU: arm-smmu-v3: Fix write to GERRORN register
Prem Mallappa
pmallapp at broadcom.com
Mon Dec 14 08:31:14 PST 2015
GERRORN should be toggled value, not just toggled bitmask
Signed-off-by: Prem Mallappa <pmallapp at broadcom.com>
---
drivers/iommu/arm-smmu-v3.c | 6 +++---
1 file changed, 3 insertions(+), 3 deletions(-)
diff --git a/drivers/iommu/arm-smmu-v3.c b/drivers/iommu/arm-smmu-v3.c
index dfda564..c2c523d 100644
--- a/drivers/iommu/arm-smmu-v3.c
+++ b/drivers/iommu/arm-smmu-v3.c
@@ -1267,10 +1267,10 @@ static int arm_smmu_device_disable(struct arm_smmu_device *smmu);
static irqreturn_t arm_smmu_gerror_handler(int irq, void *dev)
{
- u32 gerror, gerrorn;
+ u32 gerror, gerrorn, gerror_orig;
struct arm_smmu_device *smmu = dev;
- gerror = readl_relaxed(smmu->base + ARM_SMMU_GERROR);
+ gerror_orig = gerror = readl_relaxed(smmu->base + ARM_SMMU_GERROR);
gerrorn = readl_relaxed(smmu->base + ARM_SMMU_GERRORN);
gerror ^= gerrorn;
@@ -1313,7 +1313,7 @@ static irqreturn_t arm_smmu_gerror_handler(int irq, void *dev)
if (gerror & GERROR_CMDQ_ERR)
arm_smmu_cmdq_skip_err(smmu);
- writel(gerror, smmu->base + ARM_SMMU_GERRORN);
+ writel(gerror_orig, smmu->base + ARM_SMMU_GERRORN);
return IRQ_HANDLED;
}
--
2.6.0
More information about the linux-arm-kernel
mailing list