Received: by 2002:a25:1985:0:0:0:0:0 with SMTP id 127csp1283510ybz; Fri, 1 May 2020 19:03:46 -0700 (PDT) X-Google-Smtp-Source: APiQypJyHHHhaJeFXIgpjE5LLknEz/fpzjWI4DfMUILKQBEO5r+97mGHhkMV1sofcK1ejLw3KWmf X-Received: by 2002:a50:8716:: with SMTP id i22mr5927267edb.248.1588385026757; Fri, 01 May 2020 19:03:46 -0700 (PDT) ARC-Seal: i=1; a=rsa-sha256; t=1588385026; cv=none; d=google.com; s=arc-20160816; b=Qkm/SpVBJjMOIQnguGJEA2ZS5CjjW3+9jCOizXrlXJNUrYKdEFt47NIzCH3afyUFrL NP3rjxuoy+m9AmyLn4lJdcHqlsOJmlVCqp35wbKMTxYk4Wv7PCXG1oiy1/Ytb1TDh50u fDzpXdvzQWArZ54uAxRJMMBq83ilpQl36RlXI3+eWCBT1lJGwxwJU5nC3sG7D8H0b+L/ UMz/0H7ZLX/r1h8J/oVWRtitnOwHz/UBVwzuWVuDJm2mzFdeItePeUeqPhPgpSQ9zg+S 96xeFwbxPnYrXph46AD+rROEpRSsxxT20r5+TvePtJArgCfB1efLR8P0HgRF9eb0VqFS l+pg== ARC-Message-Signature: i=1; a=rsa-sha256; c=relaxed/relaxed; d=google.com; s=arc-20160816; h=list-id:precedence:sender:user-agent:message-id:references :in-reply-to:subject:cc:to:from:date:content-transfer-encoding :mime-version:dkim-signature; bh=Y7zHbm62D06FuknuUOyxfzY9RDfUfaFg2lavUE/GVKc=; b=e3xHuGFTeFqOgRzJ4Cmpm4x+1UKIp6wrPIyhZMoRz72mq5Uw0gGX7JcKe2rnVaSm/D AXMZ8K2cZN28OWg86MHIN55Rx3MkMtq9NKefdi+DC1KwBPks11aQrJneUEnr4iHTxFGX n/LIdJNjoLy4lM01o/Z3OcL5IaeCCwZQTS0pSLdDgMwvEo8Q5lmtdO2MC/rQvrQGLlNQ iQ7xf/Ws8jc4wI9+d8WLMjejuIB/MoPT/XxMC2vy9YACEnbeQ/FOT3iqnm2GhR8vHjdW vr0xzgAMPsmyD7kpnyye0GLrO+M6UrOhnzqasPG1+OqXipNOtG0IQndOBWtWF/knVRgz HfHg== ARC-Authentication-Results: i=1; mx.google.com; dkim=fail header.i=@mg.codeaurora.org header.s=smtp header.b=tmCaMLGd; 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 Return-Path: Received: from vger.kernel.org (vger.kernel.org. [23.128.96.18]) by mx.google.com with ESMTP id a31si2588846ede.290.2020.05.01.19.03.23; Fri, 01 May 2020 19:03:46 -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=fail header.i=@mg.codeaurora.org header.s=smtp header.b=tmCaMLGd; 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 Received: (majordomo@vger.kernel.org) by vger.kernel.org via listexpand id S1726660AbgEBCAG (ORCPT + 99 others); Fri, 1 May 2020 22:00:06 -0400 Received: from mail26.static.mailgun.info ([104.130.122.26]:44272 "EHLO mail26.static.mailgun.info" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S1726323AbgEBCAG (ORCPT ); Fri, 1 May 2020 22:00:06 -0400 DKIM-Signature: a=rsa-sha256; v=1; c=relaxed/relaxed; d=mg.codeaurora.org; q=dns/txt; s=smtp; t=1588384805; h=Message-ID: References: In-Reply-To: Subject: Cc: To: From: Date: Content-Transfer-Encoding: Content-Type: MIME-Version: Sender; bh=Y7zHbm62D06FuknuUOyxfzY9RDfUfaFg2lavUE/GVKc=; b=tmCaMLGdcsdBVziotMaT2396UiQxPQIQSDUrBLFs24v61dnziJ+LPc8dWDV4lzSK295vDIE0 +FDayAyRqG6d8g+6W39XChnYTUAsC1pvyoNxYBQZOc3YPCZniBV4hRQ8zWJK0g1joRLTK4Ou YYdhnX0CsDZtCaKQflCbUZ4tdLE= X-Mailgun-Sending-Ip: 104.130.122.26 X-Mailgun-Sid: WyI0MWYwYSIsICJsaW51eC1rZXJuZWxAdmdlci5rZXJuZWwub3JnIiwgImJlOWU0YSJd Received: from smtp.codeaurora.org (ec2-35-166-182-171.us-west-2.compute.amazonaws.com [35.166.182.171]) by mxa.mailgun.org with ESMTP id 5eacd40b.7f82d4197880-smtp-out-n05; Sat, 02 May 2020 01:59:39 -0000 (UTC) Received: by smtp.codeaurora.org (Postfix, from userid 1001) id 05744C4478F; Sat, 2 May 2020 01:59:38 +0000 (UTC) X-Spam-Checker-Version: SpamAssassin 3.4.0 (2014-02-07) on aws-us-west-2-caf-mail-1.web.codeaurora.org X-Spam-Level: X-Spam-Status: No, score=-1.0 required=2.0 tests=ALL_TRUSTED autolearn=unavailable autolearn_force=no version=3.4.0 Received: from mail.codeaurora.org (localhost.localdomain [127.0.0.1]) (using TLSv1 with cipher ECDHE-RSA-AES256-SHA (256/256 bits)) (No client certificate requested) (Authenticated sender: cang) by smtp.codeaurora.org (Postfix) with ESMTPSA id 06328C433D2; Sat, 2 May 2020 01:59:38 +0000 (UTC) MIME-Version: 1.0 Content-Type: text/plain; charset=UTF-8; format=flowed Content-Transfer-Encoding: 8bit Date: Sat, 02 May 2020 09:59:37 +0800 From: Can Guo To: Bart Van Assche Cc: asutoshd@codeaurora.org, nguyenb@codeaurora.org, hongwus@codeaurora.org, rnayak@codeaurora.org, stanley.chu@mediatek.com, alim.akhtar@samsung.com, beanhuo@micron.com, Avri.Altman@wdc.com, bjorn.andersson@linaro.org, linux-scsi@vger.kernel.org, kernel-team@android.com, saravanak@google.com, salyzyn@google.com, "James E.J. Bottomley" , "Martin K. Petersen" , open list Subject: Re: [PATCH v3 1/1] scsi: pm: Balance pm_only counter of request queue during system resume In-Reply-To: <2356ab42-bbdd-d214-30f5-a533fe978dcb@acm.org> References: <1588219805-25794-1-git-send-email-cang@codeaurora.org> <9e15123e-4315-15cd-3d23-2df6144bd376@acm.org> <1ef85ee212bee679f7b2927cbbc79cba@codeaurora.org> <1e2a2e39dbb3a0f06fe95bbfd66e1648@codeaurora.org> <226048f7-6ad3-a625-c2ed-d9d13e096803@acm.org> <3bfa692ce706c5c198f565e674afb56f@codeaurora.org> <2356ab42-bbdd-d214-30f5-a533fe978dcb@acm.org> Message-ID: <5196eb909699044771fe58905c543626@codeaurora.org> X-Sender: cang@codeaurora.org User-Agent: Roundcube Webmail/1.3.9 Sender: linux-kernel-owner@vger.kernel.org Precedence: bulk List-ID: X-Mailing-List: linux-kernel@vger.kernel.org On 2020-05-02 01:56, Bart Van Assche wrote: > On 2020-04-30 22:12, Can Guo wrote: >> diff --git a/drivers/scsi/scsi_pm.c b/drivers/scsi/scsi_pm.c >> index 3717eea..d18271d 100644 >> --- a/drivers/scsi/scsi_pm.c >> +++ b/drivers/scsi/scsi_pm.c >> @@ -74,12 +74,15 @@ static int scsi_dev_type_resume(struct device >> *dev, >>  { >>         const struct dev_pm_ops *pm = dev->driver ? dev->driver->pm : >> NULL; >>         int err = 0; >> +       bool was_rpm_suspended = false; >> >>         err = cb(dev, pm); >>         scsi_device_resume(to_scsi_device(dev)); >>         dev_dbg(dev, "scsi resume: %d\n", err); >> >>         if (err == 0) { >> +               was_rpm_suspended = pm_runtime_suspended(dev); >> + > > How about renaming this variable into "was_runtime_suspended"? How > about > moving the declaration of that variable inside the if-statement? > Sure, shall do, this patch was just a prototype which I made for testing. If you are OK with this idea, I will send it as the next version. >>                 pm_runtime_disable(dev); >>                 err = pm_runtime_set_active(dev); >>                 pm_runtime_enable(dev); >> @@ -93,8 +96,10 @@ static int scsi_dev_type_resume(struct device *dev, >>                  */ >>                 if (!err && scsi_is_sdev_device(dev)) { >>                         struct scsi_device *sdev = >> to_scsi_device(dev); >> - >> -                       blk_set_runtime_active(sdev->request_queue); >> +                       if (was_rpm_suspended) >> +                              >> blk_post_runtime_resume(sdev->request_queue, 0); >> +                       else >> +                              >> blk_set_runtime_active(sdev->request_queue); >>                 } >>         } > > Does other code always call both blk_pre_runtime_resume() and > blk_post_runtime_resume() upon runtime resume? How about adding a > blk_pre_runtime_resume() call before the blk_post_runtime_resume() > call? > > Thanks, > > Bart. Yes, but adding a blk_pre_runtime_resume() here is meaningless, it only sets the q->rpm_status to RPM_RESUMING, blk_post_runtime_resume() overrides it to RPM_ACTIVE for sure. Besides, this place comes after the call of pm_runtime_set_active(), meaning sdev is already runtime active, in contrast with the real runtime resume routine, we can think it as the sdev's runtime resume ops has returned 0, so we can just call blk_post_runtime_resume(err=0). Thanks, Can Guo.