diff options
author | Sean Young <sean@mess.org> | 2017-11-08 22:19:45 +0100 |
---|---|---|
committer | Mauro Carvalho Chehab <mchehab@s-opensource.com> | 2017-11-15 14:57:34 +0100 |
commit | 30b4e122d71cbec2944a5f8b558b88936ee42f10 (patch) | |
tree | d9502baa72354fa85ff8aae9cdd4062d16147b71 /drivers/irqchip/irq-gic-v3-its-platform-msi.c | |
parent | Merge tag 'staging-4.15-rc1' into v4l_for_linus (diff) | |
download | linux-30b4e122d71cbec2944a5f8b558b88936ee42f10.tar.xz linux-30b4e122d71cbec2944a5f8b558b88936ee42f10.zip |
media: rc: sir_ir: detect presence of port
Without this test, sir_ir clumsy claims resources for a device which
does not exist.
The 0-day kernel test robot reports the following errors (in a loop):
sir_ir sir_ir.0: Trapped in interrupt
genirq: Flags mismatch irq 4. 00000000 (ttyS0) vs. 00000000 (sir_ir)
When sir_ir is loaded with the default io and irq, the following happens:
- sir_ir claims irq 4
- user space opens /dev/ttyS0
- in serial8250_do_startup(), some setup is done for ttyS0, which causes
irq 4 to fire (in THRE test)
- sir_ir does not realise it was not for it, and spins until the "trapped
in interrupt"
- now serial driver calls setup_irq() and fails and we get the
"Flags mismatch" error.
There is no port present at 0x3e8 so simply check for the presence of a
port, as suggested by Linus.
Reported-by: kbuild test robot <fengguang.wu@intel.com>
Tested-by: Fengguang Wu <fengguang.wu@intel.com>
Signed-off-by: Sean Young <sean@mess.org>
Cc: <stable@vger.kernel.org> # 4.12+
Signed-off-by: Mauro Carvalho Chehab <mchehab@s-opensource.com>
Diffstat (limited to 'drivers/irqchip/irq-gic-v3-its-platform-msi.c')
0 files changed, 0 insertions, 0 deletions