2020-06-18 16:55:50 +00:00
|
|
|
/* SPDX-License-Identifier: BSD-3-Clause
|
|
|
|
* Copyright(c) 2018 Intel Corporation
|
|
|
|
*/
|
|
|
|
|
|
|
|
#ifndef _MACSWAP_COMMON_H_
|
|
|
|
#define _MACSWAP_COMMON_H_
|
|
|
|
|
|
|
|
static inline uint64_t
|
|
|
|
ol_flags_init(uint64_t tx_offload)
|
|
|
|
{
|
|
|
|
uint64_t ol_flags = 0;
|
|
|
|
|
2022-09-06 04:00:10 +00:00
|
|
|
ol_flags |= (tx_offload & RTE_ETH_TX_OFFLOAD_VLAN_INSERT) ?
|
|
|
|
RTE_MBUF_F_TX_VLAN : 0;
|
|
|
|
ol_flags |= (tx_offload & RTE_ETH_TX_OFFLOAD_QINQ_INSERT) ?
|
|
|
|
RTE_MBUF_F_TX_QINQ : 0;
|
|
|
|
ol_flags |= (tx_offload & RTE_ETH_TX_OFFLOAD_MACSEC_INSERT) ?
|
|
|
|
RTE_MBUF_F_TX_MACSEC : 0;
|
2020-06-18 16:55:50 +00:00
|
|
|
|
|
|
|
return ol_flags;
|
|
|
|
}
|
|
|
|
|
|
|
|
static inline void
|
|
|
|
vlan_qinq_set(struct rte_mbuf *pkts[], uint16_t nb,
|
|
|
|
uint64_t ol_flags, uint16_t vlan, uint16_t outer_vlan)
|
|
|
|
{
|
|
|
|
int i;
|
|
|
|
|
2022-09-06 04:00:10 +00:00
|
|
|
if (ol_flags & RTE_MBUF_F_TX_VLAN)
|
2020-06-18 16:55:50 +00:00
|
|
|
for (i = 0; i < nb; i++)
|
|
|
|
pkts[i]->vlan_tci = vlan;
|
2022-09-06 04:00:10 +00:00
|
|
|
if (ol_flags & RTE_MBUF_F_TX_QINQ)
|
2020-06-18 16:55:50 +00:00
|
|
|
for (i = 0; i < nb; i++)
|
|
|
|
pkts[i]->vlan_tci_outer = outer_vlan;
|
|
|
|
}
|
|
|
|
|
|
|
|
static inline void
|
|
|
|
mbuf_field_set(struct rte_mbuf *mb, uint64_t ol_flags)
|
|
|
|
{
|
2022-09-06 04:00:10 +00:00
|
|
|
mb->ol_flags &= RTE_MBUF_F_INDIRECT | RTE_MBUF_F_EXTERNAL;
|
2020-06-18 16:55:50 +00:00
|
|
|
mb->ol_flags |= ol_flags;
|
|
|
|
mb->l2_len = sizeof(struct rte_ether_hdr);
|
|
|
|
mb->l3_len = sizeof(struct rte_ipv4_hdr);
|
|
|
|
}
|
|
|
|
|
|
|
|
#endif /* _MACSWAP_COMMON_H_ */
|