From patchwork Tue Jun 25 09:31:49 2024 Content-Type: text/plain; charset="utf-8" MIME-Version: 1.0 Content-Transfer-Encoding: 8bit X-Patchwork-Submitter: Xinxin Zhao <15957197901@163.com> X-Patchwork-Id: 141596 X-Patchwork-Delegate: maxime.coquelin@redhat.com Return-Path: X-Original-To: patchwork@inbox.dpdk.org Delivered-To: patchwork@inbox.dpdk.org Received: from mails.dpdk.org (mails.dpdk.org [217.70.189.124]) by inbox.dpdk.org (Postfix) with ESMTP id AA669454EF; Tue, 25 Jun 2024 11:53:09 +0200 (CEST) Received: from mails.dpdk.org (localhost [127.0.0.1]) by mails.dpdk.org (Postfix) with ESMTP id 9854940BA2; Tue, 25 Jun 2024 11:53:09 +0200 (CEST) Received: from m16.mail.163.com (m16.mail.163.com [117.135.210.3]) by mails.dpdk.org (Postfix) with ESMTP id 0D1B940696; Tue, 25 Jun 2024 11:31:57 +0200 (CEST) DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/relaxed; d=163.com; s=s110527; h=From:Subject:Date:Message-ID:MIME-Version: Content-Type; bh=9fiUYGGBDVMP9YI/GgHq69ir3BgyAUvTkzEkYZ/yBxA=; b=O/c5X6Me2V5VkS+qlLb4zZnWUPOA+A+9EtFk+/zPcCZIYOvy0PtpMmSX6y6LZW eqV3AkcnYl6AW/fdJaDjj6xjBdbj3CyfF6AxsqBVpNZAhwsnZx9GAYTYXjVvMmFc /jmIpBnzkW/7KZyUQnqJF9cn9T0XQsXqSKWofdcSKAwOI= Received: from localhost.localdomain (unknown [115.199.195.158]) by gzga-smtp-mta-g3-0 (Coremail) with SMTP id _____wDXPzaHjnpmzuGlAQ--.50859S2; Tue, 25 Jun 2024 17:31:52 +0800 (CST) From: Xinxin Zhao <15957197901@163.com> To: dev@dpdk.org Cc: Xinxin Zhao <15957197901@163.com>, stable@dpdk.org Subject: [PATCH] vhost: Fix the crash caused by accessing the released memory Date: Tue, 25 Jun 2024 17:31:49 +0800 Message-ID: <20240625093149.63247-1-15957197901@163.com> X-Mailer: git-send-email 2.45.2 MIME-Version: 1.0 X-CM-TRANSID: _____wDXPzaHjnpmzuGlAQ--.50859S2 X-Coremail-Antispam: 1Uf129KBjvJXoW7uF15tr4UGFW3tr43GrWDXFb_yoW8WryDpF W8Za43Gr97tFnYq39xAa1UKa48u3WkCw17W34xG3W5Wrs8Gr4Yqa9rK3ZY9r17AFW8JFyU XF12gr4S9FWUC3DanT9S1TB71UUUUU7qnTZGkaVYY2UrUUUUjbIjqfuFe4nvWSU5nxnvy2 9KBjDUYxBIdaVFxhVjvjDU0xZFpf9x0pRAb1bUUUUU= X-Originating-IP: [115.199.195.158] X-CM-SenderInfo: zprvmkyxrzlmmqrbiqqrwthudrp/xtbBcgoJxGWXv0R7qwAAss X-Mailman-Approved-At: Tue, 25 Jun 2024 11:52:38 +0200 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 The rte_vhost_driver_unregister() vhost_user_read_cb() vhost_user_client_reconnect() can be called at the same time by 3 threads. when memory of vsocket is freed in rte_vhost_driver_unregister(), then vhost_user_read_cb() maybe add vsocket to reconn_list, the invalid memory of vsocket is accessed in vhost_user_client_reconnect(). It's a bug for vhost as client. E.g., vhostuser port is created as client. Thread 1 calls rte_vhost_driver_unregister() to remove the vsocket of reconn from the reconn list. Then “vhost-events” thread calls vhost_user_read_cb() to add the vsocket of reconn back to the reconn list. At this time, after thread 1 releases the vsocket memory, the socket of vhostuser reconnects successfully, "vhost_reconn" thread will access the released memory. The core trace is: Program terminated with signal 11, Segmentation fault. The fix is to perform a delete operation again after releasing the memory Fixes: 451dc0f ("vhost: fix crash on port deletion") Cc: stable@dpdk.org Signed-off-by: Xinxin Zhao <15957197901@163.com> --- lib/vhost/socket.c | 2 ++ 1 file changed, 2 insertions(+) diff --git a/lib/vhost/socket.c b/lib/vhost/socket.c index a75728a2e4..01946096c4 100644 --- a/lib/vhost/socket.c +++ b/lib/vhost/socket.c @@ -1121,6 +1121,8 @@ rte_vhost_driver_unregister(const char *path) if (vsocket->is_server) { close(vsocket->socket_fd); unlink(path); + } else if (vsocket->reconnect) { + vhost_user_remove_reconnect(vsocket); } pthread_mutex_destroy(&vsocket->conn_mutex);