Received: by 2002:a25:8b91:0:0:0:0:0 with SMTP id j17csp1354721ybl; Fri, 6 Dec 2019 16:03:32 -0800 (PST) X-Google-Smtp-Source: APXvYqx21vjbFAQYwzC41aRHW7IK2PLZVWO80Ch076E9xwBec9OQLjNgycTPXUVFOhL2hY8gwpmi X-Received: by 2002:a9d:dc1:: with SMTP id 59mr5486870ots.250.1575677012430; Fri, 06 Dec 2019 16:03:32 -0800 (PST) ARC-Seal: i=1; a=rsa-sha256; t=1575677012; cv=none; d=google.com; s=arc-20160816; b=BuA1Tnkg8Kif0mxbY8f7xjZshYnV1x3cgYN3fmaX1x9jkbTFcfTvKayWREzeic0G+X eAu67ybIMQ42tNbqrAoJ/4L9wWZ6w7OVAfB+2TMm9zB67i6A8WlK8P/RDHY7wIRZ+5/N F4shl9CsaEsqKLOqdXT5uDeiqmei/ICxbBEcCElZMLS8m6PLilA6zT3d2aaObJD0bCAP sdCyKwplOj9jxipYXhe79sndGDeTmekeOlQsw52bv7QD+YD+jyXcPTtIs57H8EhAUCHC apbD/SIB8m57ooeJ5RWqBOHijZssqexi5O1nVHXXXA10mrUqWV2rNy84PbU0pel1Pu9q 7ZYQ== ARC-Message-Signature: i=1; a=rsa-sha256; c=relaxed/relaxed; d=google.com; s=arc-20160816; h=list-id:precedence:sender:content-transfer-encoding:mime-version :user-agent:references:in-reply-to:date:cc:to:from:subject :message-id:dkim-signature; bh=ixJ2guiJFyST+QNjHDaZ3Gsr09qezAlVsf/9Nyn+DyI=; b=msbYq0HDvEOF+uaAJK4kGppzhv3bkauMnCdbhQzXd4T2UgkbgDk84qPkk/oWCVDjwy GbCKMdHtXuz+DlHfxnDyIGZmWFAcWB3p7fMIDF/RC9h0ocRZ5l/FWuD7rFbYNJriav2l GIZIfaiCGOGkbEP7wEAWE5Rlu6g5zwykUTLbHX1ZnE88/XfRJrVAdOFm7h2CpIx4kvAt QSCu6Was0LWQ3MS7Pae6PSLyID5xXRtv62jPWBZDdlp1dcysWOd1vwBE7CCc9c91OEBt W8GGlk8bwjPfNLGJkKaQ/+GEBT9HfeiAqIVErfLR4n6+R7HJmetOICrA+0eEcegwWqMY bp7Q== ARC-Authentication-Results: i=1; mx.google.com; dkim=pass header.i=@st.com header.s=STMicroelectronics header.b=jXEl4dvi; spf=pass (google.com: best guess record for domain of linux-kernel-owner@vger.kernel.org designates 209.132.180.67 as permitted sender) smtp.mailfrom=linux-kernel-owner@vger.kernel.org; dmarc=pass (p=NONE sp=NONE dis=NONE) header.from=st.com Return-Path: Received: from vger.kernel.org (vger.kernel.org. [209.132.180.67]) by mx.google.com with ESMTP id x7si7707798oto.264.2019.12.06.16.03.21; Fri, 06 Dec 2019 16:03:32 -0800 (PST) Received-SPF: pass (google.com: best guess record for domain of linux-kernel-owner@vger.kernel.org designates 209.132.180.67 as permitted sender) client-ip=209.132.180.67; Authentication-Results: mx.google.com; dkim=pass header.i=@st.com header.s=STMicroelectronics header.b=jXEl4dvi; spf=pass (google.com: best guess record for domain of linux-kernel-owner@vger.kernel.org designates 209.132.180.67 as permitted sender) smtp.mailfrom=linux-kernel-owner@vger.kernel.org; dmarc=pass (p=NONE sp=NONE dis=NONE) header.from=st.com Received: (majordomo@vger.kernel.org) by vger.kernel.org via listexpand id S1726418AbfLGABv (ORCPT + 99 others); Fri, 6 Dec 2019 19:01:51 -0500 Received: from mx08-00178001.pphosted.com ([91.207.212.93]:9134 "EHLO mx07-00178001.pphosted.com" rhost-flags-OK-OK-OK-FAIL) by vger.kernel.org with ESMTP id S1726377AbfLGABu (ORCPT ); Fri, 6 Dec 2019 19:01:50 -0500 Received: from pps.filterd (m0046660.ppops.net [127.0.0.1]) by mx08-00178001.pphosted.com (8.16.0.42/8.16.0.42) with SMTP id xB6Nm0nE013830; Sat, 7 Dec 2019 01:01:11 +0100 DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/relaxed; d=st.com; h=message-id : subject : from : to : cc : date : in-reply-to : references : content-type : mime-version : content-transfer-encoding; s=STMicroelectronics; bh=ixJ2guiJFyST+QNjHDaZ3Gsr09qezAlVsf/9Nyn+DyI=; b=jXEl4dviICPpr/pxS+Fv1wCFCdrOwULIGj8Q1Kx7AGBDlI74Gx/TqXMJkXu/dq74NtaH 84ZzMOpTTMT19Qnyqnb3K128OreYWrN1mjF/1LuVaUaYnq35ChXDcqu0ryINvSBFL645 5BXJWaY9o+3nNr5lWDZxW3F4nDeXHauqmA9H4j42qiSP9fZWjnygS5eYymFOFwrBpuMA uwBTKxSbc15z8bmmIs2xQA6rgRrM2Zy/sOOFlt+wADrnqbZdYxKA23LAXKcGa2WK4MWW hxRcsEmkWfLkVFM3l9SA/k1uD/wxVgbd8klTjlxC9Y3uC8iETFb/AtckyBf6VsASYapu ZA== Received: from beta.dmz-eu.st.com (beta.dmz-eu.st.com [164.129.1.35]) by mx08-00178001.pphosted.com with ESMTP id 2wkeeajvft-1 (version=TLSv1.2 cipher=ECDHE-RSA-AES256-GCM-SHA384 bits=256 verify=NOT); Sat, 07 Dec 2019 01:01:11 +0100 Received: from euls16034.sgp.st.com (euls16034.sgp.st.com [10.75.44.20]) by beta.dmz-eu.st.com (STMicroelectronics) with ESMTP id 93B6F10002A; Sat, 7 Dec 2019 01:01:10 +0100 (CET) Received: from Webmail-eu.st.com (sfhdag5node3.st.com [10.75.127.15]) by euls16034.sgp.st.com (STMicroelectronics) with ESMTP id 4A2AE207581; Sat, 7 Dec 2019 01:01:10 +0100 (CET) Received: from lshz10676 (10.75.127.45) by SFHDAG5NODE3.st.com (10.75.127.15) with Microsoft SMTP Server (TLS) id 15.0.1473.3; Sat, 7 Dec 2019 01:01:09 +0100 Message-ID: <6b5b74cede87a61d5f04f2a95bc4389830467fe9.camel@st.com> Subject: Re: [PATCH] tracing: Fix printing ptrs in preempt/irq enable/disable events From: Antonio Borneo To: Joel Fernandes CC: Steven Rostedt , Ingo Molnar , , Date: Sat, 7 Dec 2019 01:00:51 +0100 In-Reply-To: <20191204160407.GB17404@google.com> References: <20191127154428.191095-1-antonio.borneo@st.com> <20191204160407.GB17404@google.com> Content-Type: text/plain; charset="UTF-8" User-Agent: Evolution 3.34.2 MIME-Version: 1.0 Content-Transfer-Encoding: 7bit X-Originating-IP: [10.75.127.45] X-ClientProxiedBy: SFHDAG7NODE1.st.com (10.75.127.19) To SFHDAG5NODE3.st.com (10.75.127.15) X-Proofpoint-Virus-Version: vendor=fsecure engine=2.50.10434:6.0.95,18.0.572 definitions=2019-12-06_08:2019-12-05,2019-12-06 signatures=0 Sender: linux-kernel-owner@vger.kernel.org Precedence: bulk List-ID: X-Mailing-List: linux-kernel@vger.kernel.org On Wed, 2019-12-04 at 11:04 -0500, Joel Fernandes wrote: > On Wed, Nov 27, 2019 at 04:44:28PM +0100, Antonio Borneo wrote: > > This tracing event class is the only instance in kernel that logs > > in the trace buffer the instruction pointer as offset to _stext, > > instead of logging the full pointer. > > This looks like a nice optimization for 64 bits platforms, where a > > 32 bit offset can take less space than a full 64 bits pointer. But > > the symbol _stext is incorrectly resolved as zero in the expansion > > I didn't get this. If _stext is 0 on any platform, then your patch doesn't > really do anything because the offset will be equal to the ip. > > Could you provide an example with real numbers showing the overflow? > Thanks for your reply. Easy to replicate, e.g. with a vanilla v5.4 on x86_64 make x86_64_defconfig echo CONFIG_PREEMPTIRQ_EVENTS=y >> .config make oldconfig; make At login: trace-cmd record -e preemptirq:irq_enable sleep 1 trace-cmd report trace.dat | head and I incorrectly get only the offsets to _stext: cpus=1 sleep-197 [000] 280.378022: irq_enable: caller=0x1afaS parent=0xc00091S sleep-197 [000] 280.378026: irq_enable: caller=0x54d34S parent=0x78e00000S sleep-197 [000] 280.378029: irq_enable: caller=0x1afaS parent=0xc00a84S sleep-197 [000] 280.378032: irq_enable: caller=0x263dS parent=0x78e00000S ... With this patch I get the expected/right result: cpus=1 sleep-210 [000] 525.177583: irq_enable: caller=trace_hardirqs_on_thunk parent=entry_SYSCALL_64_after_hwframe sleep-210 [000] 525.177587: irq_enable: caller=__do_page_fault parent=(nil)S sleep-210 [000] 525.177590: irq_enable: caller=trace_hardirqs_on_thunk parent=swapgs_restore_regs_and_return_to_usermode sleep-210 [000] 525.177593: irq_enable: caller=do_syscall_64 parent=(nil)S ... The same correct result can be obtained by hardcoding _stext in TP_printk() (of course, disabling KASLR to use fixed _stext), e.g. on x86_64: TP_printk("caller=%pS parent=%pS", - (void *)((unsigned long)(_stext) + __entry->caller_offs), - (void *)((unsigned long)(_stext) + __entry->parent_offs)) + (void *)(0xffffffff81000000UL + __entry->caller_offs), + (void *)(0xffffffff81000000UL + __entry->parent_offs)) ); The problem is caused by having the macros TP_fast_assign() and TP_printk() expanded in different way. The simpler expansion of the former macro resolves correctly the symbol _stext. The more complex expansion of the latter macro passes through some stringification that at the end incorrectly expands _stext as 0. At first I thought to fix the macro expansion of TP_printk(), but then I realized that: - on 32 bit systems there is no gain in coding 32 bit offset instead of 32 bit pointer - on 64 bit systems I cannot find a constraint that guarantees that modules are loaded within 32 bit offset from _stext then, this patch! > > of TP_printk(), which then prints only the hex offset instead of > > the name of the caller function. Plus, on arm arch the kernel > > modules are loaded at address lower than _stext, causing the u32 > > offset arithmetics to overflow and wrap at 32 bits. > > If we use signed 32-bit, will that solve the module issue? > Of course, on arm 32 bit using a signed offset would solve the 32 bit wraparound. > > I did not identified a 64 bit arch where the modules are loaded at > > offset from _stext that exceed u32 range, but I also did not > > identified any constraint to feel safe with a u32 offset. > > > > Log directly the instruction pointer instead of the offset to > > _stext. > > I am not comfortable with this patch at the moment, mainly because it will > increase the size of this rather high frequency event. But I'm not saying > there isn't an issue on 32-bit. Let's discuss more. > Sure, the pressure on the trace buffer will increase on a 64 bit system, but in general it also has more memory than an embedded 32 bit system. The key point is, instead, can we feel safe with a 32 bit offset in a 64 bit system? Is there any guarantee a module is loaded within 32 bits offset from _stext? Antonio > thanks, > > - Joel > > > > Signed-off-by: Antonio Borneo > > Fixes: d59158162e03 ("tracing: Add support for preempt and irq enable/disable events") > > --- > > include/trace/events/preemptirq.h | 12 ++++++------ > > 1 file changed, 6 insertions(+), 6 deletions(-) > > > > diff --git a/include/trace/events/preemptirq.h b/include/trace/events/preemptirq.h > > index 95fba0471e5b..d548a6aafa18 100644 > > --- a/include/trace/events/preemptirq.h > > +++ b/include/trace/events/preemptirq.h > > @@ -18,18 +18,18 @@ DECLARE_EVENT_CLASS(preemptirq_template, > > TP_ARGS(ip, parent_ip), > > > > TP_STRUCT__entry( > > - __field(u32, caller_offs) > > - __field(u32, parent_offs) > > + __field(unsigned long, caller_ip) > > + __field(unsigned long, parent_ip) > > ), > > > > TP_fast_assign( > > - __entry->caller_offs = (u32)(ip - (unsigned long)_stext); > > - __entry->parent_offs = (u32)(parent_ip - (unsigned long)_stext); > > + __entry->caller_ip = ip; > > + __entry->parent_ip = parent_ip; > > ), > > > > TP_printk("caller=%pS parent=%pS", > > - (void *)((unsigned long)(_stext) + __entry->caller_offs), > > - (void *)((unsigned long)(_stext) + __entry->parent_offs)) > > + (void *)__entry->caller_ip, > > + (void *)__entry->parent_ip) > > ); > > > > #ifdef CONFIG_TRACE_IRQFLAGS > > -- > > 2.24.0 > >