ethdev: support flow elements with variable length

Flow API provides RAW item type for packet patterns of variable
length. The RAW item structure has fixed size members that describe the
variable pattern length and methods to process it.

There is the new Flow items with variable lengths coming - flex
item. In order to handle this item (and potentially other new ones
with variable pattern length) in flow copy and conversion routines
the helper function is introduced.

Signed-off-by: Gregory Etelson <getelson@nvidia.com>
Reviewed-by: Viacheslav Ovsiienko <viacheslavo@nvidia.com>
Acked-by: Ori Kam <orika@nvidia.com>
This commit is contained in:
Gregory Etelson 2021-10-20 18:14:54 +03:00 committed by Ferruh Yigit
parent c8c6997325
commit 6cf7204733

View File

@ -30,13 +30,52 @@ uint64_t rte_flow_dynf_metadata_mask;
struct rte_flow_desc_data { struct rte_flow_desc_data {
const char *name; const char *name;
size_t size; size_t size;
size_t (*desc_fn)(void *dst, const void *src);
}; };
/**
*
* @param buf
* Destination memory.
* @param data
* Source memory
* @param size
* Requested copy size
* @param desc
* rte_flow_desc_item - for flow item conversion.
* rte_flow_desc_action - for flow action conversion.
* @param type
* Offset into the desc param or negative value for private flow elements.
*/
static inline size_t
rte_flow_conv_copy(void *buf, const void *data, const size_t size,
const struct rte_flow_desc_data *desc, int type)
{
/**
* Allow PMD private flow item
*/
size_t sz = type >= 0 ? desc[type].size : sizeof(void *);
if (buf == NULL || data == NULL)
return 0;
rte_memcpy(buf, data, (size > sz ? sz : size));
if (desc[type].desc_fn)
sz += desc[type].desc_fn(size > 0 ? buf : NULL, data);
return sz;
}
/** Generate flow_item[] entry. */ /** Generate flow_item[] entry. */
#define MK_FLOW_ITEM(t, s) \ #define MK_FLOW_ITEM(t, s) \
[RTE_FLOW_ITEM_TYPE_ ## t] = { \ [RTE_FLOW_ITEM_TYPE_ ## t] = { \
.name = # t, \ .name = # t, \
.size = s, \ .size = s, \
.desc_fn = NULL,\
}
#define MK_FLOW_ITEM_FN(t, s, fn) \
[RTE_FLOW_ITEM_TYPE_ ## t] = {\
.name = # t, \
.size = s, \
.desc_fn = fn, \
} }
/** Information about known flow pattern items. */ /** Information about known flow pattern items. */
@ -109,8 +148,17 @@ static const struct rte_flow_desc_data rte_flow_desc_item[] = {
[RTE_FLOW_ACTION_TYPE_ ## t] = { \ [RTE_FLOW_ACTION_TYPE_ ## t] = { \
.name = # t, \ .name = # t, \
.size = s, \ .size = s, \
.desc_fn = NULL,\
} }
#define MK_FLOW_ACTION_FN(t, fn) \
[RTE_FLOW_ACTION_TYPE_ ## t] = { \
.name = # t, \
.size = 0, \
.desc_fn = fn,\
}
/** Information about known flow actions. */ /** Information about known flow actions. */
static const struct rte_flow_desc_data rte_flow_desc_action[] = { static const struct rte_flow_desc_data rte_flow_desc_action[] = {
MK_FLOW_ACTION(END, 0), MK_FLOW_ACTION(END, 0),
@ -531,12 +579,8 @@ rte_flow_conv_item_spec(void *buf, const size_t size,
} }
break; break;
default: default:
/** off = rte_flow_conv_copy(buf, data, size,
* allow PMD private flow item rte_flow_desc_item, item->type);
*/
off = (int)item->type >= 0 ?
rte_flow_desc_item[item->type].size : sizeof(void *);
rte_memcpy(buf, data, (size > off ? off : size));
break; break;
} }
return off; return off;
@ -638,12 +682,8 @@ rte_flow_conv_action_conf(void *buf, const size_t size,
} }
break; break;
default: default:
/** off = rte_flow_conv_copy(buf, action->conf, size,
* allow PMD private flow action rte_flow_desc_action, action->type);
*/
off = (int)action->type >= 0 ?
rte_flow_desc_action[action->type].size : sizeof(void *);
rte_memcpy(buf, action->conf, (size > off ? off : size));
break; break;
} }
return off; return off;