From mboxrd@z Thu Jan 1 00:00:00 1970 Return-Path: X-Spam-Checker-Version: SpamAssassin 3.4.0 (2014-02-07) on aws-us-west-2-korg-lkml-1.web.codeaurora.org Received: from bombadil.infradead.org (bombadil.infradead.org [198.137.202.133]) (using TLSv1.2 with cipher ECDHE-RSA-AES256-GCM-SHA384 (256/256 bits)) (No client certificate requested) by smtp.lore.kernel.org (Postfix) with ESMTPS id 91EDFC6FD1B for ; Mon, 6 Mar 2023 14:54:07 +0000 (UTC) DKIM-Signature: v=1; a=rsa-sha256; q=dns/txt; c=relaxed/relaxed; d=lists.infradead.org; s=bombadil.20210309; h=Sender: Content-Transfer-Encoding:Content-Type:List-Subscribe:List-Help:List-Post: List-Archive:List-Unsubscribe:List-Id:In-Reply-To:MIME-Version:References: Message-ID:Subject:Cc:To:From:Date:Reply-To:Content-ID:Content-Description: Resent-Date:Resent-From:Resent-Sender:Resent-To:Resent-Cc:Resent-Message-ID: List-Owner; bh=FTv+Ur49PfAMEPweggiFtRHOx5BKnAPri1MFphpkPIg=; b=RR6y6+xyUVqSEF cBJCLpQBLDmkMY5jQ4pYbf+0rrvdxJ+P6w6seBOF+5pJocSzR7DAfq0nedYmFEI+g/Xka+atC7HLK 7zJethSHTuO+tFJFxpS+3+t2hZOvDd+bZPX5owwvfr3ykauwExxm9mX2yf3e54/dNpbnu26kE1d42 H1b30JtZU4hTS5noTSyK5Gm8E1F8UVH1Pi1Qcv4aS0mzHLdK6IIc+87UptsCXzmm5Lx+Cjby4OrUU 79T0s9OCRlih5XteZLwxWxecdsNYOKnxh4f5vHnHuW8voMvYZv11b37gFXNINRd37+xdYplswuOD5 SbV8or5ZM/rOF57f4xRQ==; Received: from localhost ([::1] helo=bombadil.infradead.org) by bombadil.infradead.org with esmtp (Exim 4.94.2 #2 (Red Hat Linux)) id 1pZCCo-00DReg-TI; Mon, 06 Mar 2023 14:52:51 +0000 Received: from foss.arm.com ([217.140.110.172]) by bombadil.infradead.org with esmtp (Exim 4.94.2 #2 (Red Hat Linux)) id 1pZC8F-00DPPX-E0 for linux-arm-kernel@lists.infradead.org; Mon, 06 Mar 2023 14:48:11 +0000 Received: from usa-sjc-imap-foss1.foss.arm.com (unknown [10.121.207.14]) by usa-sjc-mx-foss1.foss.arm.com (Postfix) with ESMTP id 505CC12FC; Mon, 6 Mar 2023 06:48:46 -0800 (PST) Received: from FVFF77S0Q05N (unknown [10.57.47.240]) by usa-sjc-imap-foss1.foss.arm.com (Postfix) with ESMTPSA id 788323F71A; Mon, 6 Mar 2023 06:48:01 -0800 (PST) Date: Mon, 6 Mar 2023 14:47:55 +0000 From: Mark Rutland To: Rakesh Babu Saladi Cc: lpieralisi@kernel.org, sudeep.holla@arm.com, linux-arm-kernel@lists.infradead.org, linux-kernel@vger.kernel.org, sgoutham@marvell.com, gcherian@marvell.com, naveenm@marvell.com Subject: Re: [PATCH] arm64: smccc: Add trace events to SMC calls. Message-ID: References: <20230304125850.32687-1-rsaladi2@marvell.com> MIME-Version: 1.0 Content-Disposition: inline In-Reply-To: <20230304125850.32687-1-rsaladi2@marvell.com> X-CRM114-Version: 20100106-BlameMichelson ( TRE 0.8.0 (BSD) ) MR-646709E3 X-CRM114-CacheID: sfid-20230306_064809_501469_A6360F7E X-CRM114-Status: GOOD ( 28.51 ) X-BeenThere: linux-arm-kernel@lists.infradead.org X-Mailman-Version: 2.1.34 Precedence: list List-Id: List-Unsubscribe: , List-Archive: List-Post: List-Help: List-Subscribe: , Content-Type: text/plain; charset="us-ascii" Content-Transfer-Encoding: 7bit Sender: "linux-arm-kernel" Errors-To: linux-arm-kernel-bounces+linux-arm-kernel=archiver.kernel.org@lists.infradead.org On Sat, Mar 04, 2023 at 06:28:50PM +0530, Rakesh Babu Saladi wrote: > This patch adds start and end trace events to an SMC call sent from > kernel to ATF. The start trace event prints the smc_id and the end > trace event prints the smc_id and the time taken to process the SMC > call. > > Signed-off-by: Rakesh Babu Saladi We've said no to this in the past: https://lore.kernel.org/lkml/20210923112058.GA14893@C02TD0UTHF1T.local/ I don't think anything has changed, and this has all the same problems as before, so I do not think we should do this. Which SMC calls do you want to trace, and why? Thanks, Mark. > --- > drivers/firmware/smccc/Makefile | 3 +- > drivers/firmware/smccc/smccc.c | 14 ++++++++++ > drivers/firmware/smccc/smccc_trace.c | 7 +++++ > drivers/firmware/smccc/smccc_trace.h | 41 ++++++++++++++++++++++++++++ > include/linux/arm-smccc.h | 4 ++- > kernel/time/timekeeping.c | 7 +++++ > 6 files changed, 74 insertions(+), 2 deletions(-) > create mode 100644 drivers/firmware/smccc/smccc_trace.c > create mode 100644 drivers/firmware/smccc/smccc_trace.h > > diff --git a/drivers/firmware/smccc/Makefile b/drivers/firmware/smccc/Makefile > index 40d19144a860..e74c35191b49 100644 > --- a/drivers/firmware/smccc/Makefile > +++ b/drivers/firmware/smccc/Makefile > @@ -1,4 +1,5 @@ > # SPDX-License-Identifier: GPL-2.0 > # > -obj-$(CONFIG_HAVE_ARM_SMCCC_DISCOVERY) += smccc.o kvm_guest.o > +ccflags-y += -I$(src) > +obj-$(CONFIG_HAVE_ARM_SMCCC_DISCOVERY) += smccc_trace.o smccc.o kvm_guest.o > obj-$(CONFIG_ARM_SMCCC_SOC_ID) += soc_id.o > diff --git a/drivers/firmware/smccc/smccc.c b/drivers/firmware/smccc/smccc.c > index 60ccf3e90d7d..7631a16479e9 100644 > --- a/drivers/firmware/smccc/smccc.c > +++ b/drivers/firmware/smccc/smccc.c > @@ -11,6 +11,7 @@ > #include > #include > #include > +#include "smccc_trace.h" > > static u32 smccc_version = ARM_SMCCC_VERSION_1_0; > static enum arm_smccc_conduit smccc_conduit = SMCCC_CONDUIT_NONE; > @@ -59,3 +60,16 @@ static int __init smccc_devices_init(void) > return 0; > } > device_initcall(smccc_devices_init); > + > +void arm_smccc_smc(unsigned long a0, unsigned long a1, unsigned long a2, unsigned long a3, > + unsigned long a4, unsigned long a5, unsigned long a6, unsigned long a7, > + struct arm_smccc_res *res) > +{ > + u64 start, elapsed; > + > + trace_arm_smccc_smc_start(a0); > + start = ktime_get_ns(); > + __arm_smccc_smc(a0, a1, a2, a3, a4, a5, a6, a7, res, NULL); > + elapsed = ktime_get_ns() - start; > + trace_arm_smccc_smc_end(a0, elapsed); > +} > diff --git a/drivers/firmware/smccc/smccc_trace.c b/drivers/firmware/smccc/smccc_trace.c > new file mode 100644 > index 000000000000..6b94d5d9c0f4 > --- /dev/null > +++ b/drivers/firmware/smccc/smccc_trace.c > @@ -0,0 +1,7 @@ > +// SPDX-License-Identifier: GPL-2.0 > + > +#define CREATE_TRACE_POINTS > +#include "smccc_trace.h" > + > +EXPORT_TRACEPOINT_SYMBOL(arm_smccc_smc_start); > +EXPORT_TRACEPOINT_SYMBOL(arm_smccc_smc_end); > diff --git a/drivers/firmware/smccc/smccc_trace.h b/drivers/firmware/smccc/smccc_trace.h > new file mode 100644 > index 000000000000..c0ef836bc093 > --- /dev/null > +++ b/drivers/firmware/smccc/smccc_trace.h > @@ -0,0 +1,41 @@ > +/* SPDX-License-Identifier: GPL-2.0 */ > + > +#undef TRACE_SYSTEM > +#define TRACE_SYSTEM smccc > + > +#if !defined(__SMCCC_TRACE_H) || defined(TRACE_HEADER_MULTI_READ) > +#define __SMCCC_TRACE_H > + > +#include > +#include > + > +TRACE_EVENT(arm_smccc_smc_start, > + TP_PROTO(unsigned long smc_id), > + TP_ARGS(smc_id), > + TP_STRUCT__entry(__field(unsigned long, smc_id)), > + TP_fast_assign(__entry->smc_id = smc_id;), > + TP_printk("SMC ID: 0x%lx", __entry->smc_id) > +); > + > +TRACE_EVENT(arm_smccc_smc_end, > + TP_PROTO(unsigned long smc_id, u64 elapsed_time), > + TP_ARGS(smc_id, elapsed_time), > + TP_STRUCT__entry(__field(unsigned long, smc_id) > + __field(u64, elapsed_time) > + ), > + TP_fast_assign(__entry->smc_id = smc_id; > + __entry->elapsed_time = elapsed_time; > + ), > + TP_printk("SMC ID: 0x%lx time taken to process : %llu ns", > + __entry->smc_id, __entry->elapsed_time) > +); > + > +#endif /* __SMCCC_TRACE_H */ > + > +#undef TRACE_INCLUDE_PATH > +#define TRACE_INCLUDE_PATH . > + > +#undef TRACE_INCLUDE_FILE > +#define TRACE_INCLUDE_FILE smccc_trace > + > +#include > diff --git a/include/linux/arm-smccc.h b/include/linux/arm-smccc.h > index 220c8c60e021..39588c3db486 100644 > --- a/include/linux/arm-smccc.h > +++ b/include/linux/arm-smccc.h > @@ -358,7 +358,9 @@ asmlinkage void __arm_smccc_hvc(unsigned long a0, unsigned long a1, > unsigned long a5, unsigned long a6, unsigned long a7, > struct arm_smccc_res *res, struct arm_smccc_quirk *quirk); > > -#define arm_smccc_smc(...) __arm_smccc_smc(__VA_ARGS__, NULL) > +void arm_smccc_smc(unsigned long a0, unsigned long a1, unsigned long a2, > + unsigned long a3, unsigned long a4, unsigned long a5, > + unsigned long a6, unsigned long a7, struct arm_smccc_res *res); > > #define arm_smccc_smc_quirk(...) __arm_smccc_smc(__VA_ARGS__) > > diff --git a/kernel/time/timekeeping.c b/kernel/time/timekeeping.c > index 5579ead449f2..3a3bf2d674a3 100644 > --- a/kernel/time/timekeeping.c > +++ b/kernel/time/timekeeping.c > @@ -192,6 +192,13 @@ static inline u64 tk_clock_read(const struct tk_read_base *tkr) > { > struct clocksource *clock = READ_ONCE(tkr->clock); > > + /* At the time of kernel booting some SMC calls are called before the > + * clock is initialized, in such cases it would lead to kernel crash. > + * To prevent kernel crash in such cases this check is included. > + */ > + if (unlikely(!clock)) > + return 0; > + > return clock->read(clock); > } > > -- > 2.17.1 > _______________________________________________ linux-arm-kernel mailing list linux-arm-kernel@lists.infradead.org http://lists.infradead.org/mailman/listinfo/linux-arm-kernel