LKML Archive on lore.kernel.org
help / color / mirror / Atom feed
* [PATCH v1 1/1] dmaengine: acpi: Avoid comparison GSI with Linux vIRQ
@ 2021-07-30 20:27 Andy Shevchenko
2021-08-02 6:51 ` Vinod Koul
0 siblings, 1 reply; 2+ messages in thread
From: Andy Shevchenko @ 2021-07-30 20:27 UTC (permalink / raw)
To: Andy Shevchenko, dmaengine, linux-kernel; +Cc: Vinod Koul
Currently the CRST parsing relies on the fact that on most of x86 devices
the IRQ mapping is 1:1 with Linux vIRQ. However, it may be not true for
some. Fix this by converting GSI to Linux vIRQ before checking it.
Fixes: ee8209fd026b ("dma: acpi-dma: parse CSRT to extract additional resources")
Signed-off-by: Andy Shevchenko <andriy.shevchenko@linux.intel.com>
---
drivers/dma/acpi-dma.c | 10 +++++++---
1 file changed, 7 insertions(+), 3 deletions(-)
diff --git a/drivers/dma/acpi-dma.c b/drivers/dma/acpi-dma.c
index 235f1396f968..52768dc8ce12 100644
--- a/drivers/dma/acpi-dma.c
+++ b/drivers/dma/acpi-dma.c
@@ -70,10 +70,14 @@ static int acpi_dma_parse_resource_group(const struct acpi_csrt_group *grp,
si = (const struct acpi_csrt_shared_info *)&grp[1];
- /* Match device by MMIO and IRQ */
+ /* Match device by MMIO */
if (si->mmio_base_low != lower_32_bits(mem) ||
- si->mmio_base_high != upper_32_bits(mem) ||
- si->gsi_interrupt != irq)
+ si->mmio_base_high != upper_32_bits(mem))
+ return 0;
+
+ /* Match device by Linux vIRQ */
+ ret = acpi_register_gsi(NULL, si->gsi_interrupt, si->interrupt_mode, si->interrupt_polarity);
+ if (ret != irq)
return 0;
dev_dbg(&adev->dev, "matches with %.4s%04X (rev %u)\n",
--
2.30.2
^ permalink raw reply related [flat|nested] 2+ messages in thread
* Re: [PATCH v1 1/1] dmaengine: acpi: Avoid comparison GSI with Linux vIRQ
2021-07-30 20:27 [PATCH v1 1/1] dmaengine: acpi: Avoid comparison GSI with Linux vIRQ Andy Shevchenko
@ 2021-08-02 6:51 ` Vinod Koul
0 siblings, 0 replies; 2+ messages in thread
From: Vinod Koul @ 2021-08-02 6:51 UTC (permalink / raw)
To: Andy Shevchenko; +Cc: dmaengine, linux-kernel
On 30-07-21, 23:27, Andy Shevchenko wrote:
> Currently the CRST parsing relies on the fact that on most of x86 devices
> the IRQ mapping is 1:1 with Linux vIRQ. However, it may be not true for
> some. Fix this by converting GSI to Linux vIRQ before checking it.
Applied, thanks
--
~Vinod
^ permalink raw reply [flat|nested] 2+ messages in thread
end of thread, other threads:[~2021-08-02 6:51 UTC | newest]
Thread overview: 2+ messages (download: mbox.gz / follow: Atom feed)
-- links below jump to the message on this page --
2021-07-30 20:27 [PATCH v1 1/1] dmaengine: acpi: Avoid comparison GSI with Linux vIRQ Andy Shevchenko
2021-08-02 6:51 ` Vinod Koul
This is a public inbox, see mirroring instructions
for how to clone and mirror all data and code used for this inbox;
as well as URLs for NNTP newsgroup(s).