diff options
author | Troy Kisky <troy.kisky@boundarydevices.com> | 2014-03-06 14:53:54 -0700 |
---|---|---|
committer | Oleksandr Suvorov <oleksandr.suvorov@toradex.com> | 2021-01-27 11:01:55 +0200 |
commit | 4fe4cbc84e93641eb166ee2010e197379fc3626b (patch) | |
tree | ff6f8fe6bc7532b6ba67bf470e5100cd3af194d5 /drivers/mxc | |
parent | 5837ceaf3178d964e4bf944b3f95ba3b3e9db266 (diff) |
ipu_common: ipu_free_irq, do nothing if not owner
Signed-off-by: Troy Kisky <troy.kisky@boundarydevices.com>
Acked-by: Max Krummenacher <max.krummenacher@toradex.com>
(cherry picked from commit 76560022d967fefa3195181766a1228344f817b8)
(cherry picked from commit f157011ef74dd94d57cc666518ccfca889b87d64)
(cherry picked from commit 0bc1781eacb6a7ea281d9f7eeb6cb8761a7bffb5)
Diffstat (limited to 'drivers/mxc')
-rw-r--r-- | drivers/mxc/ipu3/ipu_common.c | 6 |
1 files changed, 4 insertions, 2 deletions
diff --git a/drivers/mxc/ipu3/ipu_common.c b/drivers/mxc/ipu3/ipu_common.c index c5b82f78421f..eb9cc785a4a3 100644 --- a/drivers/mxc/ipu3/ipu_common.c +++ b/drivers/mxc/ipu3/ipu_common.c @@ -3102,14 +3102,16 @@ void ipu_free_irq(struct ipu_soc *ipu, uint32_t irq, void *dev_id) _ipu_get(ipu); + if (ipu->irq_list[irq].dev_id != dev_id) + return; + spin_lock_irqsave(&ipu->int_reg_spin_lock, lock_flags); /* disable the interrupt */ reg = ipu_cm_read(ipu, IPUIRQ_2_CTRLREG(irq)); reg &= ~IPUIRQ_2_MASK(irq); ipu_cm_write(ipu, reg, IPUIRQ_2_CTRLREG(irq)); - if (ipu->irq_list[irq].dev_id == dev_id) - memset(&ipu->irq_list[irq], 0, sizeof(ipu->irq_list[irq])); + memset(&ipu->irq_list[irq], 0, sizeof(ipu->irq_list[irq])); spin_unlock_irqrestore(&ipu->int_reg_spin_lock, lock_flags); |