Received: by 2002:a25:ca44:0:0:0:0:0 with SMTP id a65csp162096ybg; Mon, 27 Jul 2020 19:05:07 -0700 (PDT) X-Google-Smtp-Source: ABdhPJy1UsyuZSwT53Gd3sXDjhIWgGz60Bo7SmBUGfYDeRqCcES46isPpJ3NtvNYhR1JUHkjehno X-Received: by 2002:a50:b941:: with SMTP id m59mr23274333ede.321.1595901906881; Mon, 27 Jul 2020 19:05:06 -0700 (PDT) ARC-Seal: i=1; a=rsa-sha256; t=1595901906; cv=none; d=google.com; s=arc-20160816; b=nqAegJqCsY1VhsXbj9gqsPU9zFu0nDy8RLGfu4KD662TIQwj7m4mmXz8TyUS10TawC ccAB0YfoDlV8lOnPAAsI2uORDfZ6DEKIYs+y66n6tb1jqdqnYrOaOsO56BbwutwFZYf5 4A+3kAPDjow2Rjil2jrfKP3tNrqQ8qQE22LlRbCOhoAbLDsWLM0B4vMtKB+6NEJU2y5U w8EsguEKAyjB9/i5i3eIHLemOKznWlkzFxWypaETLyAfm1soyc0YaXlZDUKUP6VdqVRd Mf+yvBG7qqNK6zv9B52/+bYG1jS9gyX1u2vc8lBtQBkvpXyyapPMFP0cHMqoteT13Oz1 /t1Q== 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=o5UhLrZrydyJ3t0RmJsueKJlTyvEuu5T2tAZ05lkoJA=; b=BB3K7q01d7PJA7DAfRr8DgRw3SxPd/0gGjiVdD9zo0keCCCRzgcQpZ5HKKfEYKqgUB mIG+7ypEnvZpLCak7yoZeQYQKeZsVcY6D83oM+QnFdcYPt0+ZKHPyx5kRlgBJdqhNGUK bdA/cldyrDi8VmcHquJBqeVrQ0AZSzYTLXOXqLYuIko8pQ0bTrqUGS78ZYeE71l6yDFh XdYT+Oj0Q4pQOHSwpJRdojyMj0yaxya2UQTSS8ZS+MJiprW41cNqRpdcLw/JCzl/+FID xeFZzo9NaVsybUA3Oal/WeTJax66Z52xtRIEFcK29S1GAWwZdzKaipHdi2lxXdiaNJfk DvaA== ARC-Authentication-Results: i=1; mx.google.com; dkim=fail header.i=@mg.codeaurora.org header.s=smtp header.b="rk1eQZ/m"; 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 t10si6921704edt.339.2020.07.27.19.04.44; Mon, 27 Jul 2020 19:05:06 -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="rk1eQZ/m"; 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 S1727797AbgG1CDP (ORCPT + 99 others); Mon, 27 Jul 2020 22:03:15 -0400 Received: from m43-7.mailgun.net ([69.72.43.7]:26802 "EHLO m43-7.mailgun.net" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S1727791AbgG1CDO (ORCPT ); Mon, 27 Jul 2020 22:03:14 -0400 DKIM-Signature: a=rsa-sha256; v=1; c=relaxed/relaxed; d=mg.codeaurora.org; q=dns/txt; s=smtp; t=1595901794; h=References: In-Reply-To: Message-Id: Date: Subject: Cc: To: From: Sender; bh=o5UhLrZrydyJ3t0RmJsueKJlTyvEuu5T2tAZ05lkoJA=; b=rk1eQZ/mIahLqGJR2GY8ZbW5KnkmCguWE9YwvwTslEwEOS4ETWe1GvecAnmf9i09bkH30OSf ED5bW4HC1ZXQGtbxeTUJgi/t+ZACJB4Vj4tChIpXPeIX7+CI8fzpMSJKoSouxby7KraRBogl eGNl//P1B8aaIQhNV2RKCnhJaIg= 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-n07.prod.us-east-1.postgun.com with SMTP id 5f1f873a7ab15087ebf24901 (version=TLS1.2, cipher=TLS_ECDHE_RSA_WITH_AES_128_GCM_SHA256); Tue, 28 Jul 2020 02:02:34 GMT Received: by smtp.codeaurora.org (Postfix, from userid 1001) id 0209DC4344A; Tue, 28 Jul 2020 02:02:34 +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=ham 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 65608C433C9; Tue, 28 Jul 2020 02:02:33 +0000 (UTC) DMARC-Filter: OpenDMARC Filter v1.3.2 smtp.codeaurora.org 65608C433C9 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 07/11] bus: mhi: core: Introduce counters to track MHI device state transitions Date: Mon, 27 Jul 2020 19:02:16 -0700 Message-Id: <1595901740-27379-8-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 Use counters to track MHI device state transitions such as those to M0, M2, or M3 states. This can help in better debug, allowing the user to see the number of transitions to a certain MHI state when queried using debugfs entries or via other mechanisms. Signed-off-by: Bhaumik Bhatt --- drivers/bus/mhi/core/pm.c | 4 ++++ include/linux/mhi.h | 2 ++ 2 files changed, 6 insertions(+) diff --git a/drivers/bus/mhi/core/pm.c b/drivers/bus/mhi/core/pm.c index 27bb471..ce4d969 100644 --- a/drivers/bus/mhi/core/pm.c +++ b/drivers/bus/mhi/core/pm.c @@ -256,6 +256,7 @@ int mhi_pm_m0_transition(struct mhi_controller *mhi_cntrl) dev_err(dev, "Unable to transition to M0 state\n"); return -EIO; } + mhi_cntrl->M0++; /* Wake up the device */ read_lock_bh(&mhi_cntrl->pm_lock); @@ -326,6 +327,8 @@ void mhi_pm_m1_transition(struct mhi_controller *mhi_cntrl) mhi_cntrl->dev_state = MHI_STATE_M2; write_unlock_irq(&mhi_cntrl->pm_lock); + + mhi_cntrl->M2++; wake_up_all(&mhi_cntrl->state_event); /* If there are any pending resources, exit M2 immediately */ @@ -362,6 +365,7 @@ int mhi_pm_m3_transition(struct mhi_controller *mhi_cntrl) return -EIO; } + mhi_cntrl->M3++; wake_up_all(&mhi_cntrl->state_event); return 0; diff --git a/include/linux/mhi.h b/include/linux/mhi.h index a8379b3..e38de6d 100644 --- a/include/linux/mhi.h +++ b/include/linux/mhi.h @@ -328,6 +328,7 @@ struct mhi_controller_config { * @dev_state: MHI device state * @dev_wake: Device wakeup count * @pending_pkts: Pending packets for the controller + * @M0, M2, M3, M3_fast: Counters to track number of device MHI state changes * @transition_list: List of MHI state transitions * @transition_lock: Lock for protecting MHI state transition list * @wlock: Lock for protecting device wakeup @@ -407,6 +408,7 @@ struct mhi_controller { enum mhi_state dev_state; atomic_t dev_wake; atomic_t pending_pkts; + u32 M0, M2, M3, M3_fast; struct list_head transition_list; spinlock_t transition_lock; spinlock_t wlock; -- The Qualcomm Innovation Center, Inc. is a member of the Code Aurora Forum, a Linux Foundation Collaborative Project