On Mon, 18 Mar 2024 10:48:03 +0800
"junwan...@cestc.cn" <junwan...@cestc.cn> wrote:

> The issue indeed lies with the ixgbe driver. After making the following 
> modifications, dpdk-dumpcap is now functioning properly.
> diff --git a/drivers/net/ixgbe/ixgbe_ethdev.c 
> b/drivers/net/ixgbe/ixgbe_ethdev.c
> index 
> d6cf00317e77b64f9822c155115f388ae62241eb..99b26f3c758b3c7ced5d59c6b27f305efe6cc33c
>  100644
> --- a/drivers/net/ixgbe/ixgbe_ethdev.c
> +++ b/drivers/net/ixgbe/ixgbe_ethdev.c
> @@ -4301,48 +4301,50 @@ ixgbe_dev_link_update_share(struct rte_eth_dev *dev,
>       wait = 1;
>  #endif
>  
> -     if (vf)
> -             diag = ixgbevf_check_link(hw, &link_speed, &link_up, wait);
> -     else
> -             diag = ixgbe_check_link(hw, &link_speed, &link_up, wait);
> +     if (rte_eal_process_type() == RTE_PROC_PRIMARY) {
> +             if (vf)
> +                     diag = ixgbevf_check_link(hw, &link_speed, &link_up, 
> wait);
> +             else
> +                     diag = ixgbe_check_link(hw, &link_speed, &link_up, 
> wait);
>  
> -     if (diag != 0) {
> -             link.link_speed = RTE_ETH_SPEED_NUM_100M;
> -             link.link_duplex = RTE_ETH_LINK_FULL_DUPLEX;
> -             return rte_eth_linkstatus_set(dev, &link);
> -     }
> +             if (diag != 0) {
> +                     link.link_speed = RTE_ETH_SPEED_NUM_100M;
> +                     link.link_duplex = RTE_ETH_LINK_FULL_DUPLEX;
> +                     return rte_eth_linkstatus_set(dev, &link);
> +             }
> +
> +             if (ixgbe_get_media_type(hw) == ixgbe_media_type_fiber &&
> +                 !ad->sdp3_no_tx_disable) {
> +                     esdp_reg = IXGBE_READ_REG(hw, IXGBE_ESDP);
> +                     if ((esdp_reg & IXGBE_ESDP_SDP3))
> +                             link_up = 0;
> +             }
>  
> -     if (ixgbe_get_media_type(hw) == ixgbe_media_type_fiber &&
> -         !ad->sdp3_no_tx_disable) {
> -             esdp_reg = IXGBE_READ_REG(hw, IXGBE_ESDP);
> -             if ((esdp_reg & IXGBE_ESDP_SDP3))
> -                     link_up = 0;
> -     }
> -
> -     if (link_up == 0) {
> -             if (ixgbe_get_media_type(hw) == ixgbe_media_type_fiber) {
> -                     ixgbe_dev_wait_setup_link_complete(dev, 0);
> -                     /* NOTE: review for potential ordering optimization */
> -                     if (!__atomic_test_and_set(&ad->link_thread_running, 
> __ATOMIC_SEQ_CST)) {
> -                             /* To avoid race condition between threads, set
> -                              * the IXGBE_FLAG_NEED_LINK_CONFIG flag only
> -                              * when there is no link thread running.
> -                              */
> -                             intr->flags |= IXGBE_FLAG_NEED_LINK_CONFIG;
> -                             if 
> (rte_thread_create_internal_control(&ad->link_thread_tid,
> -                                             "ixgbe-link",
> -                                             
> ixgbe_dev_setup_link_thread_handler, dev) < 0) {
> +             if (link_up == 0) {
> +                     if (ixgbe_get_media_type(hw) == ixgbe_media_type_fiber) 
> {
> +                             ixgbe_dev_wait_setup_link_complete(dev, 0);
> +                             /* NOTE: review for potential ordering 
> optimization */
> +                             if 
> (!__atomic_test_and_set(&ad->link_thread_running, __ATOMIC_SEQ_CST)) {
> +                                     /* To avoid race condition between 
> threads, set
> +                                      * the IXGBE_FLAG_NEED_LINK_CONFIG flag 
> only
> +                                      * when there is no link thread running.
> +                                      */
> +                                     intr->flags |= 
> IXGBE_FLAG_NEED_LINK_CONFIG;
> +                                     if 
> (rte_thread_create_internal_control(&ad->link_thread_tid,
> +                                                     "ixgbe-link",
> +                                                     
> ixgbe_dev_setup_link_thread_handler, dev) < 0) {
> +                                             PMD_DRV_LOG(ERR,
> +                                                     "Create link thread 
> failed!");
> +                                             /* NOTE: review for potential 
> ordering optimization */
> +                                             
> __atomic_clear(&ad->link_thread_running, __ATOMIC_SEQ_CST);
> +                                     }
> +                             } else {
>                                       PMD_DRV_LOG(ERR,
> -                                             "Create link thread failed!");
> -                                     /* NOTE: review for potential ordering 
> optimization */
> -                                     
> __atomic_clear(&ad->link_thread_running, __ATOMIC_SEQ_CST);
> +                                             "Other link thread is running 
> now!");
>                               }
> -                     } else {
> -                             PMD_DRV_LOG(ERR,
> -                                     "Other link thread is running now!");
>                       }
> +                     return rte_eth_linkstatus_set(dev, &link);
>               }
> -             return rte_eth_linkstatus_set(dev, &link);
>       }
>  
>       link.link_status = RTE_ETH_LINK_UP;
> 
>

Please send this to mailing list.
Ideally it would go to Ixgbe maintainer but there doesn't appear to be one 
right now.

Reply via email to