Received: by 2002:a05:6a10:a0d1:0:0:0:0 with SMTP id j17csp4663179pxa; Mon, 10 Aug 2020 15:03:02 -0700 (PDT) X-Google-Smtp-Source: ABdhPJygHq4nrSWOOnwd9QhPMF4odOruZGfuLYIEBDO8o7S+r/EaKRtjNclEG5RS+DOGDCEjj80E X-Received: by 2002:a17:906:c1c3:: with SMTP id bw3mr24729628ejb.8.1597096982461; Mon, 10 Aug 2020 15:03:02 -0700 (PDT) ARC-Seal: i=1; a=rsa-sha256; t=1597096982; cv=none; d=google.com; s=arc-20160816; b=j2lMdT6/OK+kxvz5WJuFCtLRrDIKpJRDErjUIJK55RMLJbgnJtVXmgUHoHi4EotdyN lv5sQTv5flPdpsKbfbeX7XNL+rFb/8mFhOwS4xsGRtqbQqgHxSzNaMRDrTj8aE7rORzj /z3DCZxzz1ajXSfeHCd9SWzpeyc2J6KOnj/RlBjiXRnO/xreqvoX1kx6MVcrNn7f4hJQ vMH8ceN3zmotCQK13cvSiWYu6e80d1Hp9Rt8ovveNRO8XQeVSVWvLpdCjbN9sqUj9bso huQ7+uZxno7ScWSN5KYPjtIwxdC0y4q9Vl+n+Vr6NNPgbE22c1B/11JAHhk8hs2+JuHA Bp1w== 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:dmarc-filter:dkim-signature; bh=hzCCILvdutEOoElZcexPsK0xDQiZOeHuVxRPtnS4sYA=; b=Oe3QSKApd8EpQqCBt0LcwSpI6wZ+6jtymx968TeqIPLc+pm43j7UzTT2/9YZpgTHnB 0eNIUUAig6fPkPt8HOqVfypf1r2A6bVhsaoMAK93cBdq/p8gibgdiq913+DIUOO+SX3n hnetA7WJXZBNY4yw9PU78dsxJAitiKxoES9sq4FuemO90ldZuej7+gmranDjH3zeCkS5 CtEXwSzk+iTNmwxb5T2DpMRr9yY/jXByqoAbYccGLyupX37IlxwLbh0EuRMOjMqWm0Yx lUGHmKynoNzAHqupWt79n9rJ64aA858xOl2AuEGP2WIKar4z63LwhB9xzKEuBL7DOFaH lNhA== ARC-Authentication-Results: i=1; mx.google.com; dkim=fail header.i=@mg.codeaurora.org header.s=smtp header.b=IFXvG6+U; 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 e1si11514236edn.361.2020.08.10.15.02.38; Mon, 10 Aug 2020 15:03:02 -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=IFXvG6+U; 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 S1726970AbgHJWBz (ORCPT + 99 others); Mon, 10 Aug 2020 18:01:55 -0400 Received: from m43-7.mailgun.net ([69.72.43.7]:33944 "EHLO m43-7.mailgun.net" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S1726897AbgHJWBy (ORCPT ); Mon, 10 Aug 2020 18:01:54 -0400 DKIM-Signature: a=rsa-sha256; v=1; c=relaxed/relaxed; d=mg.codeaurora.org; q=dns/txt; s=smtp; t=1597096913; h=References: In-Reply-To: Message-Id: Date: Subject: Cc: To: From: Sender; bh=hzCCILvdutEOoElZcexPsK0xDQiZOeHuVxRPtnS4sYA=; b=IFXvG6+UcGFPDywsx4fhtJ8ecmE5cCrHIApWq7zXgNB4zA/32H90OgkRbvvgffecWbvxMU0r s3NeJrjN0myRAOzr88ROnf/94sNxZhI08E7kzrRQVxg7HjlfqAVYdHJAdDoyR3O3jC0zFxMy LinR0nenW2UQYjQPWZDvXZlV4EM= X-Mailgun-Sending-Ip: 69.72.43.7 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 smtp-out-n03.prod.us-east-1.postgun.com with SMTP id 5f31c3ab85672017515f8425 (version=TLS1.2, cipher=TLS_ECDHE_RSA_WITH_AES_128_GCM_SHA256); Mon, 10 Aug 2020 22:01:15 GMT Received: by smtp.codeaurora.org (Postfix, from userid 1001) id CEF4BC433A0; Mon, 10 Aug 2020 22:01:14 +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,SPF_NONE autolearn=unavailable autolearn_force=no version=3.4.0 Received: from malabar-linux.qualcomm.com (i-global254.qualcomm.com [199.106.103.254]) (using TLSv1.2 with cipher ECDHE-RSA-AES128-SHA256 (128/128 bits)) (No client certificate requested) (Authenticated sender: bbhatt) by smtp.codeaurora.org (Postfix) with ESMTPSA id 1AA7DC433C9; Mon, 10 Aug 2020 22:01:14 +0000 (UTC) DMARC-Filter: OpenDMARC Filter v1.3.2 smtp.codeaurora.org 1AA7DC433C9 Authentication-Results: aws-us-west-2-caf-mail-1.web.codeaurora.org; dmarc=none (p=none dis=none) header.from=codeaurora.org Authentication-Results: aws-us-west-2-caf-mail-1.web.codeaurora.org; spf=none smtp.mailfrom=bbhatt@codeaurora.org From: Bhaumik Bhatt To: manivannan.sadhasivam@linaro.org Cc: linux-arm-msm@vger.kernel.org, hemantk@codeaurora.org, jhugo@codeaurora.org, linux-kernel@vger.kernel.org, Bhaumik Bhatt Subject: [PATCH v7 02/11] bus: mhi: core: Abort suspends due to outgoing pending packets Date: Mon, 10 Aug 2020 15:00:56 -0700 Message-Id: <1597096865-19636-3-git-send-email-bbhatt@codeaurora.org> X-Mailer: git-send-email 2.7.4 In-Reply-To: <1597096865-19636-1-git-send-email-bbhatt@codeaurora.org> References: <1597096865-19636-1-git-send-email-bbhatt@codeaurora.org> Sender: linux-kernel-owner@vger.kernel.org Precedence: bulk List-ID: X-Mailing-List: linux-kernel@vger.kernel.org Add the missing check to abort suspends if a client driver has pending outgoing packets to send to the device. This allows better utilization of the MHI bus wherein clients on the host are not left waiting for longer suspend or resume cycles to finish for data transfers. Signed-off-by: Bhaumik Bhatt Reviewed-by: Manivannan Sadhasivam --- drivers/bus/mhi/core/pm.c | 6 ++++-- 1 file changed, 4 insertions(+), 2 deletions(-) diff --git a/drivers/bus/mhi/core/pm.c b/drivers/bus/mhi/core/pm.c index 7960980..661d704 100644 --- a/drivers/bus/mhi/core/pm.c +++ b/drivers/bus/mhi/core/pm.c @@ -686,7 +686,8 @@ int mhi_pm_suspend(struct mhi_controller *mhi_cntrl) return -EIO; /* Return busy if there are any pending resources */ - if (atomic_read(&mhi_cntrl->dev_wake)) + if (atomic_read(&mhi_cntrl->dev_wake) || + atomic_read(&mhi_cntrl->pending_pkts)) return -EBUSY; /* Take MHI out of M2 state */ @@ -712,7 +713,8 @@ int mhi_pm_suspend(struct mhi_controller *mhi_cntrl) write_lock_irq(&mhi_cntrl->pm_lock); - if (atomic_read(&mhi_cntrl->dev_wake)) { + if (atomic_read(&mhi_cntrl->dev_wake) || + atomic_read(&mhi_cntrl->pending_pkts)) { write_unlock_irq(&mhi_cntrl->pm_lock); return -EBUSY; } -- The Qualcomm Innovation Center, Inc. is a member of the Code Aurora Forum, a Linux Foundation Collaborative Project