Hi Michal,

> -----Original Message-----
> From: dev [mailto:dev-boun...@dpdk.org] On Behalf Of Michal Miroslaw
> Sent: Tuesday, December 13, 2016 1:08 AM
> To: dev@dpdk.org
> Subject: [dpdk-dev] [PATCH 04/13] acl: allow zero verdict
> 
> Signed-off-by: Michał Mirosław <michal.miros...@atendesoftware.pl>
> ---
>  lib/librte_acl/rte_acl.c         | 3 +--
>  lib/librte_acl/rte_acl.h         | 2 --
>  lib/librte_table/rte_table_acl.c | 2 +-
>  3 files changed, 2 insertions(+), 5 deletions(-)
> 
> diff --git a/lib/librte_acl/rte_acl.c b/lib/librte_acl/rte_acl.c
> index 8b7e92c..d1f40be 100644
> --- a/lib/librte_acl/rte_acl.c
> +++ b/lib/librte_acl/rte_acl.c
> @@ -313,8 +313,7 @@ acl_check_rule(const struct rte_acl_rule_data *rd)
>       if ((RTE_LEN2MASK(RTE_ACL_MAX_CATEGORIES, typeof(rd->category_mask)) &
>                       rd->category_mask) == 0 ||
>                       rd->priority > RTE_ACL_MAX_PRIORITY ||
> -                     rd->priority < RTE_ACL_MIN_PRIORITY ||
> -                     rd->userdata == RTE_ACL_INVALID_USERDATA)
> +                     rd->priority < RTE_ACL_MIN_PRIORITY)
>               return -EINVAL;
>       return 0;
>  }

I am not sure, how it supposed to work properly?
Zero value is reserved and ifnicates that no match were found for that input.
Konstantin


> diff --git a/lib/librte_acl/rte_acl.h b/lib/librte_acl/rte_acl.h
> index caa91f7..b53179a 100644
> --- a/lib/librte_acl/rte_acl.h
> +++ b/lib/librte_acl/rte_acl.h
> @@ -120,8 +120,6 @@ enum {
>       RTE_ACL_MIN_PRIORITY = 0,
>  };
> 
> -#define      RTE_ACL_INVALID_USERDATA        0
> -
>  #define      RTE_ACL_MASKLEN_TO_BITMASK(v, s)        \
>  ((v) == 0 ? (v) : (typeof(v))((uint64_t)-1 << ((s) * CHAR_BIT - (v))))
> 
> diff --git a/lib/librte_table/rte_table_acl.c 
> b/lib/librte_table/rte_table_acl.c
> index 8f1f8ce..94b69a9 100644
> --- a/lib/librte_table/rte_table_acl.c
> +++ b/lib/librte_table/rte_table_acl.c
> @@ -792,7 +792,7 @@ rte_table_acl_lookup(
> 
>               pkts_mask &= ~pkt_mask;
> 
> -             if (action_table_pos != RTE_ACL_INVALID_USERDATA) {
> +             if (action_table_pos != 0) {
>                       pkts_out_mask |= pkt_mask;
>                       entries[pkt_pos] = (void *)
>                               &acl->memory[action_table_pos *
> --
> 2.10.2

Reply via email to