提交 d777f98b 编写于 作者: T Tuomas Tynkkynen 提交者: Greg Kroah-Hartman

memory: tegra20-mc: Fix hang in IRQ handler.

In Tegra20 any memory controller interrupt would cause an
infinite loop in the IRQ handler.
Signed-off-by: NTuomas Tynkkynen <ttynkkynen@nvidia.com>
Reviewed-by: NStephen Warren <swarren@nvidia.com>
Reviewed-by: NThierry Reding <thierry.reding@gmail.com>
Signed-off-by: NGreg Kroah-Hartman <gregkh@linuxfoundation.org>
上级 2c9b48ac
...@@ -193,8 +193,11 @@ static irqreturn_t tegra20_mc_isr(int irq, void *data) ...@@ -193,8 +193,11 @@ static irqreturn_t tegra20_mc_isr(int irq, void *data)
mask &= stat; mask &= stat;
if (!mask) if (!mask)
return IRQ_NONE; return IRQ_NONE;
while ((bit = ffs(mask)) != 0) while ((bit = ffs(mask)) != 0) {
tegra20_mc_decode(mc, bit - 1); tegra20_mc_decode(mc, bit - 1);
mask &= ~BIT(bit - 1);
}
mc_writel(mc, stat, MC_INTSTATUS); mc_writel(mc, stat, MC_INTSTATUS);
return IRQ_HANDLED; return IRQ_HANDLED;
} }
......
Markdown is supported
0% .
You are about to add 0 people to the discussion. Proceed with caution.
先完成此消息的编辑!
想要评论请 注册