ethdev: read link state interrupt without link update service
It is now possible to read link status updated by interrupt without having manual link_update() service provided by the PMD. Indeed link_update() is useless in interrupt case. So check of this function pointer must be done in the interrupt case only. Signed-off-by: Thomas Monjalon <thomas.monjalon@6wind.com> Acked-by: Olivier Matz <olivier.matz@6wind.com>
This commit is contained in:
parent
d47bd10c8d
commit
506964bf86
@ -1100,11 +1100,11 @@ rte_eth_link_get(uint8_t port_id, struct rte_eth_link *eth_link)
|
||||
return;
|
||||
}
|
||||
dev = &rte_eth_devices[port_id];
|
||||
FUNC_PTR_OR_RET(*dev->dev_ops->link_update);
|
||||
|
||||
if (dev->data->dev_conf.intr_conf.lsc != 0)
|
||||
rte_eth_dev_atomic_read_link_status(dev, eth_link);
|
||||
else {
|
||||
FUNC_PTR_OR_RET(*dev->dev_ops->link_update);
|
||||
(*dev->dev_ops->link_update)(dev, 1);
|
||||
*eth_link = dev->data->dev_link;
|
||||
}
|
||||
@ -1120,11 +1120,11 @@ rte_eth_link_get_nowait(uint8_t port_id, struct rte_eth_link *eth_link)
|
||||
return;
|
||||
}
|
||||
dev = &rte_eth_devices[port_id];
|
||||
FUNC_PTR_OR_RET(*dev->dev_ops->link_update);
|
||||
|
||||
if (dev->data->dev_conf.intr_conf.lsc != 0)
|
||||
rte_eth_dev_atomic_read_link_status(dev, eth_link);
|
||||
else {
|
||||
FUNC_PTR_OR_RET(*dev->dev_ops->link_update);
|
||||
(*dev->dev_ops->link_update)(dev, 0);
|
||||
*eth_link = dev->data->dev_link;
|
||||
}
|
||||
|
Loading…
Reference in New Issue
Block a user