net/ixgbe: support checksum flags in SSE vector Rx
Update desc_to_olflags_v() to set PKT_RX_IP_CKSUM_BAD and PKT_RX_L4_CKSUM_BAD in the ol_fags of the mbuf. The Rx vector function can now be used with hw_ip_checksum enabled. Tested with: cd dpdk.org/ make config T=x86_64-native-linuxapp-gcc make -j32 mkdir -p /mnt/huge mount -t hugetlbfs nodev /mnt/huge echo 256 > /sys/devices/system/node/node0/hugepages/hugepages-2048kB/nr_hugepages modprobe uio_pci_generic python tools/dpdk_nic_bind.py -b uio_pci_generic 0000:04:00.0 ./build/app/testpmd -l 2,4 -- --total-num-mbufs=65536 -i --port-topology=chained --enable-rx-cksum --disable-hw-vlan-filter --disable-hw-vlan-strip set fwd rxonly set verbose 1 start # send packets to testpmd using scapy eh = Ether(src="00:01:02:03:04:05", dst="00:1B:21:AB:8F:10") p = Ether()/IP(src="1.1.1.1", dst="1.1.1.2")/UDP()/Raw("x"*50) sendp(p, iface="ixgbe2") p = Ether()/IP(src="1.1.1.1", dst="1.1.1.2", chksum=42)/UDP()/Raw("x"*50) sendp(p, iface="ixgbe2") p = Ether()/IP(src="1.1.1.1", dst="1.1.1.2")/UDP(chksum=42)/Raw("x"*50) sendp(p, iface="ixgbe2") p = Ether()/IP(src="1.1.1.1", dst="1.1.1.2", chksum=45)/UDP(chksum=42)/Raw("x"*50) sendp(p, iface="ixgbe2") # result port 0/queue 0: received 1 packets src=00:01:02:03:04:05 - dst=00:1B:21:AB:8F:10 - type=0x0800 - length=92 - nb_segs=1Unknown packet type - Receive queue=0x0 port 0/queue 0: received 1 packets src=00:01:02:03:04:05 - dst=00:1B:21:AB:8F:10 - type=0x0800 - length=92 - nb_segs=1Unknown packet type - Receive queue=0x0 PKT_RX_IP_CKSUM_BAD port 0/queue 0: received 1 packets src=00:01:02:03:04:05 - dst=00:1B:21:AB:8F:10 - type=0x0800 - length=92 - nb_segs=1Unknown packet type - Receive queue=0x0 PKT_RX_L4_CKSUM_BAD port 0/queue 0: received 1 packets src=00:01:02:03:04:05 - dst=00:1B:21:AB:8F:10 - type=0x0800 - length=92 - nb_segs=1Unknown packet type - Receive queue=0x0 PKT_RX_L4_CKSUM_BAD PKT_RX_IP_CKSUM_BAD Signed-off-by: Maxime Leroy <maxime.leroy@6wind.com> Signed-off-by: Olivier Matz <olivier.matz@6wind.com> Acked-by: Remy Horton <remy.horton@intel.com>
This commit is contained in:
parent
425781ff5a
commit
b4f3c136a1
@ -321,12 +321,8 @@ ixgbe_rx_vec_dev_conf_condition_check_default(struct rte_eth_dev *dev)
|
||||
if (fconf->mode != RTE_FDIR_MODE_NONE)
|
||||
return -1;
|
||||
|
||||
/*
|
||||
* - no csum error report support
|
||||
* - no header split support
|
||||
*/
|
||||
if (rxmode->hw_ip_checksum == 1 ||
|
||||
rxmode->header_split == 1)
|
||||
/* no header split support */
|
||||
if (rxmode->header_split == 1)
|
||||
return -1;
|
||||
|
||||
return 0;
|
||||
|
@ -556,5 +556,11 @@ ixgbe_txq_vec_setup(struct ixgbe_tx_queue *txq)
|
||||
int __attribute__((cold))
|
||||
ixgbe_rx_vec_dev_conf_condition_check(struct rte_eth_dev *dev)
|
||||
{
|
||||
struct rte_eth_rxmode *rxmode = &dev->data->dev_conf.rxmode;
|
||||
|
||||
/* no csum error report support */
|
||||
if (rxmode->hw_ip_checksum == 1)
|
||||
return -1;
|
||||
|
||||
return ixgbe_rx_vec_dev_conf_condition_check_default(dev);
|
||||
}
|
||||
|
@ -145,7 +145,7 @@ static inline void
|
||||
desc_to_olflags_v(__m128i descs[4], uint8_t vlan_flags,
|
||||
struct rte_mbuf **rx_pkts)
|
||||
{
|
||||
__m128i ptype0, ptype1, vtag0, vtag1;
|
||||
__m128i ptype0, ptype1, vtag0, vtag1, csum;
|
||||
union {
|
||||
uint16_t e[4];
|
||||
uint64_t dword;
|
||||
@ -162,18 +162,26 @@ desc_to_olflags_v(__m128i descs[4], uint8_t vlan_flags,
|
||||
PKT_RX_RSS_HASH, 0, PKT_RX_RSS_HASH, 0,
|
||||
PKT_RX_RSS_HASH, PKT_RX_RSS_HASH, PKT_RX_RSS_HASH, 0);
|
||||
|
||||
/* mask everything except vlan present bit */
|
||||
const __m128i vlan_msk = _mm_set_epi16(
|
||||
0x0000, 0x0000,
|
||||
0x0000, 0x0000,
|
||||
IXGBE_RXD_STAT_VP, IXGBE_RXD_STAT_VP,
|
||||
IXGBE_RXD_STAT_VP, IXGBE_RXD_STAT_VP);
|
||||
/* map vlan present (0x8) to ol_flags */
|
||||
const __m128i vlan_map = _mm_set_epi8(
|
||||
/* mask everything except vlan present and l4/ip csum error */
|
||||
const __m128i vlan_csum_msk = _mm_set_epi16(
|
||||
(IXGBE_RXDADV_ERR_TCPE | IXGBE_RXDADV_ERR_IPE) >> 16,
|
||||
(IXGBE_RXDADV_ERR_TCPE | IXGBE_RXDADV_ERR_IPE) >> 16,
|
||||
(IXGBE_RXDADV_ERR_TCPE | IXGBE_RXDADV_ERR_IPE) >> 16,
|
||||
(IXGBE_RXDADV_ERR_TCPE | IXGBE_RXDADV_ERR_IPE) >> 16,
|
||||
IXGBE_RXD_STAT_VP, IXGBE_RXD_STAT_VP,
|
||||
IXGBE_RXD_STAT_VP, IXGBE_RXD_STAT_VP);
|
||||
/* map vlan present (0x8), IPE (0x2), L4E (0x1) to ol_flags */
|
||||
const __m128i vlan_csum_map = _mm_set_epi8(
|
||||
0, 0, 0, 0,
|
||||
0, 0, 0, vlan_flags,
|
||||
vlan_flags | PKT_RX_IP_CKSUM_BAD | PKT_RX_L4_CKSUM_BAD,
|
||||
vlan_flags | PKT_RX_IP_CKSUM_BAD,
|
||||
vlan_flags | PKT_RX_L4_CKSUM_BAD,
|
||||
vlan_flags,
|
||||
0, 0, 0, 0,
|
||||
0, 0, 0, 0);
|
||||
PKT_RX_IP_CKSUM_BAD | PKT_RX_L4_CKSUM_BAD,
|
||||
PKT_RX_IP_CKSUM_BAD,
|
||||
PKT_RX_L4_CKSUM_BAD,
|
||||
0);
|
||||
|
||||
ptype0 = _mm_unpacklo_epi16(descs[0], descs[1]);
|
||||
ptype1 = _mm_unpacklo_epi16(descs[2], descs[3]);
|
||||
@ -185,8 +193,21 @@ desc_to_olflags_v(__m128i descs[4], uint8_t vlan_flags,
|
||||
ptype0 = _mm_shuffle_epi8(rss_flags, ptype0);
|
||||
|
||||
vtag1 = _mm_unpacklo_epi32(vtag0, vtag1);
|
||||
vtag1 = _mm_and_si128(vtag1, vlan_msk);
|
||||
vtag1 = _mm_shuffle_epi8(vlan_map, vtag1);
|
||||
vtag1 = _mm_and_si128(vtag1, vlan_csum_msk);
|
||||
|
||||
/* csum bits are in the most significant, to use shuffle we need to
|
||||
* shift them. Change mask to 0xc000 to 0x0003.
|
||||
*/
|
||||
csum = _mm_srli_epi16(vtag1, 14);
|
||||
|
||||
/* now or the most significant 64 bits containing the checksum
|
||||
* flags with the vlan present flags.
|
||||
*/
|
||||
csum = _mm_srli_si128(csum, 8);
|
||||
vtag1 = _mm_or_si128(csum, vtag1);
|
||||
|
||||
/* convert VP, IPE, L4E to ol_flags */
|
||||
vtag1 = _mm_shuffle_epi8(vlan_csum_map, vtag1);
|
||||
|
||||
vtag1 = _mm_or_si128(ptype0, vtag1);
|
||||
vol.dword = _mm_cvtsi128_si64(vtag1);
|
||||
@ -210,7 +231,6 @@ desc_to_olflags_v(__m128i descs[4], uint8_t vlan_flags,
|
||||
* - nb_pkts > RTE_IXGBE_MAX_RX_BURST, only scan RTE_IXGBE_MAX_RX_BURST
|
||||
* numbers of DD bit
|
||||
* - floor align nb_pkts to a RTE_IXGBE_DESC_PER_LOOP power-of-two
|
||||
* - don't support ol_flags for rss and csum err
|
||||
*/
|
||||
static inline uint16_t
|
||||
_recv_raw_pkts_vec(struct ixgbe_rx_queue *rxq, struct rte_mbuf **rx_pkts,
|
||||
@ -425,7 +445,6 @@ _recv_raw_pkts_vec(struct ixgbe_rx_queue *rxq, struct rte_mbuf **rx_pkts,
|
||||
* - nb_pkts > RTE_IXGBE_MAX_RX_BURST, only scan RTE_IXGBE_MAX_RX_BURST
|
||||
* numbers of DD bit
|
||||
* - floor align nb_pkts to a RTE_IXGBE_DESC_PER_LOOP power-of-two
|
||||
* - don't support ol_flags for rss and csum err
|
||||
*/
|
||||
uint16_t
|
||||
ixgbe_recv_pkts_vec(void *rx_queue, struct rte_mbuf **rx_pkts,
|
||||
@ -438,7 +457,6 @@ ixgbe_recv_pkts_vec(void *rx_queue, struct rte_mbuf **rx_pkts,
|
||||
* vPMD receive routine that reassembles scattered packets
|
||||
*
|
||||
* Notice:
|
||||
* - don't support ol_flags for rss and csum err
|
||||
* - nb_pkts < RTE_IXGBE_DESCS_PER_LOOP, just return no packet
|
||||
* - nb_pkts > RTE_IXGBE_MAX_RX_BURST, only scan RTE_IXGBE_MAX_RX_BURST
|
||||
* numbers of DD bit
|
||||
|
Loading…
Reference in New Issue
Block a user