On Thu, Jul 13, 2023 at 4:39 PM Dumitru Ceara <dce...@redhat.com> wrote:

> Regular dp-hash is not a canonical L4 hash (at least with the netlink
> datapath).  If the datapath supports l4 symmetrical dp-hash use that one
> instead.
>
> Reported-at: https://github.com/ovn-org/ovn/issues/112
> Reported-at: https://bugzilla.redhat.com/show_bug.cgi?id=2188679
> Signed-off-by: Dumitru Ceara <dce...@redhat.com>
>

Hi Dumitru,


> ---
>  include/ovn/features.h |  2 ++
>  lib/actions.c          |  6 ++++++
>  lib/features.c         | 49 +++++++++++++++++++++++++++++++++---------
>  3 files changed, 47 insertions(+), 10 deletions(-)
>
> diff --git a/include/ovn/features.h b/include/ovn/features.h
> index de8f1f5489..3bf536127f 100644
> --- a/include/ovn/features.h
> +++ b/include/ovn/features.h
> @@ -34,12 +34,14 @@ enum ovs_feature_support_bits {
>      OVS_CT_ZERO_SNAT_SUPPORT_BIT,
>      OVS_DP_METER_SUPPORT_BIT,
>      OVS_CT_TUPLE_FLUSH_BIT,
> +    OVS_DP_HASH_L4_SYM_BIT,
>  };
>
>  enum ovs_feature_value {
>      OVS_CT_ZERO_SNAT_SUPPORT = (1 << OVS_CT_ZERO_SNAT_SUPPORT_BIT),
>      OVS_DP_METER_SUPPORT = (1 << OVS_DP_METER_SUPPORT_BIT),
>      OVS_CT_TUPLE_FLUSH_SUPPORT = (1 << OVS_CT_TUPLE_FLUSH_BIT),
> +    OVS_DP_HASH_L4_SYM_SUPPORT = (1 << OVS_DP_HASH_L4_SYM_BIT),
>  };
>
>  void ovs_feature_support_destroy(void);
> diff --git a/lib/actions.c b/lib/actions.c
> index 037172e606..9d52cb75a8 100644
> --- a/lib/actions.c
> +++ b/lib/actions.c
> @@ -1625,6 +1625,12 @@ encode_SELECT(const struct ovnact_select *select,
>      struct ds ds = DS_EMPTY_INITIALIZER;
>      ds_put_format(&ds, "type=select,selection_method=dp_hash");
>
> +    if (ovs_feature_is_supported(OVS_DP_HASH_L4_SYM_SUPPORT)) {
> +        /* Select dp-hash l4_symmetric by setting the upper 32bits of
> +         * selection_method_param to 1: */
>

This comment is a bit unfortunate, because it reads like you want to set
all bits of the upper half
to 1 e.g. 0xffffffff. Maybe change it to: "selection_method_param to value
1 (1 << 32)." during merge, wdyt?


> +        ds_put_cstr(&ds, ",selection_method_param=0x100000000");
> +    }
> +
>      struct mf_subfield sf = expr_resolve_field(&select->res_field);
>
>      for (size_t bucket_id = 0; bucket_id < select->n_dsts; bucket_id++) {
> diff --git a/lib/features.c b/lib/features.c
> index 97c9c86f00..d24e8f6c5c 100644
> --- a/lib/features.c
> +++ b/lib/features.c
> @@ -21,6 +21,7 @@
>  #include "lib/dirs.h"
>  #include "socket-util.h"
>  #include "lib/vswitch-idl.h"
> +#include "odp-netlink.h"
>  #include "openvswitch/vlog.h"
>  #include "openvswitch/ofpbuf.h"
>  #include "openvswitch/rconn.h"
> @@ -33,20 +34,48 @@ VLOG_DEFINE_THIS_MODULE(features);
>
>  #define FEATURES_DEFAULT_PROBE_INTERVAL_SEC 5
>
> +/* Parses 'cap_name' from 'ovs_capabilities' and returns whether the
> + * type of capability is supported or not. */
> +typedef bool ovs_feature_parse_func(const struct smap *ovs_capabilities,
> +                                    const char *cap_name);
> +
>  struct ovs_feature {
>      enum ovs_feature_value value;
>      const char *name;
> +    ovs_feature_parse_func *parse;
>  };
>
> +static bool
> +bool_parser(const struct smap *ovs_capabilities, const char *cap_name)
> +{
> +    return smap_get_bool(ovs_capabilities, cap_name, false);
> +}
> +
> +static bool
> +dp_hash_l4_sym_support_parser(const struct smap *ovs_capabilities,
> +                              const char *cap_name OVS_UNUSED)
> +{
> +    int max_hash_alg = smap_get_int(ovs_capabilities, "max_hash_alg", 0);
> +
> +    return max_hash_alg == OVS_HASH_ALG_SYM_L4;
> +}
> +
>  static struct ovs_feature all_ovs_features[] = {
>      {
>          .value = OVS_CT_ZERO_SNAT_SUPPORT,
> -        .name = "ct_zero_snat"
> +        .name = "ct_zero_snat",
> +        .parse = bool_parser,
>      },
>      {
>          .value = OVS_CT_TUPLE_FLUSH_SUPPORT,
> -        .name = "ct_flush"
> -    }
> +        .name = "ct_flush",
> +        .parse = bool_parser,
> +    },
> +    {
> +        .value = OVS_DP_HASH_L4_SYM_SUPPORT,
> +        .name = "dp_hash_l4_sym_support",
> +        .parse = dp_hash_l4_sym_support_parser,
> +    },
>  };
>
>  /* A bitmap of OVS features that have been detected as 'supported'. */
> @@ -65,6 +94,7 @@ ovs_feature_is_valid(enum ovs_feature_value feature)
>      case OVS_CT_ZERO_SNAT_SUPPORT:
>      case OVS_DP_METER_SUPPORT:
>      case OVS_CT_TUPLE_FLUSH_SUPPORT:
> +    case OVS_DP_HASH_L4_SYM_SUPPORT:
>          return true;
>      default:
>          return false;
> @@ -183,18 +213,17 @@ ovs_feature_support_run(const struct smap
> *ovs_capabilities,
>      }
>
>      for (size_t i = 0; i < ARRAY_SIZE(all_ovs_features); i++) {
> -        enum ovs_feature_value value = all_ovs_features[i].value;
> -        const char *name = all_ovs_features[i].name;
> -        bool old_state = supported_ovs_features & value;
> -        bool new_state = smap_get_bool(ovs_capabilities, name, false);
> +        struct ovs_feature *feature = &all_ovs_features[i];
> +        bool old_state = supported_ovs_features & feature->value;
> +        bool new_state = feature->parse(ovs_capabilities, feature->name);
>          if (new_state != old_state) {
>              updated = true;
>              if (new_state) {
> -                supported_ovs_features |= value;
> +                supported_ovs_features |= feature->value;
>              } else {
> -                supported_ovs_features &= ~value;
> +                supported_ovs_features &= ~feature->value;
>              }
> -            VLOG_INFO_RL(&rl, "OVS Feature: %s, state: %s", name,
> +            VLOG_INFO_RL(&rl, "OVS Feature: %s, state: %s", feature->name,
>                           new_state ? "supported" : "not supported");
>          }
>      }
> --
> 2.31.1
>
> _______________________________________________
> dev mailing list
> d...@openvswitch.org
> https://mail.openvswitch.org/mailman/listinfo/ovs-dev
>
>
Other than that it looks good.

Acked-by: Ales Musil <amu...@redhat.com>

-- 

Ales Musil

Senior Software Engineer - OVN Core

Red Hat EMEA <https://www.redhat.com>

amu...@redhat.com    IM: amusil
<https://red.ht/sig>
_______________________________________________
dev mailing list
d...@openvswitch.org
https://mail.openvswitch.org/mailman/listinfo/ovs-dev

Reply via email to