Skip to content

Commit e31230f

Browse files
Jakub Kicinskidavem330
authored andcommitted
nfp: add helper to reassign rings to IRQ vectors
Instead of fixing ring -> vector relations up in ring swap functions put the reassignment into a helper function which will reinit all links. Signed-off-by: Jakub Kicinski <[email protected]> Signed-off-by: David S. Miller <[email protected]>
1 parent 0668b60 commit e31230f

File tree

1 file changed

+16
-24
lines changed

1 file changed

+16
-24
lines changed

drivers/net/ethernet/netronome/nfp/nfp_net_common.c

Lines changed: 16 additions & 24 deletions
Original file line numberDiff line numberDiff line change
@@ -1601,16 +1601,11 @@ nfp_net_tx_ring_set_prepare(struct nfp_net *nn, struct nfp_net_ring_set *s)
16011601
static void
16021602
nfp_net_tx_ring_set_swap(struct nfp_net *nn, struct nfp_net_ring_set *s)
16031603
{
1604-
struct nfp_net_tx_ring *rings = s->rings;
16051604
struct nfp_net_ring_set new = *s;
1606-
unsigned int r;
16071605

16081606
s->dcnt = nn->txd_cnt;
16091607
s->rings = nn->tx_rings;
16101608

1611-
for (r = 0; r < nn->num_tx_rings; r++)
1612-
nn->tx_rings[r].r_vec->tx_ring = &rings[r];
1613-
16141609
nn->txd_cnt = new.dcnt;
16151610
nn->tx_rings = new.rings;
16161611
}
@@ -1728,17 +1723,12 @@ nfp_net_rx_ring_set_prepare(struct nfp_net *nn, struct nfp_net_ring_set *s)
17281723
static void
17291724
nfp_net_rx_ring_set_swap(struct nfp_net *nn, struct nfp_net_ring_set *s)
17301725
{
1731-
struct nfp_net_rx_ring *rings = s->rings;
17321726
struct nfp_net_ring_set new = *s;
1733-
unsigned int r;
17341727

17351728
s->mtu = nn->netdev->mtu;
17361729
s->dcnt = nn->rxd_cnt;
17371730
s->rings = nn->rx_rings;
17381731

1739-
for (r = 0; r < nn->num_rx_rings; r++)
1740-
nn->rx_rings[r].r_vec->rx_ring = &rings[r];
1741-
17421732
nn->netdev->mtu = new.mtu;
17431733
nn->fl_bufsz = nfp_net_calc_fl_bufsz(nn, new.mtu);
17441734
nn->rxd_cnt = new.dcnt;
@@ -1759,27 +1749,21 @@ nfp_net_rx_ring_set_free(struct nfp_net *nn, struct nfp_net_ring_set *s)
17591749
kfree(rings);
17601750
}
17611751

1752+
static void
1753+
nfp_net_vector_assign_rings(struct nfp_net *nn, struct nfp_net_r_vector *r_vec,
1754+
int idx)
1755+
{
1756+
r_vec->rx_ring = idx < nn->num_rx_rings ? &nn->rx_rings[idx] : NULL;
1757+
r_vec->tx_ring = idx < nn->num_tx_rings ? &nn->tx_rings[idx] : NULL;
1758+
}
1759+
17621760
static int
17631761
nfp_net_prepare_vector(struct nfp_net *nn, struct nfp_net_r_vector *r_vec,
17641762
int idx)
17651763
{
17661764
struct msix_entry *entry = &nn->irq_entries[r_vec->irq_idx];
17671765
int err;
17681766

1769-
if (idx < nn->num_tx_rings) {
1770-
r_vec->tx_ring = &nn->tx_rings[idx];
1771-
nfp_net_tx_ring_init(r_vec->tx_ring, r_vec, idx);
1772-
} else {
1773-
r_vec->tx_ring = NULL;
1774-
}
1775-
1776-
if (idx < nn->num_rx_rings) {
1777-
r_vec->rx_ring = &nn->rx_rings[idx];
1778-
nfp_net_rx_ring_init(r_vec->rx_ring, r_vec, idx);
1779-
} else {
1780-
r_vec->rx_ring = NULL;
1781-
}
1782-
17831767
snprintf(r_vec->name, sizeof(r_vec->name),
17841768
"%s-rxtx-%d", nn->netdev->name, idx);
17851769
err = request_irq(entry->vector, r_vec->handler, 0, r_vec->name, r_vec);
@@ -2100,6 +2084,9 @@ static int nfp_net_netdev_open(struct net_device *netdev)
21002084
goto err_free_rx_rings;
21012085
}
21022086

2087+
for (r = 0; r < nn->max_r_vecs; r++)
2088+
nfp_net_vector_assign_rings(nn, &nn->r_vecs[r], r);
2089+
21032090
err = netif_set_real_num_tx_queues(netdev, nn->num_tx_rings);
21042091
if (err)
21052092
goto err_free_rings;
@@ -2247,11 +2234,16 @@ nfp_net_ring_swap_enable(struct nfp_net *nn,
22472234
struct nfp_net_ring_set *rx,
22482235
struct nfp_net_ring_set *tx)
22492236
{
2237+
unsigned int r;
2238+
22502239
if (rx)
22512240
nfp_net_rx_ring_set_swap(nn, rx);
22522241
if (tx)
22532242
nfp_net_tx_ring_set_swap(nn, tx);
22542243

2244+
for (r = 0; r < nn->max_r_vecs; r++)
2245+
nfp_net_vector_assign_rings(nn, &nn->r_vecs[r], r);
2246+
22552247
return __nfp_net_set_config_and_enable(nn);
22562248
}
22572249

0 commit comments

Comments
 (0)