> -----Original Message-----
> From: Stephen Douthit <steph...@silicom-usa.com>
> Sent: Tuesday, December 7, 2021 06:19
> To: Wang, Haiyue <haiyue.w...@intel.com>; Lu, Wenzhuo <wenzhuo...@intel.com>
> Cc: dev@dpdk.org; Wen Wang <w...@silicom-usa.com>; Stephen Douthit 
> <steph...@silicom-usa.com>;
> sta...@dpdk.org
> Subject: [PATCH v2 1/7] net/ixgbe: Fix ixgbe_is_sfp() to return valid result 
> for X550EM_a devs
> 
> Currently all X500EM* MAC types fallthrough to the default case and get
> reported as non-SFP regardless of media type, which isn't correct.
> 
> Fixes: 0790adeb567 ("ixgbe/base: support X550em_a device")
> Cc: sta...@dpdk.org
> 
> Signed-off-by: Stephen Douthit <steph...@silicom-usa.com>
> ---
>  drivers/net/ixgbe/ixgbe_ethdev.c | 14 ++++++++++++++
>  1 file changed, 14 insertions(+)
> 
> diff --git a/drivers/net/ixgbe/ixgbe_ethdev.c 
> b/drivers/net/ixgbe/ixgbe_ethdev.c
> index fe61dba81d..66f7af95de 100644
> --- a/drivers/net/ixgbe/ixgbe_ethdev.c
> +++ b/drivers/net/ixgbe/ixgbe_ethdev.c
> @@ -781,6 +781,20 @@ ixgbe_is_sfp(struct ixgbe_hw *hw)
>       case ixgbe_phy_sfp_passive_unknown:
>               return 1;
>       default:
> +             /* x550em devices may be SFP, check media type */
> +             switch (hw->mac.type) {
> +             case ixgbe_mac_X550EM_x:
> +             case ixgbe_mac_X550EM_a:
> +                     switch (hw->mac.ops.get_media_type(hw)) {

Use the API 'ixgbe_get_media_type' to avoid ops null ?

> +                     case ixgbe_media_type_fiber:
> +                     case ixgbe_media_type_fiber_qsfp:
> +                             return 1;
> +                     default:
> +                             return 0;

Since we care 'return 1' only, then the two defaults just "break;" ?

> +                     }
> +             default:
> +                     return 0; 

Just 'break;'

> +             }
>               return 0;

Then this default '0' will be used.

>       }
>  }
> --
> 2.31.1

Reply via email to