Hello, It seems you didn't try to address my main comment on v4: " Before doing anything, the first patch of this series should make the current status clearer. Example, this line does not explain what it does: uint16_t split_hdr_size; /**< hdr buf size (header_split enabled).*/ And header_split has been removed in ab3ce1e0c193 ("ethdev: remove old offload API")
If RTE_ETH_RX_OFFLOAD_HEADER_SPLIT is not needed, let's add a comment to start a deprecation. " Also the comment from Andrew about removing limitation to 2 packets is not addressed. All the part about the protocols capability is missing here. It is not encouraging. 26/04/2022 13:13, wenxuanx...@intel.com: > From: Wenxuan Wu <wenxuanx...@intel.com> > > Protocol based buffer split consists of splitting a received packet into two > separate regions based on its content. The split happens after the packet > protocol header and before the packet payload. Splitting is usually between > the packet protocol header that can be posted to a dedicated buffer and the > packet payload that can be posted to a different buffer. > > Currently, Rx buffer split supports length and offset based packet split. > protocol split is based on buffer split, configuring length of buffer split > is not suitable for NICs that do split based on protocol types. Why? Is it impossible to support length split on Intel NIC? > Because tunneling makes the conversion from length > to protocol type impossible. This is not a HW issue. I agree on the need but that a different usage than length split. > This patch extends the current buffer split to support protocol and offset > based buffer split. A new proto field is introduced in the rte_eth_rxseg_split > structure reserved field to specify header protocol type. With Rx queue > offload RTE_ETH_RX_OFFLOAD_BUFFER_SPLIT enabled and corresponding protocol > type configured. PMD will split the ingress packets into two separate regions. > Currently, both inner and outer L2/L3/L4 level protocol based buffer split > can be supported. > > For example, let's suppose we configured the Rx queue with the > following segments: > seg0 - pool0, off0=2B > seg1 - pool1, off1=128B > > With protocol split type configured with RTE_PTYPE_L4_UDP. The packet > consists of MAC_IP_UDP_PAYLOAD will be splitted like following: > seg0 - udp header @ RTE_PKTMBUF_HEADROOM + 2 in mbuf from pool0 > seg1 - payload @ 128 in mbuf from pool1 Not clear what is the calculation. > The memory attributes for the split parts may differ either - for example > the mempool0 and mempool1 belong to dpdk memory and external memory, > respectively. > > Signed-off-by: Xuan Ding <xuan.d...@intel.com> > Signed-off-by: Yuan Wang <yuanx.w...@intel.com> > Signed-off-by: Wenxuan Wu <wenxuanx...@intel.com> > Reviewed-by: Qi Zhang <qi.z.zh...@intel.com> > --- > lib/ethdev/rte_ethdev.c | 36 +++++++++++++++++++++++++++++------- > lib/ethdev/rte_ethdev.h | 15 ++++++++++++++- > 2 files changed, 43 insertions(+), 8 deletions(-) > > diff --git a/lib/ethdev/rte_ethdev.c b/lib/ethdev/rte_ethdev.c > index 29a3d80466..1a2bc172ab 100644 > --- a/lib/ethdev/rte_ethdev.c > +++ b/lib/ethdev/rte_ethdev.c > @@ -1661,6 +1661,7 @@ rte_eth_rx_queue_check_split(const struct > rte_eth_rxseg_split *rx_seg, > struct rte_mempool *mpl = rx_seg[seg_idx].mp; > uint32_t length = rx_seg[seg_idx].length; > uint32_t offset = rx_seg[seg_idx].offset; > + uint32_t proto = rx_seg[seg_idx].proto; > > if (mpl == NULL) { > RTE_ETHDEV_LOG(ERR, "null mempool pointer\n"); > @@ -1694,13 +1695,34 @@ rte_eth_rx_queue_check_split(const struct > rte_eth_rxseg_split *rx_seg, > } > offset += seg_idx != 0 ? 0 : RTE_PKTMBUF_HEADROOM; > *mbp_buf_size = rte_pktmbuf_data_room_size(mpl); > - length = length != 0 ? length : *mbp_buf_size; > - if (*mbp_buf_size < length + offset) { > - RTE_ETHDEV_LOG(ERR, > - "%s mbuf_data_room_size %u < %u (segment > length=%u + segment offset=%u)\n", > - mpl->name, *mbp_buf_size, > - length + offset, length, offset); > - return -EINVAL; > + if (proto == 0) { Add a comment here, /* split at fixed length */ > + length = length != 0 ? length : *mbp_buf_size; > + if (*mbp_buf_size < length + offset) { > + RTE_ETHDEV_LOG(ERR, > + "%s mbuf_data_room_size %u < %u > (segment length=%u + segment offset=%u)\n", > + mpl->name, *mbp_buf_size, > + length + offset, length, offset); > + return -EINVAL; > + } > + } else { Add a comment here, /* split after specified protocol header */ > + /* Ensure n_seg is 2 in protocol based buffer split. */ > + if (n_seg != 2) { (should be a space, not a tab before brace) Why do you limit the feature to 2 segments only? > + RTE_ETHDEV_LOG(ERR, "number of buffer split > protocol segments should be 2.\n"); > + return -EINVAL; > + } > + /* Length and protocol are exclusive here, so make sure > length is 0 in protocol > + based buffer split. */ > + if (length != 0) { > + RTE_ETHDEV_LOG(ERR, "segment length should be > set to zero in buffer split\n"); > + return -EINVAL; > + } > + if (*mbp_buf_size < offset) { > + RTE_ETHDEV_LOG(ERR, > + "%s mbuf_data_room_size %u < %u > segment offset)\n", > + mpl->name, *mbp_buf_size, > + offset); > + return -EINVAL; [...] > + * - The proto in the elements defines the split position of received > packets. > + * > * - If the length in the segment description element is zero > * the actual buffer size will be deduced from the appropriate > * memory pool properties. > @@ -1197,12 +1200,21 @@ struct rte_eth_txmode { > * - pool from the last valid element > * - the buffer size from this pool > * - zero offset > + * > + * - Length based buffer split: > + * - mp, length, offset should be configured. > + * - The proto should not be configured in length split. Zero default. > + * > + * - Protocol based buffer split: > + * - mp, offset, proto should be configured. > + * - The length should not be configured in protocol split. Zero default. What means "Zero default"? You should just ignore the non relevant field. > struct rte_eth_rxseg_split { > struct rte_mempool *mp; /**< Memory pool to allocate segment from. */ > uint16_t length; /**< Segment data length, configures split point. */ > uint16_t offset; /**< Data offset from beginning of mbuf data buffer. */ > - uint32_t reserved; /**< Reserved field. */ How do you manage ABI compatibility? Was the reserved field initialized to 0 in previous versions? > + uint32_t proto; /**< Protocol of buffer split, determines protocol > split point. */ What are the values for "proto"? > @@ -1664,6 +1676,7 @@ struct rte_eth_conf { > RTE_ETH_RX_OFFLOAD_QINQ_STRIP) > #define DEV_RX_OFFLOAD_VLAN RTE_DEPRECATED(DEV_RX_OFFLOAD_VLAN) > RTE_ETH_RX_OFFLOAD_VLAN > > + It looks to be an useless change. > /* > * If new Rx offload capabilities are defined, they also must be > * mentioned in rte_rx_offload_names in rte_ethdev.c file. >