diff mbox series

net: thunderx: Do not invoke pci_irq_vector() from interrupt context

Message ID 87r15gngfj.ffs@tglx (mailing list archive)
State Accepted
Commit 6b292a04c694573a302686323fe15b1c7e673e5b
Delegated to: Netdev Maintainers
Headers show
Series net: thunderx: Do not invoke pci_irq_vector() from interrupt context | expand

Checks

Context Check Description
netdev/fixes_present success Fixes tag not required for -next series
netdev/subject_prefix warning Target tree name not specified in the subject
netdev/cover_letter success Single patches do not need cover letters
netdev/patch_count success Link
netdev/header_inline success No static functions without inline keyword in header files
netdev/build_32bit success Errors and warnings before: 0 this patch: 0
netdev/cc_maintainers fail 1 blamed authors not CCed: jgg@ziepe.ca; 3 maintainers not CCed: jgg@ziepe.ca edumazet@google.com linux-arm-kernel@lists.infradead.org
netdev/build_clang success Errors and warnings before: 0 this patch: 0
netdev/module_param success Was 0 now: 0
netdev/verify_signedoff success Signed-off-by tag matches author and committer
netdev/verify_fixes success Fixes tag looks correct
netdev/build_allmodconfig_warn success Errors and warnings before: 0 this patch: 0
netdev/checkpatch success total: 0 errors, 0 warnings, 0 checks, 49 lines checked
netdev/kdoc success Errors and warnings before: 0 this patch: 0
netdev/source_inline success Was 0 now: 0
netdev/tree_selection success Guessing tree name failed - patch did not apply

Commit Message

Thomas Gleixner April 29, 2022, 1:54 p.m. UTC
pci_irq_vector() can't be used in atomic context any longer. This conflicts
with the usage of this function in nic_mbx_intr_handler().

Cache the Linux interrupt numbers in struct nicpf and use that cache in the
interrupt handler to select the mailbox.

Fixes: 495c66aca3da ("genirq/msi: Convert to new functions")
Reported-by: Ondrej Mosnacek <omosnace@redhat.com>
Signed-off-by: Thomas Gleixner <tglx@linutronix.de>
Cc: Sunil Goutham <sgoutham@marvell.com>
Cc: "David S. Miller" <davem@davemloft.net>
Cc: Jakub Kicinski <kuba@kernel.org>
Cc: Paolo Abeni <pabeni@redhat.com>
Cc: netdev@vger.kernel.org
Cc: stable@vger.kernel.org
Link: https://bugzilla.redhat.com/show_bug.cgi?id=2041772
---
 drivers/net/ethernet/cavium/thunder/nic_main.c |   16 ++++++++--------
 1 file changed, 8 insertions(+), 8 deletions(-)

Comments

patchwork-bot+netdevbpf@kernel.org May 1, 2022, 4:10 p.m. UTC | #1
Hello:

This patch was applied to netdev/net.git (master)
by David S. Miller <davem@davemloft.net>:

On Fri, 29 Apr 2022 15:54:24 +0200 you wrote:
> pci_irq_vector() can't be used in atomic context any longer. This conflicts
> with the usage of this function in nic_mbx_intr_handler().
> 
> Cache the Linux interrupt numbers in struct nicpf and use that cache in the
> interrupt handler to select the mailbox.
> 
> Fixes: 495c66aca3da ("genirq/msi: Convert to new functions")
> Reported-by: Ondrej Mosnacek <omosnace@redhat.com>
> Signed-off-by: Thomas Gleixner <tglx@linutronix.de>
> Cc: Sunil Goutham <sgoutham@marvell.com>
> Cc: "David S. Miller" <davem@davemloft.net>
> Cc: Jakub Kicinski <kuba@kernel.org>
> Cc: Paolo Abeni <pabeni@redhat.com>
> Cc: netdev@vger.kernel.org
> Cc: stable@vger.kernel.org
> Link: https://bugzilla.redhat.com/show_bug.cgi?id=2041772
> 
> [...]

Here is the summary with links:
  - net: thunderx: Do not invoke pci_irq_vector() from interrupt context
    https://git.kernel.org/netdev/net/c/6b292a04c694

You are awesome, thank you!
Ondrej Mosnacek May 2, 2022, 8:27 a.m. UTC | #2
Hi David,

