[PATCH v4 06/35] net/ice: refactor context descriptor handling

Burakov, Anatoly anatoly.burakov at intel.com
Wed Feb 11 10:17:34 CET 2026


On 2/10/2026 6:40 PM, Bruce Richardson wrote:
> On Tue, Feb 10, 2026 at 01:42:17PM +0100, Burakov, Anatoly wrote:
>> On 2/9/2026 5:45 PM, Bruce Richardson wrote:
>>> Create a single function to manage all context descriptor handling,
>>> which returns either 0 or 1 depending on whether a descriptor is needed
>>> or not, as well as returning directly the descriptor contents if
>>> relevant.
>>>
>>> Signed-off-by: Bruce Richardson <bruce.richardson at intel.com>
>>> ---
>>
>> <snip>
>>
>>> +static __rte_always_inline uint16_t
>>> +get_context_desc(uint64_t ol_flags, const struct rte_mbuf *tx_pkt,
>>> +	const union ci_tx_offload *tx_offload, const struct ci_tx_queue *txq,
>>> +	uint64_t *qw0, uint64_t *qw1)
>>> +{
>>> +	uint16_t cd_l2tag2 = 0;
>>> +	uint64_t cd_type_cmd_tso_mss = ICE_TX_DESC_DTYPE_CTX;
>>> +	uint32_t cd_tunneling_params = 0;
>>> +	uint64_t ptp_tx_index = txq->ice_vsi->adapter->ptp_tx_index;
>>> +
>>> +	if (ice_calc_context_desc(ol_flags) == 0)
>>> +		return 0;
>>> +
>>> +	if (ol_flags & RTE_MBUF_F_TX_TUNNEL_MASK)
>>> +		ice_parse_tunneling_params(ol_flags, *tx_offload, &cd_tunneling_params);
>>> +
>>> +	if (ol_flags & (RTE_MBUF_F_TX_TCP_SEG | RTE_MBUF_F_TX_UDP_SEG))
>>> +		cd_type_cmd_tso_mss |= ice_set_tso_ctx(ol_flags, tx_pkt, *tx_offload);
>>> +	else if (ol_flags & RTE_MBUF_F_TX_IEEE1588_TMST)
>>> +		cd_type_cmd_tso_mss |=
>>> +			((uint64_t)CI_TX_CTX_DESC_TSYN << CI_TXD_QW1_CMD_S) |
>>> +			((ptp_tx_index << ICE_TXD_CTX_QW1_TSYN_S) & ICE_TXD_CTX_QW1_TSYN_M);
>>
>> It's tangentially related to this commit but it caught my attention that TSO
>> and timestamping are mutually exclusive here. They *are* mutually exclusive
>> as far as the driver is concerned so that part is fine, but I couldn't find
>> any signs of us enforcing this limitation anywhere in our configuration
>> path, so a well behaved application could theoretically arrive at this
>> combination of mbuf flags without breaking anything.
>>
>> (if I understand things correctly, this applies to both ice and i40e)
>>
> Yes, you are correct here. However, I'm not sure if we can or should
> enforce this, as it is completely possible to have a queue where some
> packets are sent with TSO and others are sent with the timesync flag on
> them. There is no way for the actual Tx function to flag a bad packet.
> Best we can possibly do is add a check to the pre-Tx packet prepare
> function. WDYT?
> 
> /Bruce

Now that I think of it, I believe these features do not make logical 
sense together anyway (TSO means segmented packets while timestamping 
means you have one packet you timestamp) so perhaps this can be 
considered user error? I mean we could add a check if it doesn't hurt 
performance, but maybe this isn't a problem we need to solve.

-- 
Thanks,
Anatoly


More information about the dev mailing list