From mboxrd@z Thu Jan 1 00:00:00 1970 Return-Path: Received: from mails.dpdk.org (mails.dpdk.org [217.70.189.124]) by inbox.dpdk.org (Postfix) with ESMTP id 8F97845E03; Mon, 2 Dec 2024 12:25:49 +0100 (CET) Received: from mails.dpdk.org (localhost [127.0.0.1]) by mails.dpdk.org (Postfix) with ESMTP id 619B540261; Mon, 2 Dec 2024 12:25:49 +0100 (CET) Received: from mgamail.intel.com (mgamail.intel.com [198.175.65.11]) by mails.dpdk.org (Postfix) with ESMTP id 36D2C4025E for ; Mon, 2 Dec 2024 12:25:46 +0100 (CET) DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/simple; d=intel.com; i=@intel.com; q=dns/txt; s=Intel; t=1733138748; x=1764674748; h=from:to:cc:subject:date:message-id:in-reply-to: references:mime-version:content-transfer-encoding; bh=1v7hFg8u03UOIwfhu5uqXLeyNVjlA7GxR4H8w8C3p1k=; b=jxehPBvFAPgsMXMdWkhgcduxoRCoiF96kQ6p1qE34TVJIYJe9xM6eDuc SLWEef0XXlhWgYLbTDcyhiaKiPAJwauroMio66aWsDG9X9UN6Kj7yOa0e xeiReS2ajFDA9kwdnjCpqknpWuIqNQJ5p9uBfBjjas33wblcqi9ZjYSf8 lFp8rWsSydJdewC51NJzjaRVdxokxGs3HFed8UXaTiCmoUAFyQtU9r54w vtbRGWiWAtS0wLRgAMbKufjd1ZBIi5mcPSQPR8JrJRk8f0iavddNXRMsL xNZ36IJzQaS3vktMzyCHMF3NNs2zjvEU54a31yoCGSg+Ie2OmFDAjP/2R w==; X-CSE-ConnectionGUID: NLhfBjUQRuap1N+y52ue4g== X-CSE-MsgGUID: MFAUrC1LRTia4I1Qktx9bQ== X-IronPort-AV: E=McAfee;i="6700,10204,11273"; a="43786141" X-IronPort-AV: E=Sophos;i="6.12,202,1728975600"; d="scan'208";a="43786141" Received: from orviesa005.jf.intel.com ([10.64.159.145]) by orvoesa103.jf.intel.com with ESMTP/TLS/ECDHE-RSA-AES256-GCM-SHA384; 02 Dec 2024 03:25:46 -0800 X-CSE-ConnectionGUID: rFyQF579QIidCHAQ30FBZA== X-CSE-MsgGUID: hyqqSckbTjOC+i1ZJpeWkQ== X-ExtLoop1: 1 X-IronPort-AV: E=Sophos;i="6.12,202,1728975600"; d="scan'208";a="98040186" Received: from silpixa00401197coob.ir.intel.com (HELO silpixa00401385.ir.intel.com) ([10.237.214.45]) by orviesa005.jf.intel.com with ESMTP; 02 Dec 2024 03:25:46 -0800 From: Bruce Richardson To: dev@dpdk.org Cc: Bruce Richardson Subject: [PATCH v1 00/21] Reduce code duplication across Intel NIC drivers Date: Mon, 2 Dec 2024 11:24:20 +0000 Message-ID: <20241202112444.1517416-1-bruce.richardson@intel.com> X-Mailer: git-send-email 2.43.0 In-Reply-To: <20241122125418.2857301-1-bruce.richardson@intel.com> References: <20241122125418.2857301-1-bruce.richardson@intel.com> MIME-Version: 1.0 Content-Transfer-Encoding: 8bit X-BeenThere: dev@dpdk.org X-Mailman-Version: 2.1.29 Precedence: list List-Id: DPDK patches and discussions List-Unsubscribe: , List-Archive: List-Post: List-Help: List-Subscribe: , Errors-To: dev-bounces@dpdk.org This RFC attempts to reduce the amount of code duplication across a number of Intel NIC drivers, specifically: ixgbe, i40e, iavf, and ice. The first patch extract a function from the Rx side, otherwise the majority of the changes are on the Tx side, leading to a converged Tx queue structure across the 4 drivers, and a large number of common functions. RFC->v1: * Moved the location of the common code from "common/intel_eth" to "net/_common_intel", and added only ".." to the driver include path so that the paths included "_common_intel" in them, to make it clear it's not driver-local headers. * Due to change in location, structure/fn prefix changes from "ieth" to "ci" for "common intel". * Removed the seeming-arbitrary split of vector and non-vector code - since much of the code taken from vector files was scalar code which was used by the vector drivers. * Split code into separate Rx and Tx files. * Fixed multiple checkpatch issues (but not all). * Attempted to improve name standardization, by using "_vec" as a common suffix for all vector-related fns and data. Previously, some names had "vec" in the middle, others had just "_v" suffix or full word "vector" as suffix. * Other minor changes... Bruce Richardson (21): net/_common_intel: add pkt reassembly fn for intel drivers net/_common_intel: provide common Tx entry structures net/_common_intel: add Tx mbuf ring replenish fn drivers/net: align Tx queue struct field names drivers/net: add prefix for driver-specific structs net/_common_intel: merge ice and i40e Tx queue struct net/iavf: use common Tx queue structure net/ixgbe: convert Tx queue context cache field to ptr net/ixgbe: use common Tx queue structure net/_common_intel: pack Tx queue structure net/_common_intel: add post-Tx buffer free function net/_common_intel: add Tx buffer free fn for AVX-512 net/iavf: use common Tx free fn for AVX-512 net/ice: move Tx queue mbuf cleanup fn to common net/i40e: use common Tx queue mbuf cleanup fn net/ixgbe: use common Tx queue mbuf cleanup fn net/iavf: use common Tx queue mbuf cleanup fn net/ice: use vector SW ring for all vector paths net/i40e: use vector SW ring for all vector paths net/iavf: use vector SW ring for all vector paths net/ixgbe: use common Tx backlog entry fn drivers/net/_common_intel/rx.h | 81 +++++ drivers/net/_common_intel/tx.h | 327 ++++++++++++++++++ drivers/net/i40e/i40e_ethdev.c | 4 +- drivers/net/i40e/i40e_ethdev.h | 8 +- drivers/net/i40e/i40e_fdir.c | 10 +- .../net/i40e/i40e_recycle_mbufs_vec_common.c | 6 +- drivers/net/i40e/i40e_rxtx.c | 193 ++++------- drivers/net/i40e/i40e_rxtx.h | 61 +--- drivers/net/i40e/i40e_rxtx_vec_altivec.c | 26 +- drivers/net/i40e/i40e_rxtx_vec_avx2.c | 26 +- drivers/net/i40e/i40e_rxtx_vec_avx512.c | 144 +------- drivers/net/i40e/i40e_rxtx_vec_common.h | 144 +------- drivers/net/i40e/i40e_rxtx_vec_neon.c | 26 +- drivers/net/i40e/i40e_rxtx_vec_sse.c | 26 +- drivers/net/i40e/meson.build | 2 +- drivers/net/iavf/iavf.h | 2 +- drivers/net/iavf/iavf_ethdev.c | 4 +- drivers/net/iavf/iavf_rxtx.c | 180 ++++------ drivers/net/iavf/iavf_rxtx.h | 61 +--- drivers/net/iavf/iavf_rxtx_vec_avx2.c | 47 +-- drivers/net/iavf/iavf_rxtx_vec_avx512.c | 214 ++---------- drivers/net/iavf/iavf_rxtx_vec_common.h | 160 +-------- drivers/net/iavf/iavf_rxtx_vec_sse.c | 57 ++- drivers/net/iavf/iavf_vchnl.c | 8 +- drivers/net/iavf/meson.build | 2 +- drivers/net/ice/ice_dcf.c | 4 +- drivers/net/ice/ice_dcf_ethdev.c | 21 +- drivers/net/ice/ice_diagnose.c | 2 +- drivers/net/ice/ice_ethdev.c | 2 +- drivers/net/ice/ice_ethdev.h | 7 +- drivers/net/ice/ice_rxtx.c | 164 ++++----- drivers/net/ice/ice_rxtx.h | 52 +-- drivers/net/ice/ice_rxtx_vec_avx2.c | 26 +- drivers/net/ice/ice_rxtx_vec_avx512.c | 153 +------- drivers/net/ice/ice_rxtx_vec_common.h | 190 +--------- drivers/net/ice/ice_rxtx_vec_sse.c | 30 +- drivers/net/ice/meson.build | 2 +- drivers/net/ixgbe/base/ixgbe_osdep.h | 2 +- drivers/net/ixgbe/ixgbe_ethdev.c | 4 +- .../ixgbe/ixgbe_recycle_mbufs_vec_common.c | 6 +- drivers/net/ixgbe/ixgbe_rxtx.c | 139 ++++---- drivers/net/ixgbe/ixgbe_rxtx.h | 73 +--- drivers/net/ixgbe/ixgbe_rxtx_vec_common.h | 129 +------ drivers/net/ixgbe/ixgbe_rxtx_vec_neon.c | 37 +- drivers/net/ixgbe/ixgbe_rxtx_vec_sse.c | 37 +- drivers/net/ixgbe/meson.build | 2 +- 46 files changed, 1014 insertions(+), 1887 deletions(-) create mode 100644 drivers/net/_common_intel/rx.h create mode 100644 drivers/net/_common_intel/tx.h -- 2.43.0