Received: by 2002:a6b:500f:0:0:0:0:0 with SMTP id e15csp896605iob; Thu, 12 May 2022 07:02:14 -0700 (PDT) X-Google-Smtp-Source: ABdhPJyVEswnPZtNZdN7nMBTyeTmLD67b/ukafCr2COjdQfr3qtbgpIVe5/dn/zwBV4u+o+6f3a9 X-Received: by 2002:a17:90b:3445:b0:1d6:91a5:29fe with SMTP id lj5-20020a17090b344500b001d691a529femr11007871pjb.138.1652364133751; Thu, 12 May 2022 07:02:13 -0700 (PDT) ARC-Seal: i=1; a=rsa-sha256; t=1652364133; cv=none; d=google.com; s=arc-20160816; b=UUHofL3+0KQPWbeJlhjb4SL2sFii20+yindAIRazh6FwD/tP3/ru8iXWxL+oZmLrnQ 37XfcP44rCW6K1BVyjjU/vEsaAvE4/kL8nqhCOeXg8J+WqN6n0FiH9TRr6jYolVLAOTt F/EfoJqXDRSD5ukaZCEEhWieCNJYe630o3YmMFdDpeANv5e0+TmdKShobT9nZ56EKlLp R+qBNMOjjHChIZDUFnv6/kr9QDek3vhUpRkqmUkHT0RZjFGB6MeWqxDhSItaDVfH1Zh3 JAtTLrrDOpJi0lWdZ/PBBK0B9eA14CSlsbPykY5cfo4d9XR0n4AMWyHYPmPSK/0krM1k UmIQ== ARC-Message-Signature: i=1; a=rsa-sha256; c=relaxed/relaxed; d=google.com; s=arc-20160816; h=list-id:precedence:content-transfer-encoding:content-language :in-reply-to:mime-version:user-agent:date:message-id:from:references :cc:to:subject:dkim-signature; bh=ihAXayEBD4iXMJjgukB0dh5EYYszTi17H0GSx6sI52o=; b=sMuBbq2FWIEfWE+F2vrhL0eCDNGs1uokqAtF58GNiu5GEMM/qng8TGMKNTz5n5ui6v ubXS3z4TDtFWXoO0eZtvaK6UdzaUfWmdWDmoIDY48jfsA30I1anpmcYj7C8bUFD0mTwS NZv/sIFQrxqzx3xRLsHseN64CskN7MFqS9sGDylXq/K8MUVxsQKcUHuaYxGm9B3o4GxZ TLs1dfm1Z4hO6pwm8jNjWwS5pJdryPbhXtJTTT04X09HpFjjVeNvv/qGpAvRlGGT0xvs 0e5tVAB/7z3M22En9SbnGKLqgzWecQmlmnWbhPPqximUR091Oxbx4N3BSb6lA3Ph6yj3 8bJw== ARC-Authentication-Results: i=1; mx.google.com; dkim=pass header.i=@quicinc.com header.s=qcdkim header.b=qzOgoxht; spf=pass (google.com: domain of linux-kernel-owner@vger.kernel.org designates 2620:137:e000::1:20 as permitted sender) smtp.mailfrom=linux-kernel-owner@vger.kernel.org; dmarc=pass (p=NONE sp=NONE dis=NONE) header.from=quicinc.com Return-Path: Received: from out1.vger.email (out1.vger.email. [2620:137:e000::1:20]) by mx.google.com with ESMTP id mi1-20020a17090b4b4100b001d950ab2cfdsi3833951pjb.75.2022.05.12.07.01.58; Thu, 12 May 2022 07:02:13 -0700 (PDT) Received-SPF: pass (google.com: domain of linux-kernel-owner@vger.kernel.org designates 2620:137:e000::1:20 as permitted sender) client-ip=2620:137:e000::1:20; Authentication-Results: mx.google.com; dkim=pass header.i=@quicinc.com header.s=qcdkim header.b=qzOgoxht; spf=pass (google.com: domain of linux-kernel-owner@vger.kernel.org designates 2620:137:e000::1:20 as permitted sender) smtp.mailfrom=linux-kernel-owner@vger.kernel.org; dmarc=pass (p=NONE sp=NONE dis=NONE) header.from=quicinc.com Received: (majordomo@vger.kernel.org) by vger.kernel.org via listexpand id S1353303AbiELLXE (ORCPT + 99 others); Thu, 12 May 2022 07:23:04 -0400 Received: from lindbergh.monkeyblade.net ([23.128.96.19]:38726 "EHLO lindbergh.monkeyblade.net" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S1353374AbiELLVG (ORCPT ); Thu, 12 May 2022 07:21:06 -0400 Received: from alexa-out-sd-01.qualcomm.com (alexa-out-sd-01.qualcomm.com [199.106.114.38]) by lindbergh.monkeyblade.net (Postfix) with ESMTPS id BB56915E604; Thu, 12 May 2022 04:19:40 -0700 (PDT) DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/relaxed; d=quicinc.com; i=@quicinc.com; q=dns/txt; s=qcdkim; t=1652354380; x=1683890380; h=subject:to:cc:references:from:message-id:date: mime-version:in-reply-to:content-transfer-encoding; bh=ihAXayEBD4iXMJjgukB0dh5EYYszTi17H0GSx6sI52o=; b=qzOgoxhtmMiBU+QfM/dBlwEPPaXH8WkRer7uGslkdLQbnGrZ+uOzGfWz vwf2ARWiISLCeGlJutCu0InXxFzXrOjyTiIbQx8bsiWp3ByZiH7w9W7Cn v0tHl+Z7iuxK8w+NPzXpPJb1qBhl0v20r/b/AzmpxsppVCmn+k3XPKgPP o=; Received: from unknown (HELO ironmsg05-sd.qualcomm.com) ([10.53.140.145]) by alexa-out-sd-01.qualcomm.com with ESMTP; 12 May 2022 04:19:40 -0700 X-QCInternal: smtphost Received: from nasanex01c.na.qualcomm.com ([10.47.97.222]) by ironmsg05-sd.qualcomm.com with ESMTP/TLS/ECDHE-RSA-AES256-GCM-SHA384; 12 May 2022 04:19:40 -0700 Received: from nalasex01a.na.qualcomm.com (10.47.209.196) by nasanex01c.na.qualcomm.com (10.47.97.222) with Microsoft SMTP Server (version=TLS1_2, cipher=TLS_ECDHE_RSA_WITH_AES_256_GCM_SHA384) id 15.2.986.22; Thu, 12 May 2022 04:19:39 -0700 Received: from [10.79.43.230] (10.80.80.8) by nalasex01a.na.qualcomm.com (10.47.209.196) with Microsoft SMTP Server (version=TLS1_2, cipher=TLS_ECDHE_RSA_WITH_AES_256_GCM_SHA384) id 15.2.986.22; Thu, 12 May 2022 04:19:36 -0700 Subject: Re: [PATCH v2] mailbox: qcom-ipcc: Log the pending interrupt during resume To: Manivannan Sadhasivam CC: , , , , , Prasad Sodagudi References: <1652251404-30562-1-git-send-email-quic_sibis@quicinc.com> <20220512074312.GA35848@thinkpad> <5b8aa653-5af8-a54f-b7bd-4d758eac9019@quicinc.com> <20220512095952.GB35848@thinkpad> From: Sibi Sankar Message-ID: <76a15747-b06e-e869-078f-ac4ad2e4a5ec@quicinc.com> Date: Thu, 12 May 2022 16:49:30 +0530 User-Agent: Mozilla/5.0 (X11; Linux x86_64; rv:68.0) Gecko/20100101 Thunderbird/68.10.0 MIME-Version: 1.0 In-Reply-To: <20220512095952.GB35848@thinkpad> Content-Type: text/plain; charset="utf-8"; format=flowed Content-Language: en-US Content-Transfer-Encoding: 7bit X-Originating-IP: [10.80.80.8] X-ClientProxiedBy: nasanex01b.na.qualcomm.com (10.46.141.250) To nalasex01a.na.qualcomm.com (10.47.209.196) X-Spam-Status: No, score=-7.3 required=5.0 tests=BAYES_00,DKIM_SIGNED, DKIM_VALID,DKIM_VALID_AU,DKIM_VALID_EF,NICE_REPLY_A,RCVD_IN_DNSWL_MED, SPF_HELO_NONE,SPF_PASS,T_SCC_BODY_TEXT_LINE autolearn=ham autolearn_force=no version=3.4.6 X-Spam-Checker-Version: SpamAssassin 3.4.6 (2021-04-09) on lindbergh.monkeyblade.net Precedence: bulk List-ID: X-Mailing-List: linux-kernel@vger.kernel.org On 5/12/22 3:29 PM, Manivannan Sadhasivam wrote: > On Thu, May 12, 2022 at 03:08:43PM +0530, Sibi Sankar wrote: >> Hey Mani, >> >> Thanks for taking time to review the patch. >> >> On 5/12/22 1:13 PM, Manivannan Sadhasivam wrote: >>> On Wed, May 11, 2022 at 12:13:24PM +0530, Sibi Sankar wrote: >>>> From: Prasad Sodagudi >>>> >>>> Enable logging of the pending interrupt that triggered device wakeup. This >>>> logging information helps to debug IRQs that cause periodic device wakeups >>>> and prints the detailed information of pending IPCC interrupts instead of >>>> the generic "Resume caused by IRQ 17, ipcc". >>>> >>>> Scenario: Device wakeup caused by Modem crash >>>> Logs: >>>> qcom-ipcc mailbox: virq: 182 triggered client-id: 2; signal-id: 2 >>>> >>>> From the IPCC bindings it can further understood that the client here is >>>> IPCC_CLIENT_MPSS and the signal was IPCC_MPROC_SIGNAL_SMP2P. >>>> >>>> Signed-off-by: Prasad Sodagudi >>>> Signed-off-by: Sibi Sankar >>>> --- >>>> >>>> V2: >>>> * Fix build error when ipcc is a module [Kernel Test Bot] >>>> >>>> drivers/mailbox/qcom-ipcc.c | 27 +++++++++++++++++++++++++++ >>>> 1 file changed, 27 insertions(+) >>>> >>>> diff --git a/drivers/mailbox/qcom-ipcc.c b/drivers/mailbox/qcom-ipcc.c >>>> index c5d963222014..21c071ec119c 100644 >>>> --- a/drivers/mailbox/qcom-ipcc.c >>>> +++ b/drivers/mailbox/qcom-ipcc.c >>>> @@ -254,6 +254,28 @@ static int qcom_ipcc_setup_mbox(struct qcom_ipcc *ipcc, >>>> return devm_mbox_controller_register(dev, mbox); >>>> } >>>> +#ifdef CONFIG_PM_SLEEP >>> >>> You don't need this guard anymore. Please see below. >> >> ack >> >>> >>>> +static int qcom_ipcc_pm_resume(struct device *dev) >>>> +{ >>>> + struct qcom_ipcc *ipcc = dev_get_drvdata(dev); >>>> + u32 hwirq; >>>> + int virq; >>>> + >>>> + hwirq = readl(ipcc->base + IPCC_REG_RECV_ID); >>>> + if (hwirq == IPCC_NO_PENDING_IRQ) >>>> + return 0; >>>> + >>>> + virq = irq_find_mapping(ipcc->irq_domain, hwirq); >>>> + >>>> + dev_info(dev, "virq: %d triggered client-id: %ld; signal-id: %ld\n", virq, >>>> + FIELD_GET(IPCC_CLIENT_ID_MASK, hwirq), FIELD_GET(IPCC_SIGNAL_ID_MASK, hwirq)); >>>> + >>> >>> Does this really need to be dev_info? This looks like a dev_dbg() material to >>> me. >> >> The whole point of the log is to catch sporadic issues like random >> wakeups caused by remoteprocs through ipcc. We would just end up with >> a single line identifying the client id during resume if ipcc had indeed >> caused the wakeup else it wouldn't print anything. >> > > Right but that information is only required for debugging the periodic wakeups. > And that's not going to be useful for an end user. I would consider this an extension to "Resume caused by IRQ xx, xxxx" print that we get to identify the wake up source. That's the reasoning behind marking it as dev_info (being able to nail down random wakeups is just an added advantage). That said I'll re-spin it with dbg if that's the consensus. > > Thanks, > Mani > >> -Sibi >>> >>>> + return 0; >>>> +} >>>> +#else >>>> +#define qcom_ipcc_pm_resume NULL >>>> +#endif >>>> + >>>> static int qcom_ipcc_probe(struct platform_device *pdev) >>>> { >>>> struct qcom_ipcc *ipcc; >>>> @@ -324,6 +346,10 @@ static const struct of_device_id qcom_ipcc_of_match[] = { >>>> }; >>>> MODULE_DEVICE_TABLE(of, qcom_ipcc_of_match); >>>> +static const struct dev_pm_ops qcom_ipcc_dev_pm_ops = { >>>> + SET_NOIRQ_SYSTEM_SLEEP_PM_OPS(NULL, qcom_ipcc_pm_resume) >>>> +}; >>>> + >>>> static struct platform_driver qcom_ipcc_driver = { >>>> .probe = qcom_ipcc_probe, >>>> .remove = qcom_ipcc_remove, >>>> @@ -331,6 +357,7 @@ static struct platform_driver qcom_ipcc_driver = { >>>> .name = "qcom-ipcc", >>>> .of_match_table = qcom_ipcc_of_match, >>>> .suppress_bind_attrs = true, >>>> + .pm = &qcom_ipcc_dev_pm_ops, >>> >>> You can use the new pm_sleep_ptr() macro to avoid the PM_SLEEP guard. >>> >>> .pm = pm_sleep_ptr(&qcom_ipcc_dev_pm_ops), >> >> ack >> >>> >>> Thanks, >>> Mani >>> >>>> }, >>>> }; >>>> -- >>>> 2.7.4 >>>> >>> >