On Sun, May 1, 2022 at 6:10 PM <patchwork-bot+netdevbpf@kernel.org> wrote:
>
> Hello:
>
> This patch was applied to netdev/net.git (master)
> by David S. Miller <davem@davemloft.net>:
>
> On Fri, 29 Apr 2022 15:54:24 +0200 you wrote:
> > pci_irq_vector() can't be used in atomic context any longer. This conflicts
> > with the usage of this function in nic_mbx_intr_handler().
> >
> > Cache the Linux interrupt numbers in struct nicpf and use that cache in the
> > interrupt handler to select the mailbox.
> >
> > Fixes: 495c66aca3da ("genirq/msi: Convert to new functions")
> > Reported-by: Ondrej Mosnacek <omosnace@redhat.com>
> > Signed-off-by: Thomas Gleixner <tglx@linutronix.de>
> > Cc: Sunil Goutham <sgoutham@marvell.com>
> > Cc: "David S. Miller" <davem@davemloft.net>
> > Cc: Jakub Kicinski <kuba@kernel.org>
> > Cc: Paolo Abeni <pabeni@redhat.com>
> > Cc: netdev@vger.kernel.org
> > Cc: stable@vger.kernel.org
> > Link: https://bugzilla.redhat.com/show_bug.cgi?id=2041772
> >
> > [...]
>
> Here is the summary with links:
>   - net: thunderx: Do not invoke pci_irq_vector() from interrupt context
>     https://git.kernel.org/netdev/net/c/6b292a04c694

It seems the patch got mangled when applying? The commit is missing
the subject line.

--
Ondrej Mosnacek
Software Engineer, Linux Security - SELinux kernel
Red Hat, Inc.
Thomas Gleixner May 2, 2022, 8:52 a.m. UTC | #3
On Mon, May 02 2022 at 10:27, Ondrej Mosnacek wrote:
> On Sun, May 1, 2022 at 6:10 PM <patchwork-bot+netdevbpf@kernel.org> wrote:
>> Here is the summary with links:
>>   - net: thunderx: Do not invoke pci_irq_vector() from interrupt context
>>     https://git.kernel.org/netdev/net/c/6b292a04c694
>
> It seems the patch got mangled when applying? The commit is missing
> the subject line.

Probably my fault. I somehow managed to have the proper Subject: line
and another empty 'Subject:' header in that mail.

Thanks,

        tglx
diff mbox series

Patch

--- a/drivers/net/ethernet/cavium/thunder/nic_main.c
+++ b/drivers/net/ethernet/cavium/thunder/nic_main.c
@@ -59,7 +59,7 @@  struct nicpf {
 
 	/* MSI-X */
 	u8			num_vec;
-	bool			irq_allocated[NIC_PF_MSIX_VECTORS];
+	unsigned int		irq_allocated[NIC_PF_MSIX_VECTORS];
 	char			irq_name[NIC_PF_MSIX_VECTORS][20];
 };
 
@@ -1150,7 +1150,7 @@  static irqreturn_t nic_mbx_intr_handler(
 	u64 intr;
 	u8  vf;
 
-	if (irq == pci_irq_vector(nic->pdev, NIC_PF_INTR_ID_MBOX0))
+	if (irq == nic->irq_allocated[NIC_PF_INTR_ID_MBOX0])
 		mbx = 0;
 	else
 		mbx = 1;
@@ -1176,14 +1176,14 @@  static void nic_free_all_interrupts(stru
 
 	for (irq = 0; irq < nic->num_vec; irq++) {
 		if (nic->irq_allocated[irq])
-			free_irq(pci_irq_vector(nic->pdev, irq), nic);
-		nic->irq_allocated[irq] = false;
+			free_irq(nic->irq_allocated[irq], nic);
+		nic->irq_allocated[irq] = 0;
 	}
 }
 
 static int nic_register_interrupts(struct nicpf *nic)
 {
-	int i, ret;
+	int i, ret, irq;
 	nic->num_vec = pci_msix_vec_count(nic->pdev);
 
 	/* Enable MSI-X */
@@ -1201,13 +1201,13 @@  static int nic_register_interrupts(struc
 		sprintf(nic->irq_name[i],
 			"NICPF Mbox%d", (i - NIC_PF_INTR_ID_MBOX0));
 
-		ret = request_irq(pci_irq_vector(nic->pdev, i),
-				  nic_mbx_intr_handler, 0,
+		irq = pci_irq_vector(nic->pdev, i);
+		ret = request_irq(irq, nic_mbx_intr_handler, 0,
 				  nic->irq_name[i], nic);
 		if (ret)
 			goto fail;
 
-		nic->irq_allocated[i] = true;
+		nic->irq_allocated[i] = irq;
 	}
 
 	/* Enable mailbox interrupt */