[dpdk-dev] [PATCH] drivers/net: update link status
Nélio Laranjeiro
nelio.laranjeiro at 6wind.com
Wed Mar 14 09:14:53 CET 2018
On Tue, Mar 13, 2018 at 06:05:34PM +0000, Ferruh Yigit wrote:
> Update link status related feature document items and minor updates in
> some link status related functions.
>
> Signed-off-by: Ferruh Yigit <ferruh.yigit at intel.com>
> ---
> doc/guides/nics/features/fm10k.ini | 2 ++
> doc/guides/nics/features/fm10k_vf.ini | 2 ++
> doc/guides/nics/features/i40e_vf.ini | 1 +
> doc/guides/nics/features/igb_vf.ini | 1 +
> doc/guides/nics/features/qede.ini | 1 -
> doc/guides/nics/features/qede_vf.ini | 1 -
> doc/guides/nics/features/vhost.ini | 2 --
> doc/guides/nics/features/virtio_vec.ini | 1 +
> drivers/net/e1000/em_ethdev.c | 2 +-
> drivers/net/ena/ena_ethdev.c | 2 +-
> drivers/net/fm10k/fm10k_ethdev.c | 6 ++----
> drivers/net/i40e/i40e_ethdev_vf.c | 2 +-
> drivers/net/ixgbe/ixgbe_ethdev.c | 2 +-
> drivers/net/mlx4/mlx4_ethdev.c | 2 +-
> drivers/net/mlx5/mlx5_ethdev.c | 2 +-
> 15 files changed, 15 insertions(+), 14 deletions(-)
>
> diff --git a/doc/guides/nics/features/fm10k.ini b/doc/guides/nics/features/fm10k.ini
> index f0f61a7d7..58f58b99c 100644
> --- a/doc/guides/nics/features/fm10k.ini
> +++ b/doc/guides/nics/features/fm10k.ini
> @@ -5,6 +5,8 @@
> ;
> [Features]
> Speed capabilities = P
> +Link status = Y
> +Link status event = Y
> Rx interrupt = Y
> Queue start/stop = Y
> Jumbo frame = Y
> diff --git a/doc/guides/nics/features/fm10k_vf.ini b/doc/guides/nics/features/fm10k_vf.ini
> index 32b93df4b..44b50faa1 100644
> --- a/doc/guides/nics/features/fm10k_vf.ini
> +++ b/doc/guides/nics/features/fm10k_vf.ini
> @@ -5,6 +5,8 @@
> ;
> [Features]
> Speed capabilities = P
> +Link status = Y
> +Link status event = Y
> Rx interrupt = Y
> Queue start/stop = Y
> Jumbo frame = Y
> diff --git a/doc/guides/nics/features/i40e_vf.ini b/doc/guides/nics/features/i40e_vf.ini
> index 46e0d9fce..ba2d8cbe9 100644
> --- a/doc/guides/nics/features/i40e_vf.ini
> +++ b/doc/guides/nics/features/i40e_vf.ini
> @@ -5,6 +5,7 @@
> ;
> [Features]
> Rx interrupt = Y
> +Link status = Y
> Queue start/stop = Y
> Jumbo frame = Y
> Scattered Rx = Y
> diff --git a/doc/guides/nics/features/igb_vf.ini b/doc/guides/nics/features/igb_vf.ini
> index e641a2c97..d9653234b 100644
> --- a/doc/guides/nics/features/igb_vf.ini
> +++ b/doc/guides/nics/features/igb_vf.ini
> @@ -4,6 +4,7 @@
> ; Refer to default.ini for the full list of available PMD features.
> ;
> [Features]
> +Link status = Y
> Rx interrupt = Y
> Scattered Rx = Y
> TSO = Y
> diff --git a/doc/guides/nics/features/qede.ini b/doc/guides/nics/features/qede.ini
> index cbadc1949..13e34ae33 100644
> --- a/doc/guides/nics/features/qede.ini
> +++ b/doc/guides/nics/features/qede.ini
> @@ -6,7 +6,6 @@
> [Features]
> Speed capabilities = Y
> Link status = Y
> -Link status event = Y
> MTU update = Y
> Jumbo frame = Y
> Scattered Rx = Y
> diff --git a/doc/guides/nics/features/qede_vf.ini b/doc/guides/nics/features/qede_vf.ini
> index 18857b6e3..70071a1bd 100644
> --- a/doc/guides/nics/features/qede_vf.ini
> +++ b/doc/guides/nics/features/qede_vf.ini
> @@ -6,7 +6,6 @@
> [Features]
> Speed capabilities = Y
> Link status = Y
> -Link status event = Y
> MTU update = Y
> Jumbo frame = Y
> Scattered Rx = Y
> diff --git a/doc/guides/nics/features/vhost.ini b/doc/guides/nics/features/vhost.ini
> index dffd1f493..31302745a 100644
> --- a/doc/guides/nics/features/vhost.ini
> +++ b/doc/guides/nics/features/vhost.ini
> @@ -4,8 +4,6 @@
> ; Refer to default.ini for the full list of available PMD features.
> ;
> [Features]
> -Link status = Y
> -Link status event = Y
> Free Tx mbuf on demand = Y
> Queue status event = Y
> Basic stats = Y
> diff --git a/doc/guides/nics/features/virtio_vec.ini b/doc/guides/nics/features/virtio_vec.ini
> index c06c860d4..e60fe36ae 100644
> --- a/doc/guides/nics/features/virtio_vec.ini
> +++ b/doc/guides/nics/features/virtio_vec.ini
> @@ -6,6 +6,7 @@
> [Features]
> Speed capabilities = P
> Link status = Y
> +Link status event = Y
> Rx interrupt = Y
> Queue start/stop = Y
> Promiscuous mode = Y
> diff --git a/drivers/net/e1000/em_ethdev.c b/drivers/net/e1000/em_ethdev.c
> index 242375ff1..080df70c4 100644
> --- a/drivers/net/e1000/em_ethdev.c
> +++ b/drivers/net/e1000/em_ethdev.c
> @@ -1210,7 +1210,7 @@ eth_em_link_update(struct rte_eth_dev *dev, int wait_to_complete)
> link.link_autoneg = !(dev->data->dev_conf.link_speeds &
> ETH_LINK_SPEED_FIXED);
> } else if (!link_check && (link.link_status == ETH_LINK_UP)) {
> - link.link_speed = 0;
> + link.link_speed = ETH_SPEED_NUM_NONE;
> link.link_duplex = ETH_LINK_HALF_DUPLEX;
> link.link_status = ETH_LINK_DOWN;
> link.link_autoneg = ETH_LINK_FIXED;
> diff --git a/drivers/net/ena/ena_ethdev.c b/drivers/net/ena/ena_ethdev.c
> index 34b2a8d78..ad4e03dba 100644
> --- a/drivers/net/ena/ena_ethdev.c
> +++ b/drivers/net/ena/ena_ethdev.c
> @@ -724,7 +724,7 @@ static int ena_link_update(struct rte_eth_dev *dev,
> {
> struct rte_eth_link *link = &dev->data->dev_link;
>
> - link->link_status = 1;
> + link->link_status = ETH_LINK_UP;
> link->link_speed = ETH_SPEED_NUM_10G;
> link->link_duplex = ETH_LINK_FULL_DUPLEX;
>
> diff --git a/drivers/net/fm10k/fm10k_ethdev.c b/drivers/net/fm10k/fm10k_ethdev.c
> index 94237610c..cc1a773a7 100644
> --- a/drivers/net/fm10k/fm10k_ethdev.c
> +++ b/drivers/net/fm10k/fm10k_ethdev.c
> @@ -1233,13 +1233,11 @@ fm10k_link_update(struct rte_eth_dev *dev,
> FM10K_DEV_PRIVATE_TO_INFO(dev->data->dev_private);
> PMD_INIT_FUNC_TRACE();
>
> - /* The speed is ~50Gbps per Gen3 x8 PCIe interface. For now, we
> - * leave the speed undefined since there is no 50Gbps Ethernet.
> - */
> - dev->data->dev_link.link_speed = 0;
> + dev->data->dev_link.link_speed = ETH_SPEED_NUM_50G;
> dev->data->dev_link.link_duplex = ETH_LINK_FULL_DUPLEX;
> dev->data->dev_link.link_status =
> dev_info->sm_down ? ETH_LINK_DOWN : ETH_LINK_UP;
> + dev->data->dev_link.link_autoneg = ETH_LINK_FIXED;
>
> return 0;
> }
> diff --git a/drivers/net/i40e/i40e_ethdev_vf.c b/drivers/net/i40e/i40e_ethdev_vf.c
> index fd003fe01..c771edde5 100644
> --- a/drivers/net/i40e/i40e_ethdev_vf.c
> +++ b/drivers/net/i40e/i40e_ethdev_vf.c
> @@ -2107,7 +2107,7 @@ i40evf_dev_link_update(struct rte_eth_dev *dev,
> new_link.link_status = vf->link_up ? ETH_LINK_UP :
> ETH_LINK_DOWN;
> new_link.link_autoneg =
> - dev->data->dev_conf.link_speeds & ETH_LINK_SPEED_FIXED;
> + !(dev->data->dev_conf.link_speeds & ETH_LINK_SPEED_FIXED);
>
> i40evf_dev_atomic_write_link_status(dev, &new_link);
>
> diff --git a/drivers/net/ixgbe/ixgbe_ethdev.c b/drivers/net/ixgbe/ixgbe_ethdev.c
> index 448325857..bad83968c 100644
> --- a/drivers/net/ixgbe/ixgbe_ethdev.c
> +++ b/drivers/net/ixgbe/ixgbe_ethdev.c
> @@ -3957,7 +3957,7 @@ ixgbe_dev_link_update_share(struct rte_eth_dev *dev,
> bool autoneg = false;
>
> link.link_status = ETH_LINK_DOWN;
> - link.link_speed = 0;
> + link.link_speed = ETH_SPEED_NUM_NONE;
> link.link_duplex = ETH_LINK_HALF_DUPLEX;
> link.link_autoneg = ETH_LINK_AUTONEG;
> memset(&old, 0, sizeof(old));
> diff --git a/drivers/net/mlx4/mlx4_ethdev.c b/drivers/net/mlx4/mlx4_ethdev.c
> index fbeef16c8..beecc53ba 100644
> --- a/drivers/net/mlx4/mlx4_ethdev.c
> +++ b/drivers/net/mlx4/mlx4_ethdev.c
> @@ -710,7 +710,7 @@ mlx4_link_update(struct rte_eth_dev *dev, int wait_to_complete)
> }
> link_speed = ethtool_cmd_speed(&edata);
> if (link_speed == -1)
> - dev_link.link_speed = 0;
> + dev_link.link_speed = ETH_SPEED_NUM_NONE;
> else
> dev_link.link_speed = link_speed;
> dev_link.link_duplex = ((edata.duplex == DUPLEX_HALF) ?
> diff --git a/drivers/net/mlx5/mlx5_ethdev.c b/drivers/net/mlx5/mlx5_ethdev.c
> index b73cb53df..de5576099 100644
> --- a/drivers/net/mlx5/mlx5_ethdev.c
> +++ b/drivers/net/mlx5/mlx5_ethdev.c
> @@ -536,7 +536,7 @@ mlx5_link_update_unlocked_gset(struct rte_eth_dev *dev, int wait_to_complete)
> }
> link_speed = ethtool_cmd_speed(&edata);
> if (link_speed == -1)
> - dev_link.link_speed = 0;
> + dev_link.link_speed = ETH_SPEED_NUM_NONE;
> else
> dev_link.link_speed = link_speed;
> priv->link_speed_capa = 0;
> --
> 2.13.6
Hi Ferruh,
On mlx5 this hunk is conflicts with my series [1].
Regards,
[1] https://dpdk.org/ml/archives/dev/2018-March/092495.html
--
Nélio Laranjeiro
6WIND
More information about the dev
mailing list