Received: by 2002:a05:6a10:2726:0:0:0:0 with SMTP id ib38csp1768894pxb; Fri, 25 Mar 2022 05:23:11 -0700 (PDT) X-Google-Smtp-Source: ABdhPJxkr236Td1N22bzfXpSOhlmJ7jABHHQu90q+Fu9O3IPmGtyVMHFlmvV4S7D3fC2Yx6WU1wZ X-Received: by 2002:a05:6402:5193:b0:419:3d19:ce9e with SMTP id q19-20020a056402519300b004193d19ce9emr12636438edd.199.1648210991501; Fri, 25 Mar 2022 05:23:11 -0700 (PDT) ARC-Seal: i=1; a=rsa-sha256; t=1648210991; cv=none; d=google.com; s=arc-20160816; b=cYfQa99FJNNvjFID5RmNAEuLQZweCgfGBURVt7SfIZk849FipaKnY1t7yReS3L3WJ4 8G5mmR8z67GyQvjeAAh9G/fCYuqs+mxaNU46Ts84F4Nv+CKJ2PPfTAylThgd6I4oFuY3 YQXl2tnrHcQJJCSxUWCuT/xWfhjBXID+IeohDEEZjCQBOyl4s/nHIgc2DQI4UhMzYuUc SX4Y2gT+Z0IK3/uZeZzg0HHxUTjJjNE66IQ/Z/YrvacdBnVChxN1qyrd95xHORa8quj+ dgmwMfwDr4s2rxi6dxaMi5ppd0gRW7WezFoAQK7lvRFtI0WZwFBWCFxi7H3fVycb7ds3 Ifow== ARC-Message-Signature: i=1; a=rsa-sha256; c=relaxed/relaxed; d=google.com; s=arc-20160816; h=list-id:precedence:cc:to:from:subject:mime-version:message-id:date :dkim-signature; bh=iKkzGcGXHNcNBC8QzCNubVd1VUuqnCpLdh8zslocqU0=; b=NH1KfIviXW9/wf0rZSlKopOvXd/1Vb5U+nq1TW8zC2UA+WtkK+u0lVaDiMkDcBR2MR S0Wz7OPAN4JytyMfoQLTtTRzU8ybyOeFoHpkxdVsbAFwKTlpJUBg+q1TdKViQR6JL1bc OhrQUGaTq9gpds0vZwjyECtsfbTojSZGWBYKU7ZLuvq30mhYntpy2OAAmdNnfGyIPrTe v3maGGFEMInbaLJkiOtw2PYtlRTFy/shy9MEJE2MHwuktLvvAnNS4TeaiBqDaRVUGEJb aqXnPCovFnQp41nlzgXUSdOhxtry37Ec9mH/+VMdVqiSYvkUjAwEaiH9Oh/bAYSMqyBj 7UEQ== ARC-Authentication-Results: i=1; mx.google.com; dkim=pass header.i=@google.com header.s=20210112 header.b=JVbOmq76; 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=REJECT dis=NONE) header.from=google.com Return-Path: Received: from out1.vger.email (out1.vger.email. [2620:137:e000::1:20]) by mx.google.com with ESMTP id a6-20020a509b46000000b00418c2b5be72si2770726edj.340.2022.03.25.05.22.46; Fri, 25 Mar 2022 05:23:11 -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=@google.com header.s=20210112 header.b=JVbOmq76; 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=REJECT dis=NONE) header.from=google.com Received: (majordomo@vger.kernel.org) by vger.kernel.org via listexpand id S1355178AbiCXVkP (ORCPT + 99 others); Thu, 24 Mar 2022 17:40:15 -0400 Received: from lindbergh.monkeyblade.net ([23.128.96.19]:43094 "EHLO lindbergh.monkeyblade.net" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S1354221AbiCXVkO (ORCPT ); Thu, 24 Mar 2022 17:40:14 -0400 Received: from mail-yw1-x114a.google.com (mail-yw1-x114a.google.com [IPv6:2607:f8b0:4864:20::114a]) by lindbergh.monkeyblade.net (Postfix) with ESMTPS id A02B836B6B for ; Thu, 24 Mar 2022 14:38:41 -0700 (PDT) Received: by mail-yw1-x114a.google.com with SMTP id 00721157ae682-2e61c5a0eb7so45810997b3.22 for ; Thu, 24 Mar 2022 14:38:41 -0700 (PDT) DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/relaxed; d=google.com; s=20210112; h=date:message-id:mime-version:subject:from:to:cc; bh=iKkzGcGXHNcNBC8QzCNubVd1VUuqnCpLdh8zslocqU0=; b=JVbOmq76XrgynnBO5Yhxuas50bYdBiMTf7e2IRWZzuXOwZnZDGqhmUDVmzJ/ZkYW9C ikB/1e4diohU0+QBEeuTLaRtpmtN56uFgGKJxf0sleQIO2brQqw1GNfXU2vGCCr0QOPS hAp92VeJiPj93PD3VRCf0Xze5IEsn/t1UdAr9vr9ZZF0Gdxdwum1c3Nfp5AVn0GhW5xA kzkEkISLYgP/gYhc/cWYUWCi/ozbgfwwZukixDEcO4Mbuj+zCQ3YgTxzG/Mje1mORDHq ZAWAEF2hXJ56RT0BKDiP33cUzznaD3L/baMvqQAPGb7BWkPoCyz2nsln57WD90fRxYj1 mdIQ== X-Google-DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/relaxed; d=1e100.net; s=20210112; h=x-gm-message-state:date:message-id:mime-version:subject:from:to:cc; bh=iKkzGcGXHNcNBC8QzCNubVd1VUuqnCpLdh8zslocqU0=; b=tIpFziZieboNVs2NN5AC85afEl5hUJDH3s0XMpkKCTaVQFhyEePBWMzMo8QDRW112x Q/+OoJsdjjlxPQgcQb3YXoSGqDFYvnKT2vmXBUlFhpsqxANW7ALLLrB0kyXjjrfPntGH BvpjjIRGx5nFOyqqQcNCmF3r2ldDulN2jre9NHcsgR7hLtQYA0z/9DdkaiYGraK1l/0n pXU42jaIUcOcIMWIW5mn6wefYYLftWO4T2yhWdd9LMQqxn6WjkWig2VRhJRFuEeb5E2i tpd9GC5LWxIgSEdXydL8nidiuCvLNoyJSC6mzr7RNNgfCoVygVLPou/WrRkmrtpfU7oP NUAQ== X-Gm-Message-State: AOAM531JMyntz8WRMJknrCOzsd7kDfQC3a/mqSlmxmTt/cH5Twas7pI5 xGZc6HY4aIjvfbPQx2WvV+4yr8iarf+/EXw= X-Received: from tansuresh.svl.corp.google.com ([2620:15c:2c5:13:849f:5cb9:7db8:508a]) (user=tansuresh job=sendgmr) by 2002:a05:6902:1d1:b0:636:fa07:4b9a with SMTP id u17-20020a05690201d100b00636fa074b9amr6337359ybh.590.1648157920886; Thu, 24 Mar 2022 14:38:40 -0700 (PDT) Date: Thu, 24 Mar 2022 14:38:33 -0700 Message-Id: <20220324213833.3056034-1-tansuresh@google.com> Mime-Version: 1.0 X-Mailer: git-send-email 2.35.1.1021.g381101b075-goog Subject: [PATCH 2/3] PCI: Support asynchronous shutdown From: Tanjore Suresh To: Bjorn Helgaas Cc: linux-pci@vger.kernel.org, linux-kernel@vger.kernel.org, Tanjore Suresh Content-Type: text/plain; charset="UTF-8" X-Spam-Status: No, score=-9.6 required=5.0 tests=BAYES_00,DKIMWL_WL_MED, DKIM_SIGNED,DKIM_VALID,DKIM_VALID_AU,DKIM_VALID_EF,RCVD_IN_DNSWL_NONE, SPF_HELO_NONE,SPF_PASS,T_SCC_BODY_TEXT_LINE,USER_IN_DEF_DKIM_WL 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 Enhances the base PCI driver to add support for asynchronous shutdown. Assume a device takes n secs to shutdown. If a machine has been populated with M such devices, the total time spent in shutting down all the devices will be M * n secs, if the shutdown is done synchronously. For example, if NVMe PCI Controllers take 5 secs to shutdown and if there are 16 such NVMe controllers in a system, system will spend a total of 80 secs to shutdown all NVMe devices in that system. In order to speed up the shutdown time, asynchronous interface to shutdown has been implemented. This will significantly reduce the machine reboot time. Signed-off-by: Tanjore Suresh --- drivers/pci/pci-driver.c | 17 ++++++++++++++--- include/linux/pci.h | 2 ++ 2 files changed, 16 insertions(+), 3 deletions(-) diff --git a/drivers/pci/pci-driver.c b/drivers/pci/pci-driver.c index 4ceeb75fc899..0d0b46d71e88 100644 --- a/drivers/pci/pci-driver.c +++ b/drivers/pci/pci-driver.c @@ -501,14 +501,16 @@ static void pci_device_remove(struct device *dev) pci_dev_put(pci_dev); } -static void pci_device_shutdown(struct device *dev) +static void pci_device_shutdown_pre(struct device *dev) { struct pci_dev *pci_dev = to_pci_dev(dev); struct pci_driver *drv = pci_dev->driver; pm_runtime_resume(dev); - if (drv && drv->shutdown) + if (drv && drv->shutdown_pre) + drv->shutdown_pre(pci_dev); + else if (drv && drv->shutdown) drv->shutdown(pci_dev); /* @@ -522,6 +524,14 @@ static void pci_device_shutdown(struct device *dev) pci_clear_master(pci_dev); } +static void pci_device_shutdown_post(struct device *dev) +{ + struct pci_dev *pci_dev = to_pci_dev(dev); + struct pci_driver *drv = pci_dev->driver; + + if (drv && drv->shutdown_post) + drv->shutdown_post(pci_dev); +} #ifdef CONFIG_PM /* Auxiliary functions used for system resume and run-time resume. */ @@ -1625,7 +1635,8 @@ struct bus_type pci_bus_type = { .uevent = pci_uevent, .probe = pci_device_probe, .remove = pci_device_remove, - .shutdown = pci_device_shutdown, + .shutdown_pre = pci_device_shutdown_pre, + .shutdown_post = pci_device_shutdown_post, .dev_groups = pci_dev_groups, .bus_groups = pci_bus_groups, .drv_groups = pci_drv_groups, diff --git a/include/linux/pci.h b/include/linux/pci.h index 60d423d8f0c4..bdd3a4d65a19 100644 --- a/include/linux/pci.h +++ b/include/linux/pci.h @@ -904,6 +904,8 @@ struct pci_driver { int (*suspend)(struct pci_dev *dev, pm_message_t state); /* Device suspended */ int (*resume)(struct pci_dev *dev); /* Device woken up */ void (*shutdown)(struct pci_dev *dev); + void (*shutdown_pre)(struct pci_dev *dev); + void (*shutdown_post)(struct pci_dev *dev); int (*sriov_configure)(struct pci_dev *dev, int num_vfs); /* On PF */ int (*sriov_set_msix_vec_count)(struct pci_dev *vf, int msix_vec_count); /* On PF */ u32 (*sriov_get_vf_total_msix)(struct pci_dev *pf); -- 2.35.1.1021.g381101b075-goog