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 702CBA0543; Tue, 25 Oct 2022 08:08:54 +0200 (CEST) Received: from [217.70.189.124] (localhost [127.0.0.1]) by mails.dpdk.org (Postfix) with ESMTP id 591DF42B6C; Tue, 25 Oct 2022 08:08:54 +0200 (CEST) Received: from out28-125.mail.aliyun.com (out28-125.mail.aliyun.com [115.124.28.125]) by mails.dpdk.org (Postfix) with ESMTP id B1F4B410FB for ; Tue, 25 Oct 2022 08:08:52 +0200 (CEST) X-Alimail-AntiSpam: AC=CONTINUE; BC=0.07531285|-1; CH=green; DM=|CONTINUE|false|; DS=CONTINUE|ham_system_inform|0.00032349-8.69311e-06-0.999668; FP=0|0|0|0|0|-1|-1|-1; HT=ay29a033018047208; MF=chenh@yusur.tech; NM=1; PH=DS; RN=4; RT=4; SR=0; TI=SMTPD_---.PpPORCq_1666678129; Received: from localhost.localdomain(mailfrom:chenh@yusur.tech fp:SMTPD_---.PpPORCq_1666678129) by smtp.aliyun-inc.com; Tue, 25 Oct 2022 14:08:49 +0800 From: Hao Chen To: dev@dpdk.org Cc: zy@yusur.tech, Maxime Coquelin , Chenbo Xia Subject: [PATCH v2] example: vdpa: support run in nested virtualization environment Date: Tue, 25 Oct 2022 02:08:48 -0400 Message-Id: <20221025060848.3227766-1-chenh@yusur.tech> X-Mailer: git-send-email 2.27.0 In-Reply-To: <20221011025531.887043-1-chenh@yusur.tech> References: <20221011025531.887043-1-chenh@yusur.tech> 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 When we run dpdk vdpa in the nested virtual machine vm-L1 and ping test in vm-L2, the ping is NG. The reason for troubleshooting is that the virtio net in vm-L2 sends control information to the vring, and the qemu back-end device in vm-L1 cannot obtain correct data from the vring. This problem is related to the opening of the vIOMMU. This patch add option '--iommu-support' to use guest vIOMMU to protect vhost, then the ping test in vm-L2 is OK. This option is required in a nested virtualization environment. Signed-off-by: Hao Chen --- v2: *fprintf all string including the eal one. *remove exit(1). examples/vdpa/main.c | 17 ++++++++++++----- 1 file changed, 12 insertions(+), 5 deletions(-) diff --git a/examples/vdpa/main.c b/examples/vdpa/main.c index 4c7e81d7b6..71149461c6 100644 --- a/examples/vdpa/main.c +++ b/examples/vdpa/main.c @@ -43,16 +43,18 @@ static char iface[MAX_PATH_LEN]; static int devcnt; static int interactive; static int client_mode; +static int iommu_support; /* display usage */ static void vdpa_usage(const char *prgname) { - printf("Usage: %s [EAL options] -- " - " --interactive|-i: run in interactive mode.\n" - " --iface : specify the path prefix of the socket files, e.g. /tmp/vhost-user-.\n" - " --client: register a vhost-user socket as client mode.\n", - prgname); + const char *usage_str = " --interactive|-i: run in interactive mode.\n" + " --iface : specify the path prefix of the socket files, e.g. /tmp/vhost-user-.\n" + " --client: register a vhost-user socket as client mode.\n" + " --iommu-support: use guest vIOMMU to protect vhost.\n"; + + fprintf(stderr, "Usage: %s [EAL options] --\n%s", prgname, usage_str); } static int @@ -63,6 +65,7 @@ parse_args(int argc, char **argv) {"iface", required_argument, NULL, 0}, {"interactive", no_argument, &interactive, 1}, {"client", no_argument, &client_mode, 1}, + {"iommu-support", no_argument, &iommu_support, 1}, {NULL, 0, 0, 0}, }; int opt, idx; @@ -220,6 +223,10 @@ start_vdpa(struct vdpa_port *vport) socket_path); return -1; } + + if (iommu_support) + vport->flags |= RTE_VHOST_USER_IOMMU_SUPPORT; + ret = rte_vhost_driver_register(socket_path, vport->flags); if (ret != 0) rte_exit(EXIT_FAILURE, -- 2.27.0