On 6/11/2020 9:43 AM, Qi Zhang wrote:
> This patch add support to get tunnel type of recipe
> after get recipe from fw. This will fix the issue in
> function ice_find_recp() for tunnel type comparing.
> 
> Signed-off-by: Wei Zhao <wei.zh...@intel.com>
> Signed-off-by: Paul M Stillwell Jr <paul.m.stillwell...@intel.com>
> Signed-off-by: Qi Zhang <qi.z.zh...@intel.com>

<...>

>  /**
> + * ice_get_tun_type_for_recipe - get tunnel type for the recipe
> + * @rid: recipe ID that we are populating
> + */
> +static enum ice_sw_tunnel_type ice_get_tun_type_for_recipe(u8 rid)
> +{
> +     u8 vxlan_profile[12] = {10, 11, 12, 16, 17, 18, 22, 23, 24, 25, 26, 27};
> +     u8 gre_profile[12] = {13, 14, 15, 19, 20, 21, 28, 29, 30, 31, 32, 33};
> +     u8 pppoe_profile[7] = {34, 35, 36, 37, 38, 39, 40};
> +     u8 non_tun_profile[6] = {4, 5, 6, 7, 8, 9};
> +     enum ice_sw_tunnel_type tun_type;
> +     u16 i, j, profile_num = 0;
> +     bool non_tun_valid = false;
> +     bool pppoe_valid = false;
> +     bool vxlan_valid = false;
> +     bool gre_valid = false;
> +     bool gtp_valid = false;
> +     bool flag_valid = false;
> +
> +     for (j = 0; j < ICE_MAX_NUM_PROFILES; j++) {
> +             if (!ice_is_bit_set(recipe_to_profile[rid], j))
> +                     continue;
> +             else
> +                     profile_num++;
> +
> +             for (i = 0; i < 12; i++) {
> +                     if (gre_profile[i] == j)
> +                             gre_valid = true;
> +             }
> +
> +             for (i = 0; i < 12; i++) {
> +                     if (vxlan_profile[i] == j)
> +                             vxlan_valid = true;
> +             }
> +
> +             for (i = 0; i < 7; i++) {
> +                     if (pppoe_profile[i] == j)
> +                             pppoe_valid = true;
> +             }
> +
> +             for (i = 0; i < 6; i++) {
> +                     if (non_tun_profile[i] == j)
> +                             non_tun_valid = true;
> +             }
> +
> +             if (j >= ICE_PROFID_IPV4_GTPC_TEID &&
> +                 j <= ICE_PROFID_IPV6_GTPU_IPV6_OTHER)
> +                     gtp_valid = true;
> +
> +             if (j >= ICE_PROFID_IPV4_ESP &&
> +                 j <= ICE_PROFID_IPV6_PFCP_SESSION)
> +                     flag_valid = true;
> +     }
> +
> +     if (!non_tun_valid && vxlan_valid)
> +             tun_type = ICE_SW_TUN_VXLAN;
> +     else if (!non_tun_valid && gre_valid)
> +             tun_type = ICE_SW_TUN_NVGRE;
> +     else if (!non_tun_valid && pppoe_valid)
> +             tun_type = ICE_SW_TUN_PPPOE;
> +     else if (!non_tun_valid && gtp_valid)
> +             tun_type = ICE_SW_TUN_GTP;
> +     else if ((non_tun_valid && vxlan_valid) ||
> +              (non_tun_valid && gre_valid) ||
> +              (non_tun_valid && gtp_valid) ||
> +              (non_tun_valid && pppoe_valid))
> +             tun_type = ICE_SW_TUN_AND_NON_TUN;
> +     else if ((non_tun_valid && !vxlan_valid) ||
> +              (non_tun_valid && !gre_valid) ||
> +              (non_tun_valid && !gtp_valid) ||
> +              (non_tun_valid && !pppoe_valid))
> +             tun_type = ICE_NON_TUN;
> +
> +     if (profile_num > 1 && tun_type == ICE_SW_TUN_PPPOE) {

This is giving 'tun_type' may be used uninitialized warning [1], fixing it
setting a default value [2] while merging.


[1]
.../dpdk/drivers/net/ice/base/ice_switch.c: In function ‘ice_find_recp’:
.../dpdk/drivers/net/ice/base/ice_switch.c:1100:22: error: ‘tun_type’ may be
used uninitialized in this function [-Werror=maybe-uninitialized]
 1100 |  if (profile_num > 1 && tun_type == ICE_SW_TUN_PPPOE) {
      |      ~~~~~~~~~~~~~~~~^~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~
.../dpdk/drivers/net/ice/base/ice_switch.c:1037:26: note: ‘tun_type’ was
declared here
 1037 |  enum ice_sw_tunnel_type tun_type;
      |                          ^~~~~~~~

[2]
 -       enum ice_sw_tunnel_type tun_type;
 +       enum ice_sw_tunnel_type tun_type = ICE_NON_TUN;

Reply via email to