提交 b0ec5489 编写于 作者: B Bhaskar Upadhaya 提交者: David S. Miller

qede: preserve per queue stats across up/down of interface

Here we do the initialization of coalescing values on load.
per queue coalesce values are also restored across up/down of
ethernet interface.
Signed-off-by: NBhaskar Upadhaya <bupadhaya@marvell.com>
Signed-off-by: NIgor Russkikh <irusskikh@marvell.com>
Signed-off-by: NAriel Elior <aelior@marvell.com>
Signed-off-by: NDavid S. Miller <davem@davemloft.net>
上级 a0d2d97d
...@@ -168,6 +168,12 @@ struct qede_dump_info { ...@@ -168,6 +168,12 @@ struct qede_dump_info {
u32 args[QEDE_DUMP_MAX_ARGS]; u32 args[QEDE_DUMP_MAX_ARGS];
}; };
struct qede_coalesce {
bool isvalid;
u16 rxc;
u16 txc;
};
struct qede_dev { struct qede_dev {
struct qed_dev *cdev; struct qed_dev *cdev;
struct net_device *ndev; struct net_device *ndev;
...@@ -194,6 +200,7 @@ struct qede_dev { ...@@ -194,6 +200,7 @@ struct qede_dev {
((edev)->dev_info.common.dev_type == QED_DEV_TYPE_AH) ((edev)->dev_info.common.dev_type == QED_DEV_TYPE_AH)
struct qede_fastpath *fp_array; struct qede_fastpath *fp_array;
struct qede_coalesce *coal_entry;
u8 req_num_tx; u8 req_num_tx;
u8 fp_num_tx; u8 fp_num_tx;
u8 req_num_rx; u8 req_num_rx;
...@@ -581,6 +588,9 @@ int qede_add_tc_flower_fltr(struct qede_dev *edev, __be16 proto, ...@@ -581,6 +588,9 @@ int qede_add_tc_flower_fltr(struct qede_dev *edev, __be16 proto,
struct flow_cls_offload *f); struct flow_cls_offload *f);
void qede_forced_speed_maps_init(void); void qede_forced_speed_maps_init(void);
int qede_set_coalesce(struct net_device *dev, struct ethtool_coalesce *coal);
int qede_set_per_coalesce(struct net_device *dev, u32 queue,
struct ethtool_coalesce *coal);
#define RX_RING_SIZE_POW 13 #define RX_RING_SIZE_POW 13
#define RX_RING_SIZE ((u16)BIT(RX_RING_SIZE_POW)) #define RX_RING_SIZE ((u16)BIT(RX_RING_SIZE_POW))
......
...@@ -819,8 +819,7 @@ static int qede_get_coalesce(struct net_device *dev, ...@@ -819,8 +819,7 @@ static int qede_get_coalesce(struct net_device *dev,
return rc; return rc;
} }
static int qede_set_coalesce(struct net_device *dev, int qede_set_coalesce(struct net_device *dev, struct ethtool_coalesce *coal)
struct ethtool_coalesce *coal)
{ {
struct qede_dev *edev = netdev_priv(dev); struct qede_dev *edev = netdev_priv(dev);
struct qede_fastpath *fp; struct qede_fastpath *fp;
...@@ -855,6 +854,8 @@ static int qede_set_coalesce(struct net_device *dev, ...@@ -855,6 +854,8 @@ static int qede_set_coalesce(struct net_device *dev,
"Set RX coalesce error, rc = %d\n", rc); "Set RX coalesce error, rc = %d\n", rc);
return rc; return rc;
} }
edev->coal_entry[i].rxc = rxc;
edev->coal_entry[i].isvalid = true;
} }
if (edev->fp_array[i].type & QEDE_FASTPATH_TX) { if (edev->fp_array[i].type & QEDE_FASTPATH_TX) {
...@@ -874,6 +875,8 @@ static int qede_set_coalesce(struct net_device *dev, ...@@ -874,6 +875,8 @@ static int qede_set_coalesce(struct net_device *dev,
"Set TX coalesce error, rc = %d\n", rc); "Set TX coalesce error, rc = %d\n", rc);
return rc; return rc;
} }
edev->coal_entry[i].txc = txc;
edev->coal_entry[i].isvalid = true;
} }
} }
...@@ -2105,8 +2108,7 @@ static int qede_get_dump_data(struct net_device *dev, ...@@ -2105,8 +2108,7 @@ static int qede_get_dump_data(struct net_device *dev,
return rc; return rc;
} }
static int qede_set_per_coalesce(struct net_device *dev, int qede_set_per_coalesce(struct net_device *dev, u32 queue,
u32 queue,
struct ethtool_coalesce *coal) struct ethtool_coalesce *coal)
{ {
struct qede_dev *edev = netdev_priv(dev); struct qede_dev *edev = netdev_priv(dev);
...@@ -2150,6 +2152,8 @@ static int qede_set_per_coalesce(struct net_device *dev, ...@@ -2150,6 +2152,8 @@ static int qede_set_per_coalesce(struct net_device *dev,
"Set RX coalesce error, rc = %d\n", rc); "Set RX coalesce error, rc = %d\n", rc);
goto out; goto out;
} }
edev->coal_entry[queue].rxc = rxc;
edev->coal_entry[queue].isvalid = true;
} }
if (edev->fp_array[queue].type & QEDE_FASTPATH_TX) { if (edev->fp_array[queue].type & QEDE_FASTPATH_TX) {
...@@ -2161,6 +2165,8 @@ static int qede_set_per_coalesce(struct net_device *dev, ...@@ -2161,6 +2165,8 @@ static int qede_set_per_coalesce(struct net_device *dev,
"Set TX coalesce error, rc = %d\n", rc); "Set TX coalesce error, rc = %d\n", rc);
goto out; goto out;
} }
edev->coal_entry[queue].txc = txc;
edev->coal_entry[queue].isvalid = true;
} }
out: out:
__qede_unlock(edev); __qede_unlock(edev);
......
...@@ -904,6 +904,7 @@ static int qede_alloc_fp_array(struct qede_dev *edev) ...@@ -904,6 +904,7 @@ static int qede_alloc_fp_array(struct qede_dev *edev)
{ {
u8 fp_combined, fp_rx = edev->fp_num_rx; u8 fp_combined, fp_rx = edev->fp_num_rx;
struct qede_fastpath *fp; struct qede_fastpath *fp;
void *mem;
int i; int i;
edev->fp_array = kcalloc(QEDE_QUEUE_CNT(edev), edev->fp_array = kcalloc(QEDE_QUEUE_CNT(edev),
...@@ -913,6 +914,15 @@ static int qede_alloc_fp_array(struct qede_dev *edev) ...@@ -913,6 +914,15 @@ static int qede_alloc_fp_array(struct qede_dev *edev)
goto err; goto err;
} }
mem = krealloc(edev->coal_entry, QEDE_QUEUE_CNT(edev) *
sizeof(*edev->coal_entry), GFP_KERNEL);
if (!mem) {
DP_ERR(edev, "coalesce entry allocation failed\n");
kfree(edev->coal_entry);
goto err;
}
edev->coal_entry = mem;
fp_combined = QEDE_QUEUE_CNT(edev) - fp_rx - edev->fp_num_tx; fp_combined = QEDE_QUEUE_CNT(edev) - fp_rx - edev->fp_num_tx;
/* Allocate the FP elements for Rx queues followed by combined and then /* Allocate the FP elements for Rx queues followed by combined and then
...@@ -1320,8 +1330,10 @@ static void __qede_remove(struct pci_dev *pdev, enum qede_remove_mode mode) ...@@ -1320,8 +1330,10 @@ static void __qede_remove(struct pci_dev *pdev, enum qede_remove_mode mode)
* [e.g., QED register callbacks] won't break anything when * [e.g., QED register callbacks] won't break anything when
* accessing the netdevice. * accessing the netdevice.
*/ */
if (mode != QEDE_REMOVE_RECOVERY) if (mode != QEDE_REMOVE_RECOVERY) {
kfree(edev->coal_entry);
free_netdev(ndev); free_netdev(ndev);
}
dev_info(&pdev->dev, "Ending qede_remove successfully\n"); dev_info(&pdev->dev, "Ending qede_remove successfully\n");
} }
...@@ -2328,8 +2340,9 @@ static int qede_load(struct qede_dev *edev, enum qede_load_mode mode, ...@@ -2328,8 +2340,9 @@ static int qede_load(struct qede_dev *edev, enum qede_load_mode mode,
bool is_locked) bool is_locked)
{ {
struct qed_link_params link_params; struct qed_link_params link_params;
struct ethtool_coalesce coal = {};
u8 num_tc; u8 num_tc;
int rc; int rc, i;
DP_INFO(edev, "Starting qede load\n"); DP_INFO(edev, "Starting qede load\n");
...@@ -2390,6 +2403,18 @@ static int qede_load(struct qede_dev *edev, enum qede_load_mode mode, ...@@ -2390,6 +2403,18 @@ static int qede_load(struct qede_dev *edev, enum qede_load_mode mode,
edev->state = QEDE_STATE_OPEN; edev->state = QEDE_STATE_OPEN;
coal.rx_coalesce_usecs = QED_DEFAULT_RX_USECS;
coal.tx_coalesce_usecs = QED_DEFAULT_TX_USECS;
for_each_queue(i) {
if (edev->coal_entry[i].isvalid) {
coal.rx_coalesce_usecs = edev->coal_entry[i].rxc;
coal.tx_coalesce_usecs = edev->coal_entry[i].txc;
}
__qede_unlock(edev);
qede_set_per_coalesce(edev->ndev, i, &coal);
__qede_lock(edev);
}
DP_INFO(edev, "Ending successfully qede load\n"); DP_INFO(edev, "Ending successfully qede load\n");
goto out; goto out;
......
Markdown is supported
0% .
You are about to add 0 people to the discussion. Proceed with caution.
先完成此消息的编辑!
想要评论请 注册