Received: by 2002:ac0:bc90:0:0:0:0:0 with SMTP id a16csp1441800img; Tue, 19 Mar 2019 07:44:50 -0700 (PDT) X-Google-Smtp-Source: APXvYqw+9V7VUHz9+sCkB9Ue1+AEh6JmG5vi0iuXOBJzwaU9/gqUVXzlkNC4UdSyfGeUcLthVT+/ X-Received: by 2002:a17:902:7c0a:: with SMTP id x10mr2560884pll.224.1553006690309; Tue, 19 Mar 2019 07:44:50 -0700 (PDT) ARC-Seal: i=1; a=rsa-sha256; t=1553006690; cv=none; d=google.com; s=arc-20160816; b=QoR3ZusLRWvIYQ1lZB3cbTdRiNVs+3SXuSuRCer1jRBhjPVvZChh/pJLTVAivoXIde 53k6SaIIymwrVwk13r6tNQLXMvBSCzip/UOCGi1sTmItmCC7e36zApl98snS/bGhSC57 aKB9V/mceJc+lqCPZ98icn+qsNCp8liUVHeO1vXfBT8FikiWN0hBjzv4Fgb4nUCUuOmo uL5hvIJ3W+NJqoKOYp0l/BykGS9y0/YfDENKL54rG2bedegBz7eTxVkb/V+YFrd1Maq9 LILJ9be41cQStR4poFC6KknyPwcTBsD7LU7ogzRA90gp7Pkmrzy945z/OEvYaHcANGsy 0e7A== ARC-Message-Signature: i=1; a=rsa-sha256; c=relaxed/relaxed; d=google.com; s=arc-20160816; h=list-id:precedence:sender:references:in-reply-to:message-id:date :subject:cc:to:from; bh=BhC5KqJpcR55iCYPpqM1WY89RpTDfMQTNjC/L5xkGPc=; b=vjp7/bpK/5NXT935lnhOta6JHJTvlPNGn3WC9D/PvC9SER/liYB2hlbP/9P07hQiWW oxopwTi1OcBd42x4TjFHrscO0YP7p4a1FZaiwQwN1f48jU4bW1RADTqtgY4mj8NDPcls aMKhgl0VKB49CzztrMBnveiLFVDMf+aajiV+jWvwJ79/lmmo+0SpTBaXvuyQo9vF8yOy TC0+7pRJKnTG9B5TNCU6Jva3prvCAVqIYRBwAvvnlSONsL04KsEGL38Nl2CHPgrc/NMH RLfmXKLzAU0e9VgtJCZmO++twAB5myeQkOUkZZF5Z/wUF77rq+GoI1wlE7+Nu1gTUzrZ Z3/Q== ARC-Authentication-Results: i=1; mx.google.com; spf=pass (google.com: best guess record for domain of linux-kernel-owner@vger.kernel.org designates 209.132.180.67 as permitted sender) smtp.mailfrom=linux-kernel-owner@vger.kernel.org; dmarc=fail (p=NONE sp=NONE dis=NONE) header.from=redhat.com Return-Path: Received: from vger.kernel.org (vger.kernel.org. [209.132.180.67]) by mx.google.com with ESMTP id x6si11815640pfm.219.2019.03.19.07.44.35; Tue, 19 Mar 2019 07:44:50 -0700 (PDT) Received-SPF: pass (google.com: best guess record for domain of linux-kernel-owner@vger.kernel.org designates 209.132.180.67 as permitted sender) client-ip=209.132.180.67; Authentication-Results: mx.google.com; spf=pass (google.com: best guess record for domain of linux-kernel-owner@vger.kernel.org designates 209.132.180.67 as permitted sender) smtp.mailfrom=linux-kernel-owner@vger.kernel.org; dmarc=fail (p=NONE sp=NONE dis=NONE) header.from=redhat.com Received: (majordomo@vger.kernel.org) by vger.kernel.org via listexpand id S1727809AbfCSOma (ORCPT + 99 others); Tue, 19 Mar 2019 10:42:30 -0400 Received: from mx1.redhat.com ([209.132.183.28]:34114 "EHLO mx1.redhat.com" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S1727691AbfCSOm3 (ORCPT ); Tue, 19 Mar 2019 10:42:29 -0400 Received: from smtp.corp.redhat.com (int-mx06.intmail.prod.int.phx2.redhat.com [10.5.11.16]) (using TLSv1.2 with cipher AECDH-AES256-SHA (256/256 bits)) (No client certificate requested) by mx1.redhat.com (Postfix) with ESMTPS id AC4473082E67; Tue, 19 Mar 2019 14:42:28 +0000 (UTC) Received: from maximlenovopc.usersys.redhat.com (dhcp-4-67.tlv.redhat.com [10.35.4.67]) by smtp.corp.redhat.com (Postfix) with ESMTP id DA13F5C219; Tue, 19 Mar 2019 14:42:18 +0000 (UTC) From: Maxim Levitsky To: linux-nvme@lists.infradead.org Cc: Maxim Levitsky , linux-kernel@vger.kernel.org, kvm@vger.kernel.org, Jens Axboe , Alex Williamson , Keith Busch , Christoph Hellwig , Sagi Grimberg , Kirti Wankhede , "David S . Miller" , Mauro Carvalho Chehab , Greg Kroah-Hartman , Wolfram Sang , Nicolas Ferre , "Paul E . McKenney " , Paolo Bonzini , Liang Cunming , Liu Changpeng , Fam Zheng , Amnon Ilan , John Ferlan Subject: [PATCH 4/9] nvme/pci: use the NVME_CTRL_SUSPENDED state Date: Tue, 19 Mar 2019 16:41:11 +0200 Message-Id: <20190319144116.400-5-mlevitsk@redhat.com> In-Reply-To: <20190319144116.400-1-mlevitsk@redhat.com> References: <20190319144116.400-1-mlevitsk@redhat.com> X-Scanned-By: MIMEDefang 2.79 on 10.5.11.16 X-Greylist: Sender IP whitelisted, not delayed by milter-greylist-4.5.16 (mx1.redhat.com [10.5.110.46]); Tue, 19 Mar 2019 14:42:28 +0000 (UTC) Sender: linux-kernel-owner@vger.kernel.org Precedence: bulk List-ID: X-Mailing-List: linux-kernel@vger.kernel.org When enteriing low power state, the nvme driver will now inform the core with the NVME_CTRL_SUSPENDED state which will allow mdev driver to act on this information Signed-off-by: Maxim Levitsky --- drivers/nvme/host/pci.c | 6 +++++- 1 file changed, 5 insertions(+), 1 deletion(-) diff --git a/drivers/nvme/host/pci.c b/drivers/nvme/host/pci.c index 7fee665ec45e..a188ab6ffaf8 100644 --- a/drivers/nvme/host/pci.c +++ b/drivers/nvme/host/pci.c @@ -2451,7 +2451,8 @@ static void nvme_dev_disable(struct nvme_dev *dev, bool shutdown) u32 csts = readl(dev->bar + NVME_REG_CSTS); if (dev->ctrl.state == NVME_CTRL_LIVE || - dev->ctrl.state == NVME_CTRL_RESETTING) + dev->ctrl.state == NVME_CTRL_RESETTING || + dev->ctrl.state == NVME_CTRL_SUSPENDED) nvme_start_freeze(&dev->ctrl); dead = !!((csts & NVME_CSTS_CFS) || !(csts & NVME_CSTS_RDY) || pdev->error_state != pci_channel_io_normal); @@ -2897,6 +2898,9 @@ static int nvme_suspend(struct device *dev) struct pci_dev *pdev = to_pci_dev(dev); struct nvme_dev *ndev = pci_get_drvdata(pdev); + if (!nvme_change_ctrl_state(&ndev->ctrl, NVME_CTRL_SUSPENDED)) + WARN_ON(1); + nvme_dev_disable(ndev, true); return 0; } -- 2.17.2