Hello Andrew,

> On 2/2/23 14:54, Gregory Etelson wrote:
> > diff --git a/lib/ethdev/rte_flow.c b/lib/ethdev/rte_flow.c
> > index 7d0c24366c..4554c8f021 100644
> > --- a/lib/ethdev/rte_flow.c
> > +++ b/lib/ethdev/rte_flow.c
> > @@ -1883,3 +1883,85 @@ rte_flow_async_action_handle_query(uint16_t
> port_id,
> >                                         action_handle, data, user_data, 
> > error);
> >       return flow_err(port_id, ret, error);
> >   }
> > +
> > +int
> > +rte_flow_action_handle_query_update(uint16_t port_id,
> > +                                 struct rte_flow_action_handle *handle,
> > +                                 const void *update, void *query,
> > +                                 enum rte_flow_query_update_mode mode,
> > +                                 struct rte_flow_error *error)
> > +{
> > +     int ret;
> > +     struct rte_eth_dev *dev;
> > +     const struct rte_flow_ops *ops;
> > +
> > +     RTE_ETH_VALID_PORTID_OR_ERR_RET(port_id, -ENODEV);
> > +     if (!handle)
> > +             return -EINVAL;
> > +     dev = &rte_eth_devices[port_id];
> > +     ops = rte_flow_ops_get(port_id, error);
> > +     if (!ops)
> > +             return -ENOTSUP;
> > +     if (update && query) {
> > +             if (!ops->action_handle_query_update)
> > +                     return -ENOTSUP;
> > +             if (mode != RTE_FLOW_QU_QUERY_FIRST &&
> > +                 mode != RTE_FLOW_QU_UPDATE_FIRST)
> > +                     return -EINVAL;
> 
> Shouldn't it be checked in any case?
> Also I'd initialize RTE_FLOW_QU_QUERY_FIRST to 1 on enum
> definition to ensure that just 0 is not used as a mode value.
> Also "Required if both *update* and *query* are not NULL." does
> not make sense in the description since you have no way to skip
> it.
> 

Fixed in v10.

> > +             ret = ops->action_handle_query_update(dev, handle, update,
> > +                                                   query, mode, error);
> > +     } else if (!update && query) {
> > +             ret = rte_flow_action_handle_query(port_id, handle, query,
> > +                                                error);
> > +     } else if (update && !query) {
> > +             ret = rte_flow_action_handle_update(port_id, handle, update,
> > +                                                 error);
> > +     } else {
> > +             return -EINVAL;
> > +     }
> 
> IMHO logic is wrong above since it should be sufficient to
> implement just one action_handle_query_update callback instead
> of all three.
> 
> I.e. if action_handle_query_update is available, it should be
> used in any case.
> 

Fixed in v10.

> > +     return flow_err(port_id, ret, error);
> > +}
> >   };
> >
> >   INTERNAL {
> 
> same for async API

Fixed in v10.

Reply via email to