Received: by 2002:a6b:fb09:0:0:0:0:0 with SMTP id h9csp581354iog; Mon, 13 Jun 2022 08:32:30 -0700 (PDT) X-Google-Smtp-Source: AGRyM1voPpsbYjD5MBfmHO1vtZirVh3D8HvwOQX2DiJWNKGQ3jnSFtb/318ry2RflvNHrrg29qa0 X-Received: by 2002:a17:907:86ac:b0:708:9c4a:c6e9 with SMTP id qa44-20020a17090786ac00b007089c4ac6e9mr356132ejc.297.1655134350750; Mon, 13 Jun 2022 08:32:30 -0700 (PDT) ARC-Seal: i=1; a=rsa-sha256; t=1655134350; cv=none; d=google.com; s=arc-20160816; b=A8p1IvwkjSwAHyZ6+T5OHDueTaX7xsKeVgd7LZG1f7SbL9oUSmuCkmlVqC99EpQf+9 dWGEPLhbOvgzlybw7/Jg7QMis1noR8EZik79Muh6JuUR83g7AU/6YTvTRggQPDPuLji5 pdaOqoUJQEfALtIK0Kx5WBk7kL9bfbFtACcaGzzrO21hLbAF0T9/ergRRaOaGDwxKbas EarGRijvNorhgnUQcZ9UW+gm3+n6gPO5WrAzlc9Au7nqxJo0s0j9fJxdKWIsqmDlunv0 61zIolGSMLUkNBLSLPTsfa+XLzfG5P7C/GxDoYOkKbsVIMSM17eO+cBHlLS457twdRku /Uig== ARC-Message-Signature: i=1; a=rsa-sha256; c=relaxed/relaxed; d=google.com; s=arc-20160816; h=list-id:precedence:content-transfer-encoding:mime-version :user-agent:references:in-reply-to:message-id:date:subject:cc:to :from:dkim-signature; bh=Zu1tx46BGnZQ6DiaDSuUm+b3XbDesBctVi0zuDOHgsE=; b=zzVBVoarGHufgw0iijuw2o35VjMut4VaqtijXFHqKt+Z7WQs1QbOhjT47c+KJI/Lrx DJYIsGScq/k22pEXNqd02zeFqWHouEK3J/xPPqyohk9kYgWrtDygnLzX4lz8Rdyz5tzl /BI7sljxvQS+Xxswdjc2XzNOEkSQ1TYlbw6ySV4t186FnpoBhADb7OiATTTejTSkyBkh 1FGcNosLRJCUsNyLDpRftk5ZJpasMOUQal/atvAInBclIKt4V1AtruTRbWixqDBa0041 MdxKhh6RQABhxmfeCg5BIfCUSZd202A/987TusgPFru1D0wRDamGBCGOvTK37p1yZZsZ 1CnA== ARC-Authentication-Results: i=1; mx.google.com; dkim=pass header.i=@linuxfoundation.org header.s=korg header.b=LXn9y9FK; 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=NONE sp=NONE dis=NONE) header.from=linuxfoundation.org Return-Path: Received: from out1.vger.email (out1.vger.email. [2620:137:e000::1:20]) by mx.google.com with ESMTP id h10-20020a0564020e8a00b00434fe8aaf55si1059140eda.434.2022.06.13.08.32.05; Mon, 13 Jun 2022 08:32:30 -0700 (PDT) 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=@linuxfoundation.org header.s=korg header.b=LXn9y9FK; 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=NONE sp=NONE dis=NONE) header.from=linuxfoundation.org Received: (majordomo@vger.kernel.org) by vger.kernel.org via listexpand id S234437AbiFMNGG (ORCPT + 99 others); Mon, 13 Jun 2022 09:06:06 -0400 Received: from lindbergh.monkeyblade.net ([23.128.96.19]:44830 "EHLO lindbergh.monkeyblade.net" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S1358234AbiFMMzJ (ORCPT ); Mon, 13 Jun 2022 08:55:09 -0400 Received: from ams.source.kernel.org (ams.source.kernel.org [145.40.68.75]) by lindbergh.monkeyblade.net (Postfix) with ESMTPS id EC031638B; Mon, 13 Jun 2022 04:14:52 -0700 (PDT) Received: from smtp.kernel.org (relay.kernel.org [52.25.139.140]) (using TLSv1.2 with cipher ECDHE-RSA-AES256-GCM-SHA384 (256/256 bits)) (No client certificate requested) by ams.source.kernel.org (Postfix) with ESMTPS id A2816B80EA7; Mon, 13 Jun 2022 11:14:51 +0000 (UTC) Received: by smtp.kernel.org (Postfix) with ESMTPSA id 17EB0C34114; Mon, 13 Jun 2022 11:14:49 +0000 (UTC) DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/simple; d=linuxfoundation.org; s=korg; t=1655118890; bh=L8pNPXENcGl4mTBVoi1vnDoV48D1r2hQ4ShnGOv7jDc=; h=From:To:Cc:Subject:Date:In-Reply-To:References:From; b=LXn9y9FKkqcVraBEj6BWF3l+6w0NHvpjk+bSSB5SUda7Cu/ylnMLfaFiX7E4eYKI+ ZvOHR1WUPgu8WPAcDErAk6rx+YsEz33SAwrECcr0siueqJql2MhvlS7eZ7J8D6JP+D sTYlRFQqSH0XPRTl0TpXA6HZMAsSxjVGku1Qx9nY= From: Greg Kroah-Hartman To: linux-kernel@vger.kernel.org Cc: Greg Kroah-Hartman , stable@vger.kernel.org, Zhang Wensheng , Sasha Levin Subject: [PATCH 5.15 065/247] driver core: fix deadlock in __device_attach Date: Mon, 13 Jun 2022 12:09:27 +0200 Message-Id: <20220613094924.930494278@linuxfoundation.org> X-Mailer: git-send-email 2.36.1 In-Reply-To: <20220613094922.843438024@linuxfoundation.org> References: <20220613094922.843438024@linuxfoundation.org> User-Agent: quilt/0.66 MIME-Version: 1.0 Content-Type: text/plain; charset=UTF-8 Content-Transfer-Encoding: 8bit X-Spam-Status: No, score=-8.3 required=5.0 tests=BAYES_00,DKIMWL_WL_HIGH, DKIM_SIGNED,DKIM_VALID,DKIM_VALID_AU,DKIM_VALID_EF,RCVD_IN_DNSWL_HI, SPF_HELO_NONE,SPF_PASS,T_SCC_BODY_TEXT_LINE 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 From: Zhang Wensheng [ Upstream commit b232b02bf3c205b13a26dcec08e53baddd8e59ed ] In __device_attach function, The lock holding logic is as follows: ... __device_attach device_lock(dev) // get lock dev async_schedule_dev(__device_attach_async_helper, dev); // func async_schedule_node async_schedule_node_domain(func) entry = kzalloc(sizeof(struct async_entry), GFP_ATOMIC); /* when fail or work limit, sync to execute func, but __device_attach_async_helper will get lock dev as well, which will lead to A-A deadlock. */ if (!entry || atomic_read(&entry_count) > MAX_WORK) { func; else queue_work_node(node, system_unbound_wq, &entry->work) device_unlock(dev) As shown above, when it is allowed to do async probes, because of out of memory or work limit, async work is not allowed, to do sync execute instead. it will lead to A-A deadlock because of __device_attach_async_helper getting lock dev. To fix the deadlock, move the async_schedule_dev outside device_lock, as we can see, in async_schedule_node_domain, the parameter of queue_work_node is system_unbound_wq, so it can accept concurrent operations. which will also not change the code logic, and will not lead to deadlock. Fixes: 765230b5f084 ("driver-core: add asynchronous probing support for drivers") Signed-off-by: Zhang Wensheng Link: https://lore.kernel.org/r/20220518074516.1225580-1-zhangwensheng5@huawei.com Signed-off-by: Greg Kroah-Hartman Signed-off-by: Sasha Levin --- drivers/base/dd.c | 5 ++++- 1 file changed, 4 insertions(+), 1 deletion(-) diff --git a/drivers/base/dd.c b/drivers/base/dd.c index 95ae347df137..a480004b9897 100644 --- a/drivers/base/dd.c +++ b/drivers/base/dd.c @@ -944,6 +944,7 @@ static void __device_attach_async_helper(void *_dev, async_cookie_t cookie) static int __device_attach(struct device *dev, bool allow_async) { int ret = 0; + bool async = false; device_lock(dev); if (dev->p->dead) { @@ -982,7 +983,7 @@ static int __device_attach(struct device *dev, bool allow_async) */ dev_dbg(dev, "scheduling asynchronous probe\n"); get_device(dev); - async_schedule_dev(__device_attach_async_helper, dev); + async = true; } else { pm_request_idle(dev); } @@ -992,6 +993,8 @@ static int __device_attach(struct device *dev, bool allow_async) } out_unlock: device_unlock(dev); + if (async) + async_schedule_dev(__device_attach_async_helper, dev); return ret; } -- 2.35.1