Received: by 2002:a05:7412:8d10:b0:f3:1519:9f41 with SMTP id bj16csp1071577rdb; Wed, 6 Dec 2023 07:54:50 -0800 (PST) X-Google-Smtp-Source: AGHT+IGBCBOoFWHc/4QcAn+8TqLhy2I6AHejMlwDCKdtKr7fJW3qkdNJMSGDaZu+qTssNTKb+JLL X-Received: by 2002:aa7:991a:0:b0:6ce:7926:c3e5 with SMTP id z26-20020aa7991a000000b006ce7926c3e5mr976331pff.63.1701878089793; Wed, 06 Dec 2023 07:54:49 -0800 (PST) ARC-Seal: i=1; a=rsa-sha256; t=1701878089; cv=none; d=google.com; s=arc-20160816; b=NDf/42WTRLe9IcrmSq8HVpcxG29+b75HyDiYdz/CtBofC6d8vcrkY1z1yv9bmN0PbC EKfWWUW0QnB0u/sJmZthk9eIyiqfcIUNaeYJs6B6DM1puiW7GovM1vD/j5A7EWEG5gw8 kzpchR5KCWEWnjf0ARovVNScW3956G4JpS2hqaWDi4ab4CviTQl6/aEWtkn/3bqFVvC7 G65LuLlDSU8aOGJlZJQxSvxNBTSyhN1AFJQm83MtteYgmZiPDaRdBGB9Oz6tLbRQV/eg fYt7x6aX/P7oiYlxZMpC1G16MadRIr7q1iK7Pksdez93huv0dBHucezhSDOjDmuUrJ7N sLWg== ARC-Message-Signature: i=1; a=rsa-sha256; c=relaxed/relaxed; d=google.com; s=arc-20160816; h=list-id:precedence:content-transfer-encoding:mime-version :references:in-reply-to:message-id:subject:cc:to:from:date; bh=6EXxDbfsuoLfbITo5H+YtVL/wPBsVP0+1IVT7eEpoGE=; fh=ai3M2rq+dbXmBX2v5gAlMXourqnspz4ZBTYkkKvCu+M=; b=IYfLfsVE+BPLF8+ZGhXzqfwxGVAPNzASn7sLnY/GstJkm/uqjyOowD7W5yQgEDcOMA VeTjN9sDlTilye0qpSJds7F2uV4UAY/z63l67n96t7PGlxZj+YLwvQ7oX+Q3Pl8r6hj1 qTQnN79ckqzQjSpYLdKNQp5B5wExwfbfEpFfWh1nNi1tBXiAv+Rc2HDU1tQJ+JGTsxBR rEas/wkx0s6CRXY/aDF76OZZZeClllWipYqXBAvpBI84OZ9lFkPQqFoOE6lR2H+oXpYL owwhYPyXuVw++qAN9N4/8byYIRs0yosdhGVXDXx6Uhz/knMZEXH/+9l42viIaRtOZq5Z nPmg== ARC-Authentication-Results: i=1; mx.google.com; spf=pass (google.com: domain of linux-kernel-owner@vger.kernel.org designates 23.128.96.35 as permitted sender) smtp.mailfrom=linux-kernel-owner@vger.kernel.org Return-Path: Received: from groat.vger.email (groat.vger.email. [23.128.96.35]) by mx.google.com with ESMTPS id y25-20020aa78059000000b006ce6d0550c3si121763pfm.395.2023.12.06.07.54.49 (version=TLS1_3 cipher=TLS_AES_256_GCM_SHA384 bits=256/256); Wed, 06 Dec 2023 07:54:49 -0800 (PST) Received-SPF: pass (google.com: domain of linux-kernel-owner@vger.kernel.org designates 23.128.96.35 as permitted sender) client-ip=23.128.96.35; Authentication-Results: mx.google.com; spf=pass (google.com: domain of linux-kernel-owner@vger.kernel.org designates 23.128.96.35 as permitted sender) smtp.mailfrom=linux-kernel-owner@vger.kernel.org Received: from out1.vger.email (depot.vger.email [IPv6:2620:137:e000::3:0]) by groat.vger.email (Postfix) with ESMTP id D3330802A3D2; Wed, 6 Dec 2023 07:54:46 -0800 (PST) X-Virus-Status: Clean X-Virus-Scanned: clamav-milter 0.103.11 at groat.vger.email Received: (majordomo@vger.kernel.org) by vger.kernel.org via listexpand id S1379433AbjLFPy3 (ORCPT + 99 others); Wed, 6 Dec 2023 10:54:29 -0500 Received: from lindbergh.monkeyblade.net ([23.128.96.19]:55888 "EHLO lindbergh.monkeyblade.net" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S1379416AbjLFPy2 (ORCPT ); Wed, 6 Dec 2023 10:54:28 -0500 Received: from smtp.kernel.org (relay.kernel.org [52.25.139.140]) by lindbergh.monkeyblade.net (Postfix) with ESMTPS id 5A9C3DC for ; Wed, 6 Dec 2023 07:54:34 -0800 (PST) Received: by smtp.kernel.org (Postfix) with ESMTPSA id B672CC433C8; Wed, 6 Dec 2023 15:54:32 +0000 (UTC) Date: Wed, 6 Dec 2023 10:55:00 -0500 From: Steven Rostedt To: Krishna chaitanya chundru Cc: Manivannan Sadhasivam , Masami Hiramatsu , , , , , , , , , Subject: Re: [PATCH v7] bus: mhi: host: Add tracing support Message-ID: <20231206105500.148ea367@gandalf.local.home> In-Reply-To: <20231206-ftrace_support-v7-1-aca49a04268b@quicinc.com> References: <20231206-ftrace_support-v7-1-aca49a04268b@quicinc.com> X-Mailer: Claws Mail 3.19.1 (GTK+ 2.24.33; x86_64-pc-linux-gnu) MIME-Version: 1.0 Content-Type: text/plain; charset=US-ASCII Content-Transfer-Encoding: 7bit X-Spam-Status: No, score=-0.8 required=5.0 tests=HEADER_FROM_DIFFERENT_DOMAINS, MAILING_LIST_MULTI,SPF_HELO_NONE,SPF_PASS,T_SCC_BODY_TEXT_LINE autolearn=unavailable autolearn_force=no version=3.4.6 X-Spam-Checker-Version: SpamAssassin 3.4.6 (2021-04-09) on groat.vger.email Precedence: bulk List-ID: X-Mailing-List: linux-kernel@vger.kernel.org X-Greylist: Sender passed SPF test, not delayed by milter-greylist-4.6.4 (groat.vger.email [0.0.0.0]); Wed, 06 Dec 2023 07:54:47 -0800 (PST) On Wed, 6 Dec 2023 21:12:57 +0530 Krishna chaitanya chundru wrote: > diff --git a/drivers/bus/mhi/host/init.c b/drivers/bus/mhi/host/init.c > index f78aefd2d7a3..6acb85f4c5f8 100644 > --- a/drivers/bus/mhi/host/init.c > +++ b/drivers/bus/mhi/host/init.c > @@ -20,6 +20,9 @@ > #include > #include "internal.h" > > +#define CREATE_TRACE_POINTS > +#include "trace.h" > + > static DEFINE_IDA(mhi_controller_ida); > > const char * const mhi_ee_str[MHI_EE_MAX] = { > diff --git a/drivers/bus/mhi/host/main.c b/drivers/bus/mhi/host/main.c > index dcf627b36e82..507cf3351a97 100644 > --- a/drivers/bus/mhi/host/main.c > +++ b/drivers/bus/mhi/host/main.c > @@ -15,6 +15,7 @@ > #include > #include > #include "internal.h" > +#include "trace.h" > > int __must_check mhi_read_reg(struct mhi_controller *mhi_cntrl, > void __iomem *base, u32 offset, u32 *out) > @@ -491,11 +492,9 @@ irqreturn_t mhi_intvec_threaded_handler(int irq_number, void *priv) > > state = mhi_get_mhi_state(mhi_cntrl); > ee = mhi_get_exec_env(mhi_cntrl); > - dev_dbg(dev, "local ee: %s state: %s device ee: %s state: %s\n", > - TO_MHI_EXEC_STR(mhi_cntrl->ee), > - mhi_state_str(mhi_cntrl->dev_state), > - TO_MHI_EXEC_STR(ee), mhi_state_str(state)); > > + trace_mhi_intvec_states(mhi_cntrl->mhi_dev->name, mhi_cntrl->ee, > + mhi_cntrl->dev_state, ee, state); I'm not sure if this was discussed before, but why not just pass in the mhi_cntrl pointer and do the assigning in the TRACE_EVENT() TP_fast_assign() portion? It will save on setting up the parameters. > if (state == MHI_STATE_SYS_ERR) { > dev_dbg(dev, "System error detected\n"); > pm_state = mhi_tryset_pm_state(mhi_cntrl, > @@ -832,6 +831,10 @@ int mhi_process_ctrl_ev_ring(struct mhi_controller *mhi_cntrl, > while (dev_rp != local_rp) { > enum mhi_pkt_type type = MHI_TRE_GET_EV_TYPE(local_rp); > > + trace_mhi_ctrl_event(mhi_cntrl->mhi_dev->name, local_rp, > + local_rp->ptr, local_rp->dword[0], > + local_rp->dword[1]); And here.. > + > switch (type) { > case MHI_PKT_TYPE_BW_REQ_EVENT: > { > @@ -997,6 +1000,9 @@ int mhi_process_data_event_ring(struct mhi_controller *mhi_cntrl, > while (dev_rp != local_rp && event_quota > 0) { > enum mhi_pkt_type type = MHI_TRE_GET_EV_TYPE(local_rp); > > + trace_mhi_data_event(mhi_cntrl->mhi_dev->name, local_rp, local_rp->ptr, > + local_rp->dword[0], local_rp->dword[1]); and here.. for the local_rp. Especially since you are just repeating what you send into the two events. You can consolidate it down to just adding that in the TP_fast_assign() of the shared DECLARE_EVENT_CLASS(). > + > chan = MHI_TRE_GET_EV_CHID(local_rp); > > WARN_ON(chan >= mhi_cntrl->max_chan); > @@ -1235,6 +1241,8 @@ int mhi_gen_tre(struct mhi_controller *mhi_cntrl, struct mhi_chan *mhi_chan, > mhi_tre->dword[0] = MHI_TRE_DATA_DWORD0(info->len); > mhi_tre->dword[1] = MHI_TRE_DATA_DWORD1(bei, eot, eob, chain); > > + trace_mhi_gen_tre(mhi_cntrl->mhi_dev->name, mhi_chan->chan, mhi_tre, > + mhi_tre->ptr, mhi_tre->dword[0], mhi_tre->dword[1]); Same here. You can pass in the mhi_tre pointer. > /* increment WP */ > mhi_add_ring_element(mhi_cntrl, tre_ring); > mhi_add_ring_element(mhi_cntrl, buf_ring); > @@ -1327,9 +1335,7 @@ static int mhi_update_channel_state(struct mhi_controller *mhi_cntrl, > enum mhi_cmd_type cmd = MHI_CMD_NOP; > int ret; > > - dev_dbg(dev, "%d: Updating channel state to: %s\n", mhi_chan->chan, > - TO_CH_STATE_TYPE_STR(to_state)); > - > + trace_mhi_channel_command_start(mhi_cntrl->mhi_dev->name, mhi_chan->chan, to_state); And here.. > switch (to_state) { > case MHI_CH_STATE_TYPE_RESET: > write_lock_irq(&mhi_chan->lock); > @@ -1396,9 +1402,7 @@ static int mhi_update_channel_state(struct mhi_controller *mhi_cntrl, > write_unlock_irq(&mhi_chan->lock); > } > > - dev_dbg(dev, "%d: Channel state change to %s successful\n", > - mhi_chan->chan, TO_CH_STATE_TYPE_STR(to_state)); > - > + trace_mhi_channel_command_end(mhi_cntrl->mhi_dev->name, mhi_chan->chan, to_state); and here.. Where you can also update the DECLARE_EVENT_CLASS() to directly access the mhi_cntrl and mhi_chan pointers. Sometimes it's better to do the dereference from inside the TP_fast_assign. That way, things like eprobes and bpf tracing can also have access to the full structure if needed. -- Steve