Received: by 2002:a25:ca44:0:0:0:0:0 with SMTP id a65csp162129ybg; Mon, 27 Jul 2020 19:05:11 -0700 (PDT) X-Google-Smtp-Source: ABdhPJw3tktHCEpnWQxwzRWe51YNuuujuywxfA0/GwzkFCUzebALpQvSqLQSJS3J2ePiyAreAPkb X-Received: by 2002:a17:906:1c84:: with SMTP id g4mr9578182ejh.59.1595901911280; Mon, 27 Jul 2020 19:05:11 -0700 (PDT) ARC-Seal: i=1; a=rsa-sha256; t=1595901911; cv=none; d=google.com; s=arc-20160816; b=HDwoC92r9RIB2D8DnLsEDDuULuArY4l2pd4SBeQ1iU6bLhFKHaIfZ8LYlKiFBuGllx /RwZCSJ4jaFwnIkyA9+j6OMfgabuz4/+fd3glto6auc6bl7M2/o9NM/pDg69plvfJS3i PFholKg2LYmj9itZzYh26vpMe2myeWZ6qtojoR0CH1QBOB1BTp/uJ6e4dXzxZIatnaMg 1K2h19nHqZP+O7fsZvmICVLM9HUfxMvQtlCrKnmR7a/tSQ4pHbk+NBsGC9jRFqTPokf0 sqlqIS9wFJzzcQZBCTfUQDhQsKDa2/y1oy0yxQUOFCbl3ZyyrpuKOErw0biPcPJbJyE1 FP7g== 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=UfC6aAHCyVDU86Mkps5HUi5MGAnkw4hGah8RJEqV3lOW/tQ53nMx3aoVJZT9yN0E11 Y7vaoJ+ofetSi+KRZ1GOFP7yiWwJAnPDZLBh59Emsf1HwZnLZkAZl/wpC9Bb5TU6NNdA /gvYScqpzw2ynzqjbG9A0EW77MNVBQUFsvVAc3J5zAVLnmVUn15mxPJ+0mVT9HyiWdvR dcsR9ZftnwR75b1KBR6RIYE3MahFtb5roPvscc3ToeX0qDa/ofImLlDgR1B5A/T9JRue y6PVL09Ivp8zL1CF/vdQVUA7SW4jnd2QqM4L7eQ9ktym+xoBt2x45uk5q05KUhJI4eEu 9gwg== ARC-Authentication-Results: i=1; mx.google.com; dkim=fail header.i=@mg.codeaurora.org header.s=smtp header.b="S/JbjKPi"; 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 b14si3384537eds.102.2020.07.27.19.04.48; Mon, 27 Jul 2020 19:05:11 -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="S/JbjKPi"; 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 S1727811AbgG1CD0 (ORCPT + 99 others); Mon, 27 Jul 2020 22:03:26 -0400 Received: from mail29.static.mailgun.info ([104.130.122.29]:38685 "EHLO mail29.static.mailgun.info" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S1726888AbgG1CD0 (ORCPT ); Mon, 27 Jul 2020 22:03:26 -0400 DKIM-Signature: a=rsa-sha256; v=1; c=relaxed/relaxed; d=mg.codeaurora.org; q=dns/txt; s=smtp; t=1595901805; h=References: In-Reply-To: Message-Id: Date: Subject: Cc: To: From: Sender; bh=hzCCILvdutEOoElZcexPsK0xDQiZOeHuVxRPtnS4sYA=; b=S/JbjKPi9VtUBoJ99O5ZEk9N2SzfKU4ehTk8f+ecKoCwKkquhGm8so52NzLNpJk+kDmNcn/v SE6ysLi5iaHL2Ew05he4c/WMq10UBnG/DoKwhP7AZhJ+ZU62EHplndXPU33hyxCkJPuf1SNj 5odmeonAWl0rKDOW+MRoMu3zTMo= X-Mailgun-Sending-Ip: 104.130.122.29 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-n15.prod.us-east-1.postgun.com with SMTP id 5f1f873936e6de324e3d6a40 (version=TLS1.2, cipher=TLS_ECDHE_RSA_WITH_AES_128_GCM_SHA256); Tue, 28 Jul 2020 02:02:33 GMT Received: by smtp.codeaurora.org (Postfix, from userid 1001) id 7CD89C433C6; Tue, 28 Jul 2020 02:02:32 +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, URIBL_BLOCKED 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 3D667C433CB; Tue, 28 Jul 2020 02:02:31 +0000 (UTC) DMARC-Filter: OpenDMARC Filter v1.3.2 smtp.codeaurora.org 3D667C433CB 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 v6 02/11] bus: mhi: core: Abort suspends due to outgoing pending packets Date: Mon, 27 Jul 2020 19:02:11 -0700 Message-Id: <1595901740-27379-3-git-send-email-bbhatt@codeaurora.org> X-Mailer: git-send-email 2.7.4 In-Reply-To: <1595901740-27379-1-git-send-email-bbhatt@codeaurora.org> References: <1595901740-27379-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