Skip to content

Commit bd07a98

Browse files
Jiawen WuPaolo Abeni
authored andcommitted
net: txgbe: remove separate irq request for MSI and INTx
When using MSI or INTx interrupts, request_irq() for pdev->irq will conflict with request_threaded_irq() for txgbe->misc.irq, to cause system crash. So remove txgbe_request_irq() for MSI/INTx case, and rename txgbe_request_msix_irqs() since it only request for queue irqs. Add wx->misc_irq_domain to determine whether the driver creates an IRQ domain and threaded request the IRQs. Fixes: aefd013 ("net: txgbe: use irq_domain for interrupt controller") Signed-off-by: Jiawen Wu <[email protected]> Signed-off-by: Paolo Abeni <[email protected]>
1 parent 7c36711 commit bd07a98

File tree

6 files changed

+15
-76
lines changed

6 files changed

+15
-76
lines changed

drivers/net/ethernet/wangxun/libwx/wx_hw.c

Lines changed: 1 addition & 0 deletions
Original file line numberDiff line numberDiff line change
@@ -1959,6 +1959,7 @@ int wx_sw_init(struct wx *wx)
19591959
}
19601960

19611961
bitmap_zero(wx->state, WX_STATE_NBITS);
1962+
wx->misc_irq_domain = false;
19621963

19631964
return 0;
19641965
}

drivers/net/ethernet/wangxun/libwx/wx_lib.c

Lines changed: 3 additions & 2 deletions
Original file line numberDiff line numberDiff line change
@@ -1997,7 +1997,8 @@ void wx_free_irq(struct wx *wx)
19971997
int vector;
19981998

19991999
if (!(pdev->msix_enabled)) {
2000-
free_irq(pdev->irq, wx);
2000+
if (!wx->misc_irq_domain)
2001+
free_irq(pdev->irq, wx);
20012002
return;
20022003
}
20032004

@@ -2012,7 +2013,7 @@ void wx_free_irq(struct wx *wx)
20122013
free_irq(entry->vector, q_vector);
20132014
}
20142015

2015-
if (wx->mac.type == wx_mac_em)
2016+
if (!wx->misc_irq_domain)
20162017
free_irq(wx->msix_entry->vector, wx);
20172018
}
20182019
EXPORT_SYMBOL(wx_free_irq);

drivers/net/ethernet/wangxun/libwx/wx_type.h

Lines changed: 1 addition & 0 deletions
Original file line numberDiff line numberDiff line change
@@ -1058,6 +1058,7 @@ struct wx {
10581058
dma_addr_t isb_dma;
10591059
u32 *isb_mem;
10601060
u32 isb_tag[WX_ISB_MAX];
1061+
bool misc_irq_domain;
10611062

10621063
#define WX_MAX_RETA_ENTRIES 128
10631064
#define WX_RSS_INDIR_TBL_MAX 64

drivers/net/ethernet/wangxun/txgbe/txgbe_irq.c

Lines changed: 8 additions & 72 deletions
Original file line numberDiff line numberDiff line change
@@ -27,57 +27,19 @@ void txgbe_irq_enable(struct wx *wx, bool queues)
2727
}
2828

