Received: by 2002:a05:6a10:2726:0:0:0:0 with SMTP id ib38csp5710918pxb; Mon, 28 Mar 2022 16:36:07 -0700 (PDT) X-Google-Smtp-Source: ABdhPJwzHOJXgeV2OqJ6TCOFhyDs5MLTBzycMQTa3F0zN6LTNQfPiuPF21eqILSWGHdJAl8KP9HH X-Received: by 2002:a67:e24f:0:b0:325:6a10:1221 with SMTP id w15-20020a67e24f000000b003256a101221mr12187131vse.14.1648510567443; Mon, 28 Mar 2022 16:36:07 -0700 (PDT) ARC-Seal: i=1; a=rsa-sha256; t=1648510567; cv=none; d=google.com; s=arc-20160816; b=S2b7T9W6moxZvkJqXXwdvHW2ZRlGC+nLhh55aO4xti02DsZ0pm7mgQd3gCy5oXWirj que0bz7m4RUgVf6el8rTc1fTQFT6ckymtumQ8wi6CQ/YuN8+rTQXz6Pc5bh87DL1tzh6 dbn9hIlbrPjBDCqBmOhWrkmMmpRiFomX+tBo/Ph5MMIwzibSH3KWpLTvOY5oYuItP4qC CNKkC+iHNeYWrAoBOrozEU/vfra62qO1+C9KszuE7jpr0YDnNuEPNj48DgTrViwEp9lL vB0Of/zGicvMch22Emq474d5v22Ui42VLfr39LbG84UcW5JRdSu4ECHWF6maXWhUzAy6 rR/Q== 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:references:mime-version :message-id:in-reply-to:date:dkim-signature; bh=PjCJgoS657I/tk8eQdlHI01Sy2nbJ1vs0eOca3BDeMA=; b=cwaRh6/Ce0upRCru1HaHDR9SLWh2BW2CkFkKaPQ3VvT5Elrqa2VAyVtcPMQR3xJMNG E8dFNUqoBtkvTYsSi2x3qkJpMnss2WCGEFnfnEDpIKYQsCoP5JLwkbJpj6G7ecFvzqlb ygw+bQdOGHkJ2/V152sDa8AM7FRoIUxUw4wcsT7NOlbgGo3juP5ARmG6C8mfGqtWRiF7 1EjmgMtUcvKpL6oVsaRoqsQ3vOmCxwMUj74/8wBh8Rwu3JatPzNtWKxMYUOs9/CR4uEM Y/MV4HcalDLa1KJkYNCblEDkWqFXVZXrCQDG3Cauh1RuG6AcyEAC0PJBjk7JXiA21NCa eNDg== ARC-Authentication-Results: i=1; mx.google.com; dkim=pass header.i=@google.com header.s=20210112 header.b=YrW1oHI6; spf=softfail (google.com: domain of transitioning linux-kernel-owner@vger.kernel.org does not designate 23.128.96.19 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 lindbergh.monkeyblade.net (lindbergh.monkeyblade.net. [23.128.96.19]) by mx.google.com with ESMTPS id y12-20020a67d20c000000b00325276077d6si3542813vsi.189.2022.03.28.16.36.06 (version=TLS1_3 cipher=TLS_AES_256_GCM_SHA384 bits=256/256); Mon, 28 Mar 2022 16:36:07 -0700 (PDT) Received-SPF: softfail (google.com: domain of transitioning linux-kernel-owner@vger.kernel.org does not designate 23.128.96.19 as permitted sender) client-ip=23.128.96.19; Authentication-Results: mx.google.com; dkim=pass header.i=@google.com header.s=20210112 header.b=YrW1oHI6; spf=softfail (google.com: domain of transitioning linux-kernel-owner@vger.kernel.org does not designate 23.128.96.19 as permitted sender) smtp.mailfrom=linux-kernel-owner@vger.kernel.org; dmarc=pass (p=REJECT sp=REJECT dis=NONE) header.from=google.com Received: from vger.kernel.org (vger.kernel.org [23.128.96.18]) by lindbergh.monkeyblade.net (Postfix) with ESMTP id BE0052B1A3; Mon, 28 Mar 2022 16:00:41 -0700 (PDT) Received: (majordomo@vger.kernel.org) by vger.kernel.org via listexpand id S230243AbiC1XCR (ORCPT + 99 others); Mon, 28 Mar 2022 19:02:17 -0400 Received: from lindbergh.monkeyblade.net ([23.128.96.19]:42814 "EHLO lindbergh.monkeyblade.net" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S230221AbiC1XCI (ORCPT ); Mon, 28 Mar 2022 19:02:08 -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 1FCFF26130 for ; Mon, 28 Mar 2022 16:00:23 -0700 (PDT) Received: by mail-yw1-x114a.google.com with SMTP id 00721157ae682-2e9e838590dso62331717b3.5 for ; Mon, 28 Mar 2022 16:00:23 -0700 (PDT) DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/relaxed; d=google.com; s=20210112; h=date:in-reply-to:message-id:mime-version:references:subject:from:to :cc; bh=PjCJgoS657I/tk8eQdlHI01Sy2nbJ1vs0eOca3BDeMA=; b=YrW1oHI6OeNS97qb0yJLiWsmS/O0yisj3J+4OLHulXFrVW++E6+RYQOIE9kRM8gvPl nYVOVSMnQ38vUWHmvPhbD7Di+LW8cxAlhFJk6rylh8ho4c7W6RbVgiqFR3kqbUGal79N AnGraxxjbZ/qEIuvv/3hskPbqVzITszKNTauorm3U5A10LAz33yyLW+qRHr39PSjgZEc gFxP0vIK4JjSTg72HAxnLs1TerTNewB0WjKzK2tZmdEGrsphjP+GpJ/8nRfVGtQ6/6oh 8DnJjPZ35lUPzzKkyIyhHXn9zk+j+m6UjTXpgJYAHJ8LEDsxYZSRsjbEB7hd4MEVv7fE U7mw== X-Google-DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/relaxed; d=1e100.net; s=20210112; h=x-gm-message-state:date:in-reply-to:message-id:mime-version :references:subject:from:to:cc; bh=PjCJgoS657I/tk8eQdlHI01Sy2nbJ1vs0eOca3BDeMA=; b=oR7Si2TcLZ5d7QUPWQE36UGomBA4P1YHYJj4T4VMM8Hk2R/bFtlwwKYGIxTkA9Z5MJ iUr/yxQ3OE+gMTYNkGS9h+M060V7Bo6EnLT2N0omLHqQbShibpEHvEhPKeIu8s2dDO5d dk56Vs8uiWyxYzBUn+WlxVVk3YlcOrmfAXmlliIWHzDMHUSV5Fs7xBnXk/686D13u3A9 erEtEkHpkrSX0I0cdeBJ37DVgxaeKXg9nUdlI+MtCpqknjfmqn/egqrGFCvPQ0ZfSzYe ArvxgqTd+p2aShBqGtIWPc4T2TfnfvCuPxjE8Y405Cnjb+lPorXyDuZ3YoR/MPEWP3MS M38Q== X-Gm-Message-State: AOAM532PYwMNE0m0v2mFgmH2fcP1NJs5XBqSyGiuDYtB56+HoBHMsTwV dfxeaOyZ7/EUZJdHzD28PZAx2I72X/rCiM8= X-Received: from tansuresh.svl.corp.google.com ([2620:15c:2c5:13:3dbb:6bbc:98be:a31e]) (user=tansuresh job=sendgmr) by 2002:a81:c02:0:b0:2e5:b6af:2c8 with SMTP id 2-20020a810c02000000b002e5b6af02c8mr29031195ywm.190.1648508422372; Mon, 28 Mar 2022 16:00:22 -0700 (PDT) Date: Mon, 28 Mar 2022 16:00:07 -0700 In-Reply-To: <20220328230008.3587975-2-tansuresh@google.com> Message-Id: <20220328230008.3587975-3-tansuresh@google.com> Mime-Version: 1.0 References: <20220328230008.3587975-1-tansuresh@google.com> <20220328230008.3587975-2-tansuresh@google.com> X-Mailer: git-send-email 2.35.1.1021.g381101b075-goog Subject: [PATCH v1 2/3] PCI: Support asynchronous shutdown From: Tanjore Suresh To: Greg Kroah-Hartman , "Rafael J . Wysocki" , Christoph Hellwig , Sagi Grimberg , Bjorn Helgaas Cc: linux-kernel@vger.kernel.org, linux-nvme@lists.infradead.org, linux-pci@vger.kernel.org, Tanjore Suresh Content-Type: text/plain; charset="UTF-8" X-Spam-Status: No, score=-9.5 required=5.0 tests=BAYES_00,DKIMWL_WL_MED, DKIM_SIGNED,DKIM_VALID,DKIM_VALID_AU,HEADER_FROM_DIFFERENT_DOMAINS, MAILING_LIST_MULTI,RDNS_NONE,SPF_HELO_NONE,T_SCC_BODY_TEXT_LINE, USER_IN_DEF_DKIM_WL autolearn=no 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 b957eeb89c7a..19047fcb3c8a 100644 --- a/include/linux/pci.h +++ b/include/linux/pci.h @@ -905,6 +905,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