2018-12-16 08:58:33 +08: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;
|
|
|
|
|
|
|
|
ol_flags |= (tx_offload & DEV_TX_OFFLOAD_VLAN_INSERT) ?
|
|
|
|
PKT_TX_VLAN : 0;
|
|
|
|
ol_flags |= (tx_offload & DEV_TX_OFFLOAD_QINQ_INSERT) ?
|
|
|
|
PKT_TX_QINQ : 0;
|
|
|
|
ol_flags |= (tx_offload & DEV_TX_OFFLOAD_MACSEC_INSERT) ?
|
|
|
|
PKT_TX_MACSEC : 0;
|
|
|
|
|
|
|
|
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;
|
|
|
|
|
|
|
|
if (ol_flags & PKT_TX_VLAN)
|
|
|
|
for (i = 0; i < nb; i++)
|
|
|
|
pkts[i]->vlan_tci = vlan;
|
|
|
|
if (ol_flags & PKT_TX_QINQ)
|
|
|
|
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)
|
|
|
|
{
|
|
|
|
mb->ol_flags &= IND_ATTACHED_MBUF | EXT_ATTACHED_MBUF;
|
|
|
|
mb->ol_flags |= ol_flags;
|
2019-05-21 18:13:03 +02:00
|
|
|
mb->l2_len = sizeof(struct rte_ether_hdr);
|
2018-12-16 08:58:33 +08:00
|
|
|
mb->l3_len = sizeof(struct ipv4_hdr);
|
|
|
|
}
|
|
|
|
|
|
|
|
#endif /* _MACSWAP_COMMON_H_ */
|