2929
/**
30-
* txgbe_intr - msi/legacy mode Interrupt Handler
31-
* @irq: interrupt number
32-
* @data: pointer to a network interface device structure
33-
**/
34-
static irqreturn_t txgbe_intr(int __always_unused irq, void *data)
35-
{
36-
struct wx_q_vector *q_vector;
37-
struct wx *wx = data;
38-
struct pci_dev *pdev;
39-
u32 eicr;
40-
41-
q_vector = wx->q_vector[0];
42-
pdev = wx->pdev;
43-
44-
eicr = wx_misc_isb(wx, WX_ISB_VEC0);
45-
if (!eicr) {
46-
/* shared interrupt alert!
47-
* the interrupt that we masked before the ICR read.
48-
*/
49-
if (netif_running(wx->netdev))
50-
txgbe_irq_enable(wx, true);
51-
return IRQ_NONE; /* Not our interrupt */
52-
}
53-
wx->isb_mem[WX_ISB_VEC0] = 0;
54-
if (!(pdev->msi_enabled))
55-
wr32(wx, WX_PX_INTA, 1);
56-
57-
wx->isb_mem[WX_ISB_MISC] = 0;
58-
/* would disable interrupts here but it is auto disabled */
59-
napi_schedule_irqoff(&q_vector->napi);
60-
61-
/* re-enable link(maybe) and non-queue interrupts, no flush.
62-
* txgbe_poll will re-enable the queue interrupts
63-
*/
64-
if (netif_running(wx->netdev))
65-
txgbe_irq_enable(wx, false);
66-
67-
return IRQ_HANDLED;
68-
}
69-
70-
/**
71-
* txgbe_request_msix_irqs - Initialize MSI-X interrupts
30+
* txgbe_request_queue_irqs - Initialize MSI-X queue interrupts
7231
* @wx: board private structure
7332
*
74-
* Allocate MSI-X vectors and request interrupts from the kernel.
33+
* Allocate MSI-X queue vectors and request interrupts from the kernel.
7534
**/
76-
static int txgbe_request_msix_irqs(struct wx *wx)
35+
int txgbe_request_queue_irqs(struct wx *wx)
7736
{
7837
struct net_device *netdev = wx->netdev;
7938
int vector, err;
8039

40+
if (!wx->pdev->msix_enabled)
41+
return 0;
42+
8143
for (vector = 0; vector < wx->num_q_vectors; vector++) {
8244
struct wx_q_vector *q_vector = wx->q_vector[vector];
8345
struct msix_entry *entry = &wx->msix_q_entries[vector];
@@ -110,34 +72,6 @@ static int txgbe_request_msix_irqs(struct wx *wx)
11072
return err;
11173
}
11274

113-
/**
114-
* txgbe_request_irq - initialize interrupts
115-
* @wx: board private structure
116-
*
117-
* Attempt to configure interrupts using the best available
118-
* capabilities of the hardware and kernel.
119-
**/
120-
int txgbe_request_irq(struct wx *wx)
121-
{
122-
struct net_device *netdev = wx->netdev;
123-
struct pci_dev *pdev = wx->pdev;
124-
int err;
125-
126-
if (pdev->msix_enabled)
127-
err = txgbe_request_msix_irqs(wx);
128-
else if (pdev->msi_enabled)
129-
err = request_irq(wx->pdev->irq, &txgbe_intr, 0,
130-
netdev->name, wx);
131-
else
132-
err = request_irq(wx->pdev->irq, &txgbe_intr, IRQF_SHARED,
133-
netdev->name, wx);
134-
135-
if (err)
136-
wx_err(wx, "request_irq failed, Error %d\n", err);
137-
138-
return err;
139-
}
140-
14175
static int txgbe_request_gpio_irq(struct txgbe *txgbe)
14276
{
14377
txgbe->gpio_irq = irq_find_mapping(txgbe->misc.domain, TXGBE_IRQ_GPIO);
@@ -256,6 +190,8 @@ int txgbe_setup_misc_irq(struct txgbe *txgbe)
256190
if (err)
257191
goto free_gpio_irq;
258192

193+
wx->misc_irq_domain = true;
194+
259195
return 0;
260196

261197
free_gpio_irq:

drivers/net/ethernet/wangxun/txgbe/txgbe_irq.h

Lines changed: 1 addition & 1 deletion
Original file line numberDiff line numberDiff line change
@@ -2,6 +2,6 @@
22
/* Copyright (c) 2015 - 2024 Beijing WangXun Technology Co., Ltd. */
33

44
void txgbe_irq_enable(struct wx *wx, bool queues);
5-
int txgbe_request_irq(struct wx *wx);
5+
int txgbe_request_queue_irqs(struct wx *wx);
66
void txgbe_free_misc_irq(struct txgbe *txgbe);
77
int txgbe_setup_misc_irq(struct txgbe *txgbe);

drivers/net/ethernet/wangxun/txgbe/txgbe_main.c

Lines changed: 1 addition & 1 deletion
Original file line numberDiff line numberDiff line change
@@ -294,7 +294,7 @@ static int txgbe_open(struct net_device *netdev)
294294

295295
wx_configure(wx);
296296

297-
err = txgbe_request_irq(wx);
297+
err = txgbe_request_queue_irqs(wx);
298298
if (err)
299299
goto err_free_isb;
300300

0 commit comments

Comments
 (0)