Received: by 2002:a05:6358:16cc:b0:ea:6187:17c9 with SMTP id r12csp6752613rwl; Mon, 9 Jan 2023 12:33:19 -0800 (PST) X-Google-Smtp-Source: AMrXdXtFAfgzkU/0I8G7Ioc2FvVy1UYabbeJoVH9G7Nh/tfabu6HcIacX/4ir6LAYa78Afu6ets9 X-Received: by 2002:a17:90a:b795:b0:227:199c:e66 with SMTP id m21-20020a17090ab79500b00227199c0e66mr3761135pjr.2.1673296399577; Mon, 09 Jan 2023 12:33:19 -0800 (PST) ARC-Seal: i=1; a=rsa-sha256; t=1673296399; cv=none; d=google.com; s=arc-20160816; b=L480yesebwSo0oPCAWE+T899oDltiH69al4FOcR9Ax/Pyf/dMbO/leshEknwWH3zn7 J2U640RzuopYunf/G3PEsKDjBzrAj33Ziicb7ktCNmIxUSzMhHpxebY2bUpdHiyj1bOJ dYq/EhSAoWZmgzyso0/s1uDYVd9QarO39arOJSwGDWz84hI8eParE4h9/QNV069+6hpn kWcmN9pTEylaBXTRGdUkhRsDsAv4H+RWXAwhX4RGwFtwQRUGz49HTfP/KhXEKLFA2qBw S4zJz3HLX6hWJsu+zhnjOJz75eHckzX10yYzRt4hmYsTpc+qNqRSwmMBZSgPkHlsGYjd 8UNg== ARC-Message-Signature: i=1; a=rsa-sha256; c=relaxed/relaxed; d=google.com; s=arc-20160816; h=list-id:precedence:mime-version:content-transfer-encoding :message-id:date:subject:cc:to:from:dkim-signature; bh=jUANk1sUBjvkcXo4F7E4VJUiJF91U0hygswuYCgVs9o=; b=fWGBELhVF/47whfKAHMHvLm9gsUM657guiOIssL+l8FuYDU6d81mMABZNLHOSsgmC7 voAP/w36E9bmo6mrl5JdCG6uBKjXxlkUdMfEQNdvkZUX3ku2itABPrIg2LbH5WeWqu4q Wg1KcLu1EOxsrjhbLmePJWb9pv4fvKZrOr+LHdRG47R5ezo1CDFupjM8A87Lg3fyO7IH 11bjl36Ynh5pHZivx6eq3SSiODUAKU7WfC/R8tYbgHytvk8UxIqL9AA6cj5v49Px6Pbg LtDZU0RkqZG8X/nUlNAsIGFk0TE2kRir3aGUpo/KByx1D2s0KSwh+ZRxeSo2CBiS/Tf5 Yc4w== ARC-Authentication-Results: i=1; mx.google.com; dkim=pass header.i=@ibm.com header.s=pp1 header.b=sjKuOj87; spf=pass (google.com: domain of linux-kernel-owner@vger.kernel.org designates 2620:137:e000::1:20 as permitted sender) smtp.mailfrom=linux-kernel-owner@vger.kernel.org; dmarc=pass (p=REJECT sp=NONE dis=NONE) header.from=ibm.com Return-Path: Received: from out1.vger.email (out1.vger.email. [2620:137:e000::1:20]) by mx.google.com with ESMTP id b10-20020a17090ae38a00b00219c6a4b550si12787506pjz.103.2023.01.09.12.33.12; Mon, 09 Jan 2023 12:33:19 -0800 (PST) Received-SPF: pass (google.com: domain of linux-kernel-owner@vger.kernel.org designates 2620:137:e000::1:20 as permitted sender) client-ip=2620:137:e000::1:20; Authentication-Results: mx.google.com; dkim=pass header.i=@ibm.com header.s=pp1 header.b=sjKuOj87; spf=pass (google.com: domain of linux-kernel-owner@vger.kernel.org designates 2620:137:e000::1:20 as permitted sender) smtp.mailfrom=linux-kernel-owner@vger.kernel.org; dmarc=pass (p=REJECT sp=NONE dis=NONE) header.from=ibm.com Received: (majordomo@vger.kernel.org) by vger.kernel.org via listexpand id S237558AbjAIULX (ORCPT + 53 others); Mon, 9 Jan 2023 15:11:23 -0500 Received: from lindbergh.monkeyblade.net ([23.128.96.19]:35130 "EHLO lindbergh.monkeyblade.net" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S237554AbjAIUKz (ORCPT ); Mon, 9 Jan 2023 15:10:55 -0500 Received: from mx0a-001b2d01.pphosted.com (mx0b-001b2d01.pphosted.com [148.163.158.5]) by lindbergh.monkeyblade.net (Postfix) with ESMTPS id 72CA7E6E; Mon, 9 Jan 2023 12:10:51 -0800 (PST) Received: from pps.filterd (m0098420.ppops.net [127.0.0.1]) by mx0b-001b2d01.pphosted.com (8.17.1.19/8.17.1.19) with ESMTP id 309I2Gbh015694; Mon, 9 Jan 2023 20:10:45 GMT DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/relaxed; d=ibm.com; h=from : to : cc : subject : date : message-id : content-transfer-encoding : mime-version; s=pp1; bh=jUANk1sUBjvkcXo4F7E4VJUiJF91U0hygswuYCgVs9o=; b=sjKuOj87quOPL4x97JCGT0n6j4OvaKo9JgreUK02MoRAF4ooP8XDOXxMSsOU4j1aBLge H/JeaMEy9Jufyw59x6j1vtNdHmprb3dR1f2iy1dE588DAp1czBd5WWFebNm48YAt1VQh +4sGzPZrhi9tkl6QBJ3z/+D6I+Wcu7X+0AsSH5St09nihBdjwC/08+5OyKoEa7PyryX4 KWTqu/FfuVI1k/7546M3PKoYlxUEsKOEvPZQJUCstUTWOGA6AC1aPyl1J4AQmNC4Rl97 vt/tWyy3Lq4C17Qz/laPsT1QXR5n0ooiz/WMJF550w7/OzUScdg/TwFPZYMfAp9n4jfT GA== Received: from pps.reinject (localhost [127.0.0.1]) by mx0b-001b2d01.pphosted.com (PPS) with ESMTPS id 3myjp27s2j-1 (version=TLSv1.2 cipher=ECDHE-RSA-AES256-GCM-SHA384 bits=256 verify=NOT); Mon, 09 Jan 2023 20:10:44 +0000 Received: from m0098420.ppops.net (m0098420.ppops.net [127.0.0.1]) by pps.reinject (8.17.1.5/8.17.1.5) with ESMTP id 309K7u9K003676; Mon, 9 Jan 2023 20:10:44 GMT Received: from ppma01dal.us.ibm.com (83.d6.3fa9.ip4.static.sl-reverse.com [169.63.214.131]) by mx0b-001b2d01.pphosted.com (PPS) with ESMTPS id 3myjp27s1k-1 (version=TLSv1.2 cipher=ECDHE-RSA-AES256-GCM-SHA384 bits=256 verify=NOT); Mon, 09 Jan 2023 20:10:44 +0000 Received: from pps.filterd (ppma01dal.us.ibm.com [127.0.0.1]) by ppma01dal.us.ibm.com (8.17.1.19/8.17.1.19) with ESMTP id 309JF8Ep021950; Mon, 9 Jan 2023 20:10:42 GMT Received: from smtprelay04.wdc07v.mail.ibm.com ([9.208.129.114]) by ppma01dal.us.ibm.com (PPS) with ESMTPS id 3my0c7s311-1 (version=TLSv1.2 cipher=ECDHE-RSA-AES256-GCM-SHA384 bits=256 verify=NOT); Mon, 09 Jan 2023 20:10:42 +0000 Received: from smtpav06.wdc07v.mail.ibm.com (smtpav06.wdc07v.mail.ibm.com [10.39.53.233]) by smtprelay04.wdc07v.mail.ibm.com (8.14.9/8.14.9/NCO v10.0) with ESMTP id 309KAfb624773194 (version=TLSv1/SSLv3 cipher=DHE-RSA-AES256-GCM-SHA384 bits=256 verify=OK); Mon, 9 Jan 2023 20:10:41 GMT Received: from smtpav06.wdc07v.mail.ibm.com (unknown [127.0.0.1]) by IMSVA (Postfix) with ESMTP id EC6575803F; Mon, 9 Jan 2023 20:10:40 +0000 (GMT) Received: from smtpav06.wdc07v.mail.ibm.com (unknown [127.0.0.1]) by IMSVA (Postfix) with ESMTP id A465D5804E; Mon, 9 Jan 2023 20:10:38 +0000 (GMT) Received: from li-2311da4c-2e09-11b2-a85c-c003041e9174.ibm.com.com (unknown [9.65.251.44]) by smtpav06.wdc07v.mail.ibm.com (Postfix) with ESMTP; Mon, 9 Jan 2023 20:10:38 +0000 (GMT) From: Matthew Rosato To: alex.williamson@redhat.com, pbonzini@redhat.com Cc: jgg@nvidia.com, cohuck@redhat.com, farman@linux.ibm.com, pmorel@linux.ibm.com, borntraeger@linux.ibm.com, frankja@linux.ibm.com, imbrenda@linux.ibm.com, david@redhat.com, akrowiak@linux.ibm.com, jjherne@linux.ibm.com, pasic@linux.ibm.com, zhenyuw@linux.intel.com, zhi.a.wang@intel.com, linux-s390@vger.kernel.org, kvm@vger.kernel.org, intel-gvt-dev@lists.freedesktop.org, intel-gfx@lists.freedesktop.org, linux-kernel@vger.kernel.org Subject: [PATCH 0/2] kvm/vfio: fix potential deadlock on vfio group lock Date: Mon, 9 Jan 2023 15:10:35 -0500 Message-Id: <20230109201037.33051-1-mjrosato@linux.ibm.com> X-Mailer: git-send-email 2.39.0 X-TM-AS-GCONF: 00 X-Proofpoint-ORIG-GUID: HM6h6j1tRZm-o5imo2ah2XQ9Uc1zdcw7 X-Proofpoint-GUID: Lr2MBWKHuVuEHQcxXlJ8qPbazXOLOLZN Content-Transfer-Encoding: 8bit X-Proofpoint-UnRewURL: 0 URL was un-rewritten MIME-Version: 1.0 X-Proofpoint-Virus-Version: vendor=baseguard engine=ICAP:2.0.205,Aquarius:18.0.923,Hydra:6.0.545,FMLib:17.11.122.1 definitions=2023-01-09_13,2023-01-09_02,2022-06-22_01 X-Proofpoint-Spam-Details: rule=outbound_notspam policy=outbound score=0 malwarescore=0 mlxlogscore=999 impostorscore=0 bulkscore=0 clxscore=1015 suspectscore=0 phishscore=0 spamscore=0 mlxscore=0 adultscore=0 priorityscore=1501 lowpriorityscore=0 classifier=spam adjust=0 reason=mlx scancount=1 engine=8.12.0-2212070000 definitions=main-2301090141 X-Spam-Status: No, score=-2.0 required=5.0 tests=BAYES_00,DKIM_SIGNED, DKIM_VALID,DKIM_VALID_EF,RCVD_IN_MSPIKE_H2,SPF_HELO_NONE,SPF_PASS autolearn=ham autolearn_force=no version=3.4.6 X-Spam-Checker-Version: SpamAssassin 3.4.6 (2021-04-09) on lindbergh.monkeyblade.net Precedence: bulk List-ID: X-Mailing-List: linux-kernel@vger.kernel.org Hi Alex, Paolo, As reported by Alex [1], since commit 421cfe6596f6 it is possible for a kvm_put_kvm call to hit a refcount of 0 and trigger kvm_destroy_vm while the vfio group lock is held. However, if this occurs, and the associated group is still in the kvm device list, this thread of execution will attempt to acquire the vfio group lock again, resulting in a deadlock. This series proposes to resolve this by adding a new kvm_put_kvm_async which behaves the same as kvm_put_kvm but, in the case where the refcount hits 0, will use a workqueue to perform the kvm_destroy_vm asynchronously. The fix is provided in 2 patches because s390 PCI passthrough has the same issue, albeit introduced slightly later via a different commit. [1]: https://lore.kernel.org/kvm/20230105150930.6ee65182.alex.williamson@redhat.com/ Matthew Rosato (2): KVM: async kvm_destroy_vm for vfio devices KVM: s390: pci: use asyncronous kvm put arch/s390/kvm/pci.c | 8 ++++++-- drivers/gpu/drm/i915/gvt/kvmgt.c | 6 +++++- drivers/s390/crypto/vfio_ap_ops.c | 7 ++++++- include/linux/kvm_host.h | 3 +++ virt/kvm/kvm_main.c | 22 ++++++++++++++++++++++ 5 files changed, 42 insertions(+), 4 deletions(-) -- 2.39.0