net/netvsc: fix xstats for VF device
The id values for VF stats were not being offset correctly. And getting xstats for VF device only worked if VF device supported it; it did not support the generic stats. Fixes: dc7680e8597c ("net/netvsc: support integrated VF") Cc: stable@dpdk.org Signed-off-by: Stephen Hemminger <stephen@networkplumber.org>
This commit is contained in:
parent
b21ad01a82
commit
cc9271f9e7
@ -763,7 +763,7 @@ hn_dev_xstats_get(struct rte_eth_dev *dev,
|
||||
}
|
||||
}
|
||||
|
||||
ret = hn_vf_xstats_get(dev, xstats + count, n - count);
|
||||
ret = hn_vf_xstats_get(dev, xstats, count, n);
|
||||
if (ret < 0)
|
||||
return ret;
|
||||
|
||||
|
@ -241,7 +241,7 @@ int hn_vf_xstats_get_names(struct rte_eth_dev *dev,
|
||||
unsigned int size);
|
||||
int hn_vf_xstats_get(struct rte_eth_dev *dev,
|
||||
struct rte_eth_xstat *xstats,
|
||||
unsigned int n);
|
||||
unsigned int offset, unsigned int n);
|
||||
void hn_vf_xstats_reset(struct rte_eth_dev *dev);
|
||||
int hn_vf_rss_hash_update(struct rte_eth_dev *dev,
|
||||
struct rte_eth_rss_conf *rss_conf);
|
||||
|
@ -506,17 +506,19 @@ int hn_vf_xstats_get_names(struct rte_eth_dev *dev,
|
||||
struct hn_data *hv = dev->data->dev_private;
|
||||
struct rte_eth_dev *vf_dev;
|
||||
int i, count = 0;
|
||||
char tmp[RTE_ETH_XSTATS_NAME_SIZE];
|
||||
|
||||
rte_spinlock_lock(&hv->vf_lock);
|
||||
vf_dev = hn_get_vf_dev(hv);
|
||||
if (vf_dev && vf_dev->dev_ops->xstats_get_names)
|
||||
count = vf_dev->dev_ops->xstats_get_names(vf_dev, names, n);
|
||||
if (vf_dev)
|
||||
count = rte_eth_xstats_get_names(vf_dev->data->port_id,
|
||||
names, n);
|
||||
rte_spinlock_unlock(&hv->vf_lock);
|
||||
|
||||
/* add vf_ prefix to xstat names */
|
||||
if (names) {
|
||||
for (i = 0; i < count; i++) {
|
||||
char tmp[RTE_ETH_XSTATS_NAME_SIZE];
|
||||
|
||||
snprintf(tmp, sizeof(tmp), "vf_%s", names[i].name);
|
||||
strlcpy(names[i].name, tmp, sizeof(names[i].name));
|
||||
}
|
||||
@ -527,18 +529,26 @@ int hn_vf_xstats_get_names(struct rte_eth_dev *dev,
|
||||
|
||||
int hn_vf_xstats_get(struct rte_eth_dev *dev,
|
||||
struct rte_eth_xstat *xstats,
|
||||
unsigned int offset,
|
||||
unsigned int n)
|
||||
{
|
||||
struct hn_data *hv = dev->data->dev_private;
|
||||
struct rte_eth_dev *vf_dev;
|
||||
int count = 0;
|
||||
int i, count = 0;
|
||||
|
||||
rte_spinlock_lock(&hv->vf_lock);
|
||||
vf_dev = hn_get_vf_dev(hv);
|
||||
if (vf_dev && vf_dev->dev_ops->xstats_get)
|
||||
count = vf_dev->dev_ops->xstats_get(vf_dev, xstats, n);
|
||||
if (vf_dev)
|
||||
count = rte_eth_xstats_get(vf_dev->data->port_id,
|
||||
xstats + offset, n - offset);
|
||||
rte_spinlock_unlock(&hv->vf_lock);
|
||||
|
||||
/* Offset id's for VF stats */
|
||||
if (count > 0) {
|
||||
for (i = 0; i < count; i++)
|
||||
xstats[i + offset].id += offset;
|
||||
}
|
||||
|
||||
return count;
|
||||
}
|
||||
|
||||
@ -549,8 +559,8 @@ void hn_vf_xstats_reset(struct rte_eth_dev *dev)
|
||||
|
||||
rte_spinlock_lock(&hv->vf_lock);
|
||||
vf_dev = hn_get_vf_dev(hv);
|
||||
if (vf_dev && vf_dev->dev_ops->xstats_reset)
|
||||
vf_dev->dev_ops->xstats_reset(vf_dev);
|
||||
if (vf_dev)
|
||||
rte_eth_xstats_reset(vf_dev->data->port_id);
|
||||
rte_spinlock_unlock(&hv->vf_lock);
|
||||
}
|
||||
|
||||
|
Loading…
x
Reference in New Issue
Block a user