net: hns3: fix the TX/RX ring.queue_index in hns3_ring_get_cfg
authorLipeng <lipeng321@huawei.com>
Mon, 23 Oct 2017 11:51:05 +0000 (19:51 +0800)
committerGreg Kroah-Hartman <gregkh@linuxfoundation.org>
Wed, 20 Dec 2017 09:10:33 +0000 (10:10 +0100)
[ Upstream commit 66b447301ac710ee237dba8b653244018fbb6168 ]

The interface hns3_ring_get_cfg only update TX ring queue_index,
but do not update RX ring queue_index. This patch fixes it.

Fixes: 76ad4f0 (net: hns3: Add support of HNS3 Ethernet Driver for hip08 SoC)

Signed-off-by: Lipeng <lipeng321@huawei.com>
Signed-off-by: David S. Miller <davem@davemloft.net>
Signed-off-by: Sasha Levin <alexander.levin@verizon.com>
Signed-off-by: Greg Kroah-Hartman <gregkh@linuxfoundation.org>
drivers/net/ethernet/hisilicon/hns3/hns3pf/hns3_enet.c

index 52687f0691f157f647f86e09c1600037958290ec..8944d836ac9a1b46c44e12417f45bf92df16e724 100644 (file)
@@ -2488,16 +2488,16 @@ static int hns3_ring_get_cfg(struct hnae3_queue *q, struct hns3_nic_priv *priv,
 
        if (ring_type == HNAE3_RING_TYPE_TX) {
                ring_data[q->tqp_index].ring = ring;
+               ring_data[q->tqp_index].queue_index = q->tqp_index;
                ring->io_base = (u8 __iomem *)q->io_base + HNS3_TX_REG_OFFSET;
        } else {
                ring_data[q->tqp_index + queue_num].ring = ring;
+               ring_data[q->tqp_index + queue_num].queue_index = q->tqp_index;
                ring->io_base = q->io_base;
        }
 
        hnae_set_bit(ring->flag, HNAE3_RING_TYPE_B, ring_type);
 
-       ring_data[q->tqp_index].queue_index = q->tqp_index;
-
        ring->tqp = q;
        ring->desc = NULL;
        ring->desc_cb = NULL;