Received: by 2002:a05:6902:102b:0:0:0:0 with SMTP id x11csp2973833ybt; Mon, 29 Jun 2020 11:52:20 -0700 (PDT) X-Google-Smtp-Source: ABdhPJwk5yeYDJcyHSELWJiCzfdg+1bpEiJdeE9OyKwotO0Sn4y8HKD7qqkcG6yzBe6/2KFzhWcl X-Received: by 2002:a50:9f6a:: with SMTP id b97mr18630559edf.322.1593456739981; Mon, 29 Jun 2020 11:52:19 -0700 (PDT) ARC-Seal: i=1; a=rsa-sha256; t=1593456739; cv=none; d=google.com; s=arc-20160816; b=v2Bd5Kg2HbbWwdcCI+X1+z99N/kQpBkrSODBlgUVHYf5jx0Aa3myrW+fJdGP5fyivo s6L3CpQcq5w+EgGZmfrRuT2g+RwQBUWi/hxVw0mxHd9IEJ6XasVZrUbzatevpKdGZxwE 7zSHXP9nMQM23nvoDpD6b7WFwWF5KaPLboiJqoFiYgPUbm7zmfA5xiyLW1HAs8BwAl0M qnwg0tdbSzak1MY2gsckyJUGJHA0LCIaxsybuttgY7Fj4KZ1wP7BMHwEm6rGy/0G7fGH Mw3GTswUzNcIY9jZZIeWG4cwLF+U1eUb+vvEvwrxxldRr1v3wM2/zDO8XUm/9+qxmLia q9fg== 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=j1u5QBULuJKFUyNxaQAkdzuQVerFj62srXNJ8V0Lrak=; b=v0ouSu53ahx7hFnfNkQkI2EacO4FHBst+SyS8v+nmImbrCzGVaMhyfUiSVDtzwjHBx Gp/aD6O51xEMDuz1qQg05moMdUHnChFapaONWz2f4rMhhG6evt/pF1sWf8Q31B1a/0Qi TKUf52EXn7RvcFa7XE9KuvQLMby7M+MqFCPm7Dp8EnL8m8PJFcz11ga71rBBfZarH1/w K+X7qmMvAeLoyg+EYvcjf6dyvCb3uhnd2fP0WH7nQjwkUHCdFQ2PdEfXIpSXCGOGSEaD G8iCx4qX5eBhgr92XrN92WN4R4SHYKVoMunMtcTwjIEOH+bgQCZ4NmcO3hdsc94XqfrJ 6kgQ== ARC-Authentication-Results: i=1; mx.google.com; dkim=fail header.i=@mg.codeaurora.org header.s=smtp header.b=Iw9YeMPR; 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 dn16si310921ejc.427.2020.06.29.11.51.56; Mon, 29 Jun 2020 11:52:19 -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=Iw9YeMPR; 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 S1729677AbgF2Svv (ORCPT + 99 others); Mon, 29 Jun 2020 14:51:51 -0400 Received: from m43-7.mailgun.net ([69.72.43.7]:61738 "EHLO m43-7.mailgun.net" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S1727073AbgF2Svo (ORCPT ); Mon, 29 Jun 2020 14:51:44 -0400 DKIM-Signature: a=rsa-sha256; v=1; c=relaxed/relaxed; d=mg.codeaurora.org; q=dns/txt; s=smtp; t=1593456704; h=References: In-Reply-To: Message-Id: Date: Subject: Cc: To: From: Sender; bh=j1u5QBULuJKFUyNxaQAkdzuQVerFj62srXNJ8V0Lrak=; b=Iw9YeMPR/GP7xHQg/vE0nTGBNjF3pEGHUQ2YWt41ZQI3p6VI8YWAxsSWIqq5GSScTL7KDYQj c7ETvHEqO6lMrLSzC6mCn24jTRUY5tEqX89qAowS0cDIyNnqcyTzez4+yKC6wSbgCXZPj3Ke f5rtsrB77AOQKD6QGDv7b4ru/a8= 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-n18.prod.us-west-2.postgun.com with SMTP id 5efa19593a8a8b20b8968ca8 (version=TLS1.2, cipher=TLS_ECDHE_RSA_WITH_AES_128_GCM_SHA256); Mon, 29 Jun 2020 16:39:53 GMT Received: by smtp.codeaurora.org (Postfix, from userid 1001) id 59024C433C8; Mon, 29 Jun 2020 16:39:53 +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 A60C5C43391; Mon, 29 Jun 2020 16:39:52 +0000 (UTC) DMARC-Filter: OpenDMARC Filter v1.3.2 smtp.codeaurora.org A60C5C43391 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 v4 2/9] bus: mhi: core: Abort suspends due to outgoing pending packets Date: Mon, 29 Jun 2020 09:39:35 -0700 Message-Id: <1593448782-8385-3-git-send-email-bbhatt@codeaurora.org> X-Mailer: git-send-email 2.7.4 In-Reply-To: <1593448782-8385-1-git-send-email-bbhatt@codeaurora.org> References: <1593448782-8385-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 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 --- 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