Received: by 2002:a05:6a10:f3d0:0:0:0:0 with SMTP id a16csp4742908pxv; Tue, 6 Jul 2021 08:08:48 -0700 (PDT) X-Google-Smtp-Source: ABdhPJzx1qhbZzXKF5pqKlop7o9pWGrtZ0WVrUkcQllNeKT18Yj4Dz6R6O/OuG5WEfTMKb9ZCJbc X-Received: by 2002:a05:6e02:1a04:: with SMTP id s4mr14467822ild.294.1625584128016; Tue, 06 Jul 2021 08:08:48 -0700 (PDT) ARC-Seal: i=1; a=rsa-sha256; t=1625584128; cv=none; d=google.com; s=arc-20160816; b=jYTFQXP52LypRufJbbR9Vdh9PUri0l/HLYePc7nmmyB2Jat/0eushSATbAYp4fG360 KN/fsQ6CprAW6t809NQQ+CqB1SONpBa47EaF/uVDR0RsVUFcj7AjhS+IWnOQZXcefz+F VH0T+OtNitKb4Sq2inJDCiLD16rJbUvZxIqNtyALjBqjNwHZYOMt7QqtPdG87NA979Ac Xz2g/HFyET2c7V8BMlQvE5K445si3idTr17pDHbcYaAPV7cAmI+ykZd23znt7q6QIbLZ YRv8QszlnYy7O2aFHALgesWWEWngBtcafQzibIlohCRDSizDyDPcqA/JVpKCPr+dB/IJ UwMw== ARC-Message-Signature: i=1; a=rsa-sha256; c=relaxed/relaxed; d=google.com; s=arc-20160816; h=list-id:precedence:in-reply-to:content-disposition:mime-version :references:message-id:subject:cc:to:from:date:dkim-signature; bh=PAL+2WZQwRhzrl4aJCwjNra2e97iuByx5vpgN/Xwt2w=; b=EUwMxoPB8Zt8gbs3Uf11D/tpxupSYHupRkgnsEMQ/d1gd+O2wLvpaOmHJg8XIc+SVs b7oXhwSnJipEp+Ujkgu4lN9ZQxeOt45IPRJK0i2tWW+W58IBD9M62uqwTsxfWxNTdxOf guGwxficS9ZrBOX/7AojBlWw0NIgGmq4+KlYtaubh6U7xFbMLvLPRs6cddLiKYrFpZe3 jv7LxH2o0Bi86gWS6xqKspN7+enf6Gxsg0PHPzNyrFvk1byar9TpPtrbi1WcCD67cQ3/ 1jm2tWl57Qv3BzdMNrMHZwMA4c6zh0IbNZEab6Hq+lsdT7O+wITPt5Q9QuBJ4aRjIb8V LcSg== ARC-Authentication-Results: i=1; mx.google.com; dkim=pass header.i=@kernel.org header.s=k20201202 header.b=nq1KVNwH; 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=NONE dis=NONE) header.from=kernel.org Return-Path: Received: from vger.kernel.org (vger.kernel.org. [23.128.96.18]) by mx.google.com with ESMTP id z16si1416779ilm.29.2021.07.06.08.08.36; Tue, 06 Jul 2021 08:08:48 -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=@kernel.org header.s=k20201202 header.b=nq1KVNwH; 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=NONE dis=NONE) header.from=kernel.org Received: (majordomo@vger.kernel.org) by vger.kernel.org via listexpand id S232404AbhGFPKD (ORCPT + 99 others); Tue, 6 Jul 2021 11:10:03 -0400 Received: from mail.kernel.org ([198.145.29.99]:46610 "EHLO mail.kernel.org" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S232443AbhGFPJw (ORCPT ); Tue, 6 Jul 2021 11:09:52 -0400 Received: by mail.kernel.org (Postfix) with ESMTPSA id 70F0661C21; Tue, 6 Jul 2021 15:07:13 +0000 (UTC) DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/simple; d=kernel.org; s=k20201202; t=1625584034; bh=OaOtGlYd/ajyQ9/+XQVhEEAgkcRDMXj2QiJgTH5ai5o=; h=Date:From:To:Cc:Subject:References:In-Reply-To:From; b=nq1KVNwHS1Rz/rXhLOhklUOzoOJm++F158VpelOJG5XH1XI3paCdgzHR924eb5+77 kgBMLUVgXVmIRcINY9bE90fZ40oPOXVQLXQVGeEf9xUV1YdQFykFNMf+sE3Mt45JQJ 8j2qFvF3wtuZEvtcNkwujKAdncGaZSGsQOyVrwJZwPuHnUGB+GtDJ8BDgeKp3xlI64 PVPBlJ3yXjN9q9O2YnIDO7Xz6q7vasHHYIclHkK7MzzDNcfr3A56P2sn+CyMZyPOPH swNGd8ZBH0E5pSAMo5jeZRR2V3lPOx+HzX8k0EmuYkkFtGmryNkl9O+5BX1cmaWYNZ kO+47xPFVkVrA== Date: Tue, 6 Jul 2021 08:07:11 -0700 From: Keith Busch To: "Shivamurthy Shastri (sshivamurthy)" Cc: Christoph Hellwig , "axboe@fb.com" , "sagi@grimberg.me" , "linux-nvme@lists.infradead.org" , "linux-kernel@vger.kernel.org" , "shiva.linuxworks@gmail.com" Subject: Re: [EXT] Re: [PATCH] nvme: Add abrupt shutdown support Message-ID: <20210706150711.GA241231@dhcp-10-100-145-180.wdc.com> References: <20210705101157.1009135-1-sshivamurthy@micron.com> <20210705101554.GA12803@lst.de> <20210705104208.GA14891@lst.de> <20210705115349.GA20266@lst.de> <20210705130456.GA239714@dhcp-10-100-145-180.wdc.com> MIME-Version: 1.0 Content-Type: text/plain; charset=us-ascii Content-Disposition: inline In-Reply-To: Precedence: bulk List-ID: X-Mailing-List: linux-kernel@vger.kernel.org On Tue, Jul 06, 2021 at 08:14:45AM +0000, Shivamurthy Shastri (sshivamurthy) wrote: > > Is it the device that wants an abrupt shutdown or the platform? If the > > platform's power is running on limited back-up supply, and could inform > > the kernel's power management subsystem of this, then a driver could use > > that to determine if the quick shutdown is appropriate. > > Yes, the platform is running on limited back-up supply. In this case, abrupt shutdown > option will help to achieve shutdown with relatively low back-up requirements. > > Please let me know if you want to include the abrupt shutdown as part of > > static const struct dev_pm_ops nvme_dev_pm_ops = { > .suspend = nvme_suspend, > ..... Are you suggesting creating a new pm callback just for this? I don't think that's necessary. I was considering just adding a bit to the pm_suspend_global_flags, something like the patch below. You just have to fill in the platform specific parts to set the flag. --- diff --git a/include/linux/suspend.h b/include/linux/suspend.h index 8af13ba60c7e..f43c0b2313d0 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,21 @@ 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. */ --