From mboxrd@z Thu Jan 1 00:00:00 1970 Return-Path: Received: from mails.dpdk.org (xvm-189-124.dc0.ghst.net [217.70.189.124]) by inbox.dpdk.org (Postfix) with ESMTP id 46C0AA09FF; Thu, 7 Jan 2021 09:41:06 +0100 (CET) Received: from [217.70.189.124] (localhost [127.0.0.1]) by mails.dpdk.org (Postfix) with ESMTP id 3571D140EF4; Thu, 7 Jan 2021 09:41:06 +0100 (CET) Received: from mga04.intel.com (mga04.intel.com [192.55.52.120]) by mails.dpdk.org (Postfix) with ESMTP id 16343140EEA for ; Thu, 7 Jan 2021 09:41:03 +0100 (CET) IronPort-SDR: Q02jz/knSZNPDup5j+Or3D2w7ot87ZtP1U1hQXD+JVtCYAT4ldK+69ZRbm5Lp8esblZWJm1k68 U1Cc0RnmRmCA== X-IronPort-AV: E=McAfee;i="6000,8403,9856"; a="174819142" X-IronPort-AV: E=Sophos;i="5.79,329,1602572400"; d="scan'208";a="174819142" Received: from orsmga003.jf.intel.com ([10.7.209.27]) by fmsmga104.fm.intel.com with ESMTP/TLS/ECDHE-RSA-AES256-GCM-SHA384; 07 Jan 2021 00:41:03 -0800 IronPort-SDR: 2w8gCPspo7W6oOzNYpwMRpnc9X6SI6eLzj27DWMBsN1nFocHLcTwsIp/GnObL08y+kSu5eNYg8 3azig94xsscw== X-ExtLoop1: 1 X-IronPort-AV: E=Sophos;i="5.79,329,1602572400"; d="scan'208";a="346928831" Received: from dpdk-wujingji.sh.intel.com ([10.67.119.101]) by orsmga003.jf.intel.com with ESMTP; 07 Jan 2021 00:41:00 -0800 From: Jingjing Wu To: dev@dpdk.org Cc: jingjing.wu@intel.com, beilei.xing@intel.com, chenbo.xia@intel.com, xiuchun.lu@intel.com Date: Thu, 7 Jan 2021 16:27:13 +0800 Message-Id: <20210107082718.33748-1-jingjing.wu@intel.com> X-Mailer: git-send-email 2.21.1 In-Reply-To: <20210107074533.15465-1-jingjing.wu@intel.com> References: <20210107074533.15465-1-jingjing.wu@intel.com> MIME-Version: 1.0 Content-Type: text/plain; charset=UTF-8 Content-Transfer-Encoding: 8bit Subject: [dpdk-dev] [PATCH v3 0/5] introduce new iavf driver on vfio-user client 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 Sender: "dev" This series introduces a new net virtual device called iavf_client which is based on vfio-user client interface. Through vfio-user client interface, PCI liked device could be used similar as IntelĀ® Ethernet Adaptive Virtual Function specification. The code to enable iavf_client mainly contains two parts: - Emulated pci interfaces for vfio-user client which is located in common/iavf/vfio_user/. - A new net driver base on vdev abstraction, i.e. iavf_client_ethdev.c ---------------------- | ------------------ | | | iavf driver | |----> (iavf_client_ethdev.c) | ------------------ | | ------------------ | | | device emulate | |------>(common/iavf/vfio_user/) | ------------------ | ---------------------- | | ---------------------- | vfio-user | | client | ---------------------- This driver can be used to test the device emulation framework mentioned in: [RFC 0/2] Add device emulation support in DPDK http://patchwork.dpdk.org/cover/75549/ +------------------------------------------------------+ | +---------------+ +---------------+ | | | iavf_emudev | | iavfbe_ethdev | | | | driver | | driver | | | +---------------+ +---------------+ | | | | | | ------------------------------------------- VDEV BUS | | | | | | +---------------+ +--------------+ | +--------------+ | | vdev: | | vdev: | | | +----------+ | | | /path/to/vfio | |iavf_emudev_# | | | | iavf | | | +---------------+ +--------------+ | | | client | | | | | +----------+ | | | | | +----------+ | | +----------+ | | | vfio-user| | | | vfio-user| | | | client | |<---|----->| server | | | +----------+ | | +----------+ | | QEMU/DPDK | | DPDK | +--------------+ +------------------------------------------------------+ It can be launched together with patch series for the testing: [0/9] Introduce vfio-user library: http://patchwork.dpdk.org/cover/85389/ [0/8] Introduce emudev library and iavf emudev driver http://patchwork.dpdk.org/cover/85488/ [0/6] Introduce iavf backend driver http://patchwork.dpdk.org/cover/86084/ This series depends on patch serieses: [0/9] Introduce vfio-user library: http://patchwork.dpdk.org/cover/85389/ v3: - Reword commit log - Add missed patch in v2 v2: - Enable interrupt for control queue - Enable interrupt for rx queue - Rename some Macros - Fix resource release when close - Fix ptype_tbl assignment - Fix typo Jingjing Wu (5): common/iavf: emulated pci interfaces on vfio-user client net/iavf_client: introduce iavf driver on vfio-user client net/iavf_client: enable interrupt on control queue net/iavf_client: enable interrupt of Rx queue net/iavf: fix vector mapping with queue config/rte_config.h | 3 + drivers/common/iavf/iavf_common.c | 7 + drivers/common/iavf/iavf_impl.c | 45 +- drivers/common/iavf/iavf_osdep.h | 14 + drivers/common/iavf/iavf_prototype.h | 1 + drivers/common/iavf/iavf_type.h | 3 + drivers/common/iavf/meson.build | 11 +- drivers/common/iavf/version.map | 6 + drivers/common/iavf/vfio_user/vfio_user_pci.c | 525 ++++++++++++++++++ drivers/common/iavf/vfio_user/vfio_user_pci.h | 68 +++ drivers/net/iavf/iavf.h | 37 +- drivers/net/iavf/iavf_client_ethdev.c | 404 ++++++++++++++ drivers/net/iavf/iavf_ethdev.c | 57 +- drivers/net/iavf/iavf_rxtx.c | 23 +- drivers/net/iavf/meson.build | 1 + 15 files changed, 1157 insertions(+), 48 deletions(-) create mode 100644 drivers/common/iavf/vfio_user/vfio_user_pci.c create mode 100644 drivers/common/iavf/vfio_user/vfio_user_pci.h create mode 100644 drivers/net/iavf/iavf_client_ethdev.c -- 2.21.1