X-Git-Url: http://git.droids-corp.org/?a=blobdiff_plain;f=drivers%2Fnet%2Fiavf%2Fiavf_hash.c;h=2b03dad8589c0e5d395b32aec8debbbecc7b0a33;hb=c2a42d19d967e24223f06f2fc797eaed8e17c345;hp=03dae5d9995ce691c22e2b68ab7e943fe55e5e12;hpb=36c2b46fed3bb274b52af2a4224b9101bf83b959;p=dpdk.git diff --git a/drivers/net/iavf/iavf_hash.c b/drivers/net/iavf/iavf_hash.c index 03dae5d999..2b03dad858 100644 --- a/drivers/net/iavf/iavf_hash.c +++ b/drivers/net/iavf/iavf_hash.c @@ -623,6 +623,38 @@ iavf_rss_hash_set(struct iavf_adapter *ad, uint64_t rss_hf, bool add) iavf_add_del_rss_cfg(ad, &rss_cfg, add); } + if (rss_hf & ETH_RSS_FRAG_IPV4) { + struct virtchnl_proto_hdrs hdr = { + .tunnel_level = TUNNEL_LEVEL_OUTER, + .count = 3, + .proto_hdr = { + proto_hdr_eth, + proto_hdr_ipv4, + { + VIRTCHNL_PROTO_HDR_IPV4_FRAG, + FIELD_SELECTOR(VIRTCHNL_PROTO_HDR_IPV4_FRAG_PKID), + {BUFF_NOUSED}, + }, + }, + }; + rss_cfg.proto_hdrs = hdr; + iavf_add_del_rss_cfg(ad, &rss_cfg, add); + } + + if (rss_hf & ETH_RSS_FRAG_IPV6) { + struct virtchnl_proto_hdrs hdr = { + .tunnel_level = TUNNEL_LEVEL_OUTER, + .count = 3, + .proto_hdr = { + proto_hdr_eth, + proto_hdr_ipv6, + proto_hdr_ipv6_frag, + }, + }; + rss_cfg.proto_hdrs = hdr; + iavf_add_del_rss_cfg(ad, &rss_cfg, add); + } + vf->rss_hf = rss_hf & IAVF_RSS_HF_ALL; return 0; }