From mboxrd@z Thu Jan 1 00:00:00 1970 Return-Path: Received: from mga04.intel.com (mga04.intel.com [192.55.52.120]) by dpdk.org (Postfix) with ESMTP id 23FBF1B339 for ; Fri, 22 Dec 2017 08:21:43 +0100 (CET) X-Amp-Result: SKIPPED(no attachment in message) X-Amp-File-Uploaded: False Received: from orsmga006.jf.intel.com ([10.7.209.51]) by fmsmga104.fm.intel.com with ESMTP/TLS/DHE-RSA-AES256-GCM-SHA384; 21 Dec 2017 23:21:42 -0800 X-ExtLoop1: 1 X-IronPort-AV: E=Sophos;i="5.45,439,1508828400"; d="scan'208";a="4875841" Received: from dpdk15.sh.intel.com ([10.67.111.77]) by orsmga006.jf.intel.com with ESMTP; 21 Dec 2017 23:21:40 -0800 From: Jiayu Hu To: dev@dpdk.org Cc: jianfeng.tan@intel.com, junjie.j.chen@intel.com, konstantin.ananyev@intel.com, stephen@networkplumber.org, ferruh.yigit@intel.com, lei.a.yao@intel.com, Jiayu Hu Date: Fri, 22 Dec 2017 15:25:42 +0800 Message-Id: <1513927544-97241-1-git-send-email-jiayu.hu@intel.com> X-Mailer: git-send-email 2.7.4 In-Reply-To: <1513219779-100115-1-git-send-email-jiayu.hu@intel.com> References: <1513219779-100115-1-git-send-email-jiayu.hu@intel.com> Subject: [dpdk-dev] [PATCH v3 0/2] Support VxLAN GRO X-BeenThere: dev@dpdk.org X-Mailman-Version: 2.1.15 Precedence: list List-Id: DPDK patches and discussions List-Unsubscribe: , List-Archive: List-Post: List-Help: List-Subscribe: , X-List-Received-Date: Fri, 22 Dec 2017 07:21:44 -0000 VxLAN is one of the most widely used tunneled protocols. Providing GRO support for VxLAN-encapsulated packets can benefit many per-packet based applications, like Open vSwitch. This patchset is to support VxLAN GRO. The first patch cleans up current gro codes for the sake of supporting tunneled GRO. The second patch supports GRO on the VxLAN packets which have an outer IPv4 header and an inner TCP/IPv4 packet. Change log =========== v3: - remove needless check - add "likely()" and "unlikely()" to optimize branch prediction - fix a bug in merge_two_tcp4_packets(): for VxLAN packets, check if the outer IPv4 packet length is less than or equal to UINT16_MAX, rather than the inner IPv4 packet length. - fix a bug in rte_gro.h: change RTE_GRO_TYPE_SUPPORT_NUM to 2 - Avoid inserting timestamp in rte_gro_reassemble_burst(), since all packets in the tables will be flushed. - fix typos v2: - comply RFC 6848 to process IP ID fields. Specifically, we require the IP ID fields of neighbor packets whose DF bit is 0 to be increased by 1. We don't check IP ID for the packets whose DF bit is 1. Additionally, packets whose DF bits are different cannot be merged. - update the programmer guide and function comments Jiayu Hu (2): gro: code cleanup gro: support VxLAN GRO .../prog_guide/generic_receive_offload_lib.rst | 269 ++++++----- doc/guides/prog_guide/img/gro-key-algorithm.png | Bin 0 -> 28231 bytes lib/librte_gro/Makefile | 1 + lib/librte_gro/gro_tcp4.c | 330 +++++-------- lib/librte_gro/gro_tcp4.h | 253 +++++++--- lib/librte_gro/gro_vxlan_tcp4.c | 515 +++++++++++++++++++++ lib/librte_gro/gro_vxlan_tcp4.h | 184 ++++++++ lib/librte_gro/rte_gro.c | 199 +++++--- lib/librte_gro/rte_gro.h | 97 ++-- 9 files changed, 1337 insertions(+), 511 deletions(-) create mode 100644 doc/guides/prog_guide/img/gro-key-algorithm.png create mode 100644 lib/librte_gro/gro_vxlan_tcp4.c create mode 100644 lib/librte_gro/gro_vxlan_tcp4.h -- 2.7.4