Received: by 2002:a05:6a10:1287:0:0:0:0 with SMTP id d7csp3540340pxv; Mon, 26 Jul 2021 06:27:56 -0700 (PDT) X-Google-Smtp-Source: ABdhPJzKjV6vaNJVBLcdJZHUijx4Arroosvhu2pBx6FhtlUgiaxJ3QgapT/yNZCiks6+fti1CztH X-Received: by 2002:a17:907:98c1:: with SMTP id kd1mr2708904ejc.51.1627306076320; Mon, 26 Jul 2021 06:27:56 -0700 (PDT) ARC-Seal: i=1; a=rsa-sha256; t=1627306076; cv=none; d=google.com; s=arc-20160816; b=MFX+5C5on8QMc/fBzkCmSV/Q8a2WqWwFa420X+nYKmtoAbr9x1tCe039oNo9TIrVXx Zxk30n+pgprTUKo7d+sYutHuTUK8E3eh9EnXqe3l2fZ+fkOVWh4hnIo+k5p0r4wDVpOl h8TxfLTp0KfQIEYokylJmBRiJI41YGJ9RPsTZp0KoJcZY9aX6VP4q5zyrzFhHnQ6TOqE o3Y2F7nbBbvnkQTIbLPs4/gwJ41kaBBByrr7bk9R62A5qJwkXvjJ3aOy5t6BXYL4h+sl ALT4YOa8vmzVeaNkLEE25+uijrnzf2EzND/PXp1l41paVIYODKSiLsxFZo84iOD7l8hY FZkA== 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 :references:in-reply-to:message-id:date:subject:cc:to:from :dkim-signature; bh=9K67sWK8iCvxn8wA3EP4cDIU+lrlaZyWsxH1S+wkYOk=; b=PdbHVklCGlPDpCRBsu3Zw8ubMkD42iqJE6fS4UBLs3/SVfGk4bPy9ctb0/REhPVcE6 Sy4/RHTXJ7GUfbr+7ClLrCp0zfy7envORBHu+HgPX1CruZ8aO3KJOOl/pyYtDGBcrGtJ HCLRq6acV/NEkSULK8v5x/7PblkPQCXmIOB7dn6fSMgSJRJhckf7DutYAZ9mXRm/7Kfy 6mHwTW+JZlUPMcjfqR9zm3waABXYNuQGBuxzhZ2kyW5aO9cBLY4wPIs0fGAKttRXiaHi 7t3vhIOBBYiin7B86HT2wQ9FqDialS3A6eG3/48rvEgepOk4j4ZDkpnlzxvslkKZtWCE xA+w== ARC-Authentication-Results: i=1; mx.google.com; dkim=pass header.i=@gmail.com header.s=20161025 header.b=SuZZBJip; spf=pass (google.com: domain of linux-kernel-owner@vger.kernel.org designates 23.128.96.18 as permitted sender) smtp.mailfrom=linux-kernel-owner@vger.kernel.org; dmarc=pass (p=NONE sp=QUARANTINE dis=NONE) header.from=gmail.com Return-Path: Received: from vger.kernel.org (vger.kernel.org. [23.128.96.18]) by mx.google.com with ESMTP id hp5si328859ejc.383.2021.07.26.06.27.31; Mon, 26 Jul 2021 06:27:56 -0700 (PDT) Received-SPF: pass (google.com: domain of linux-kernel-owner@vger.kernel.org designates 23.128.96.18 as permitted sender) client-ip=23.128.96.18; Authentication-Results: mx.google.com; dkim=pass header.i=@gmail.com header.s=20161025 header.b=SuZZBJip; spf=pass (google.com: domain of linux-kernel-owner@vger.kernel.org designates 23.128.96.18 as permitted sender) smtp.mailfrom=linux-kernel-owner@vger.kernel.org; dmarc=pass (p=NONE sp=QUARANTINE dis=NONE) header.from=gmail.com Received: (majordomo@vger.kernel.org) by vger.kernel.org via listexpand id S233607AbhGZMm5 (ORCPT + 99 others); Mon, 26 Jul 2021 08:42:57 -0400 Received: from lindbergh.monkeyblade.net ([23.128.96.19]:42172 "EHLO lindbergh.monkeyblade.net" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S233593AbhGZMmz (ORCPT ); Mon, 26 Jul 2021 08:42:55 -0400 Received: from mail-wr1-x42e.google.com (mail-wr1-x42e.google.com [IPv6:2a00:1450:4864:20::42e]) by lindbergh.monkeyblade.net (Postfix) with ESMTPS id 7E927C061757; Mon, 26 Jul 2021 06:23:24 -0700 (PDT) Received: by mail-wr1-x42e.google.com with SMTP id h14so3117757wrx.10; Mon, 26 Jul 2021 06:23:24 -0700 (PDT) DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/relaxed; d=gmail.com; s=20161025; h=from:to:cc:subject:date:message-id:in-reply-to:references :mime-version:content-transfer-encoding; bh=9K67sWK8iCvxn8wA3EP4cDIU+lrlaZyWsxH1S+wkYOk=; b=SuZZBJipNbPUZaCppP1IpW/GUu7EREB17r3O2x4RRKUBddZb/DPJWFM2D2yPk6HaS8 dwpZBgsZEe+JxhCYo0i9ZfC1JzogLyjFf2r4NXY+QnIUKgYevYwGkxWgCaQjr+MKV73/ HCfSbSFgw6B9XATA8nj/GEkkYaK19r5+Uwvtl3xKUaHHhuZhwypzUw7lraPUiE/WvEcj haRm31qV4CQ+iVkt5bLMNpFyFx/roj6x9k4OBrqTvojR1mgBmCZ+vMIJEDf3U5jNfGXR vUjkTpfTW97crzw4/5wizMHsUxf99qtVe7fvTJlc6h3SXsZr4YSU5rllmc6CTuO2crzs PxAA== X-Google-DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/relaxed; d=1e100.net; s=20161025; h=x-gm-message-state:from:to:cc:subject:date:message-id:in-reply-to :references:mime-version:content-transfer-encoding; bh=9K67sWK8iCvxn8wA3EP4cDIU+lrlaZyWsxH1S+wkYOk=; b=VDCot7owBQAX7/ebBzxZgnNbo7swYMxhA41JXuTByunpE7itxI2bChyuUIfg2xsgxS T7hZrNT9fvWY6rzuSnNiKQ9tJAs5Ha9k8be940PmsqCfGHW0GsqkppkSNqk4lV8IrXrh osi3f2RTFd1Gph13OOx21638zJJpjoFzSSCuPxzvc4le6Mma0U7HSNFHfk0Y3fhV4qWM ehVpafpIbGZNE8B/CZKvJSgbKd8jhQ4Xn1HxHwHsVOnwW3AsMrjOg14dQOeJCYEqT8T1 60XZh7o6d3u/ZPhIlVDOnnZ9dQT5nxFa0RnNuzJrmQ5mkfOeXXLP7qcaWngUGr9v+oGK NBLA== X-Gm-Message-State: AOAM5304mR7Fx+Za/VuJmkjDijtd57O5mKWMxnMC/3RzPogXdTwhJlD3 tgNPm6D3uep2cxUS/TEiYuA= X-Received: by 2002:a5d:6708:: with SMTP id o8mr9758731wru.304.1627305803088; Mon, 26 Jul 2021 06:23:23 -0700 (PDT) Received: from microndev.lxd (ip5f5ac0ff.dynamic.kabel-deutschland.de. [95.90.192.255]) by smtp.gmail.com with ESMTPSA id w15sm8580wmi.3.2021.07.26.06.23.22 (version=TLS1_3 cipher=TLS_AES_256_GCM_SHA384 bits=256/256); Mon, 26 Jul 2021 06:23:22 -0700 (PDT) From: shiva.linuxworks@gmail.com X-Google-Original-From: sshivamurthy@micron.com To: rjw@rjwysocki.net, pavel@ucw.cz, len.brown@intel.com, linux-pm@vger.kernel.org, kbusch@kernel.org, axboe@fb.com, hch@lst.de, sagi@grimberg.me, linux-nvme@lists.infradead.org Cc: linux-kernel@vger.kernel.org, Shivamurthy Shastri , Keith Busch Subject: [PATCH v2 1/2] PM: enable support for imminent power loss Date: Mon, 26 Jul 2021 13:22:22 +0000 Message-Id: <20210726132223.1661-2-sshivamurthy@micron.com> X-Mailer: git-send-email 2.25.1 In-Reply-To: <20210726132223.1661-1-sshivamurthy@micron.com> References: <20210726132223.1661-1-sshivamurthy@micron.com> MIME-Version: 1.0 Content-Transfer-Encoding: 8bit Precedence: bulk List-ID: X-Mailing-List: linux-kernel@vger.kernel.org From: Shivamurthy Shastri If the shutdown is pwerformed when the platform is running on the limited backup power supply, some of the devices might not have enough power to perform a clean shutdown. It is necessary to inform the driver about the limited backup power supply, to allow the driver to decide to perform the minimal required operation for a fast and clean shutdown. Signed-off-by: Keith Busch Signed-off-by: Shivamurthy Shastri --- include/linux/suspend.h | 28 +++++++++++++++++++++++++--- 1 file changed, 25 insertions(+), 3 deletions(-) diff --git a/include/linux/suspend.h b/include/linux/suspend.h index 8af13ba60c7e..1898792c10d3 100644 --- a/include/linux/suspend.h +++ b/include/linux/suspend.h @@ -210,9 +210,10 @@ extern int suspend_valid_only_mem(suspend_state_t state); extern unsigned int pm_suspend_global_flags; -#define PM_SUSPEND_FLAG_FW_SUSPEND BIT(0) -#define PM_SUSPEND_FLAG_FW_RESUME BIT(1) -#define PM_SUSPEND_FLAG_NO_PLATFORM BIT(2) +#define PM_SUSPEND_FLAG_FW_SUSPEND BIT(0) +#define PM_SUSPEND_FLAG_FW_RESUME BIT(1) +#define PM_SUSPEND_FLAG_NO_PLATFORM BIT(2) +#define PM_SUSPEND_FLAG_POWER_LOSS_IMMINENT BIT(3) static inline void pm_suspend_clear_flags(void) { @@ -234,6 +235,11 @@ static inline void pm_set_suspend_no_platform(void) pm_suspend_global_flags |= PM_SUSPEND_FLAG_NO_PLATFORM; } +static inline void pm_set_power_loss_imminent(void) +{ + pm_suspend_global_flags |= PM_SUSPEND_FLAG_POWER_LOSS_IMMINENT; +} + /** * pm_suspend_via_firmware - Check if platform firmware will suspend the system. * @@ -291,6 +297,22 @@ static inline bool pm_suspend_no_platform(void) return !!(pm_suspend_global_flags & PM_SUSPEND_FLAG_NO_PLATFORM); } +/** + * pm_power_loss_imminent - Check if platform is running on limited backup power + * source + * + * To be called during system-wide power management transitions to sleep states. + * + * Return 'true' if power loss may be imminent due to platform running on + * limited backup supply. If set during a shutdown, drivers should use any + * available shortcuts to prepare their device for abrupt power loss. + */ +static inline bool pm_power_loss_imminent(void) +{ + return !!(pm_suspend_global_flags & + PM_SUSPEND_FLAG_POWER_LOSS_IMMINENT); +} + /* Suspend-to-idle state machnine. */ enum s2idle_states { S2IDLE_STATE_NONE, /* Not suspended/suspending. */ -- 2.25.1