GERRORN should be toggled value, not just toggled bitmask

Signed-off-by: Prem Mallappa <[email protected]>
---
 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

_______________________________________________
iommu mailing list
[email protected]
https://lists.linuxfoundation.org/mailman/listinfo/iommu

Reply via email to