dpdk: fix update link state

Type: fix

Correct vnet_hw_interface_t flags update on link state changes.
Currently incomplete set of flags is applied on each change,
only flags related to the most recent change are being set correct.
E.g. setting the link up would erase the duplex part of the flags.

Signed-off-by: Alexander Skorichenko <askorichenko@netgate.com>
Change-Id: I5b95e1c0eaea0c283b108dbf7f809682ec9064eb
This commit is contained in:
Alexander Skorichenko
2022-05-20 11:13:19 +00:00
committed by Matthew Smith
parent 8abbdf509b
commit d8366d085f

View File

@@ -1373,9 +1373,20 @@ dpdk_update_link_state (dpdk_device_t * xd, f64 now)
ed->new_link_state = (u8) xd->link.link_status;
}
if ((xd->link.link_duplex != prev_link.link_duplex))
hw_flags_chg = ((xd->link.link_duplex != prev_link.link_duplex) ||
(xd->link.link_status != prev_link.link_status));
if (xd->link.link_speed != prev_link.link_speed)
vnet_hw_interface_set_link_speed (vnm, xd->hw_if_index,
(xd->link.link_speed == UINT32_MAX) ?
UINT32_MAX :
xd->link.link_speed * 1000);
if (hw_flags_chg)
{
hw_flags_chg = 1;
if (xd->link.link_status)
hw_flags |= VNET_HW_INTERFACE_FLAG_LINK_UP;
switch (xd->link.link_duplex)
{
case RTE_ETH_LINK_HALF_DUPLEX:
@@ -1387,23 +1398,7 @@ dpdk_update_link_state (dpdk_device_t * xd, f64 now)
default:
break;
}
}
if (xd->link.link_speed != prev_link.link_speed)
vnet_hw_interface_set_link_speed (vnm, xd->hw_if_index,
(xd->link.link_speed == UINT32_MAX) ?
UINT32_MAX :
xd->link.link_speed * 1000);
if (xd->link.link_status != prev_link.link_status)
{
hw_flags_chg = 1;
if (xd->link.link_status)
hw_flags |= VNET_HW_INTERFACE_FLAG_LINK_UP;
}
if (hw_flags_chg)
{
if (LINK_STATE_ELOGS)
{
ELOG_TYPE_DECLARE (e) =