From patchwork Fri Jun 16 17:07:36 2017 Content-Type: text/plain; charset="utf-8" MIME-Version: 1.0 Content-Transfer-Encoding: 7bit X-Patchwork-Submitter: Jeremy Linton X-Patchwork-Id: 105756 Delivered-To: patch@linaro.org Received: by 10.140.91.77 with SMTP id y71csp1404496qgd; Fri, 16 Jun 2017 10:07:43 -0700 (PDT) X-Received: by 10.98.178.215 with SMTP id z84mr12135887pfl.71.1497632862988; Fri, 16 Jun 2017 10:07:42 -0700 (PDT) ARC-Seal: i=1; a=rsa-sha256; t=1497632862; cv=none; d=google.com; s=arc-20160816; b=h8oCT+x5R0YDqSXkJaLxjDKizXoZXrWdY2xXp2oXlVlK8SyRrWzRrTeUHAsQV85E1H 8Vem43qWmm+QZjqjAzc23Mnpgw88NJbVSXCnUH+VXMmdOIPr+DBt8BYkHD4qak2FCMMn bFrNqLI2l3rfjkiIyBJuqrONWBkcwlj9B2Oy22RYl86AX3/IjEZ9A98Bsq7Q4oT/+KvV WsL20jdABdz8SBjYd/YV/SiazdWiin8UECPFvPUjSv8h9XJRsms0dQ5CIwFV8W81bmSj DyGdPbUswYn2+aSPDF8/hVRrScl2iM/15I6dfm417wXJFXFzPGfI87mawh76th32MYjW yVDA== 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:arc-authentication-results; bh=tsGhzmSbmBnFYs0rvbKA08z0OKoA/Kco5oooSrgi6KE=; b=SYgf16uMuRnCSm29NtjpBZJO2K7m5BfYbzPUurYEYpnCwZIM76s/NfkBzX0UcWvvZq GKtVYuXXEghHvPH0mo3t2XVW7hrboEcZoovq/c7u0gEKsxecoaGw0efdFhIdVux3C575 135GQTNd0xitG/Bek5afP5/QtQSAM+xq4AL3emPdjg23qQk5gidpE37NnxI65/LTU63C SCcVrqEWYLqDApTJQg5QrUW7wBk1r3gxBWPrMeRPzvQaDEJRignImAwE63fwsZh94duZ bQejuvlHbLBG9iFD0QAx2Evfu9/mKMeVn33pJmMR49mj+juxmMlFP4mqonZXsVW8yR7V Xk+Q== ARC-Authentication-Results: i=1; mx.google.com; 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 Return-Path: Received: from vger.kernel.org (vger.kernel.org. [209.132.180.67]) by mx.google.com with ESMTP id j23si2377424pfj.308.2017.06.16.10.07.42; Fri, 16 Jun 2017 10:07:42 -0700 (PDT) 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; 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 Received: (majordomo@vger.kernel.org) by vger.kernel.org via listexpand id S1752420AbdFPRHk (ORCPT + 25 others); Fri, 16 Jun 2017 13:07:40 -0400 Received: from foss.arm.com ([217.140.101.70]:59768 "EHLO foss.arm.com" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S1750864AbdFPRHh (ORCPT ); Fri, 16 Jun 2017 13:07:37 -0400 Received: from usa-sjc-imap-foss1.foss.arm.com (unknown [10.72.51.249]) by usa-sjc-mx-foss1.foss.arm.com (Postfix) with ESMTP id 0D41915AD; Fri, 16 Jun 2017 10:07:37 -0700 (PDT) Received: from beelzebub.ast.arm.com (beelzebub.austin.arm.com [10.118.12.119]) by usa-sjc-imap-foss1.foss.arm.com (Postfix) with ESMTPA id C96633F41F; Fri, 16 Jun 2017 10:07:36 -0700 (PDT) From: Jeremy Linton To: rostedt@goodmis.org Cc: linux-kernel@vger.kernel.org, trivial@kernel.org Subject: [PATCH v2 2/2] tracing: Document the use of TRACE_DEFINE_SIZEOF Date: Fri, 16 Jun 2017 12:07:36 -0500 Message-Id: <20170616170736.25198-2-jeremy.linton@arm.com> X-Mailer: git-send-email 2.9.4 In-Reply-To: <20170616170736.25198-1-jeremy.linton@arm.com> References: <20170616170736.25198-1-jeremy.linton@arm.com> Sender: linux-kernel-owner@vger.kernel.org Precedence: bulk List-ID: X-Mailing-List: linux-kernel@vger.kernel.org The kernel now corrects the use of sizeof() in the trace format files. Lets document how to make use of that feature. Signed-off-by: Jeremy Linton --- samples/trace_events/trace-events-sample.h | 28 +++++++++++++++++++--------- 1 file changed, 19 insertions(+), 9 deletions(-) -- 2.9.4 diff --git a/samples/trace_events/trace-events-sample.h b/samples/trace_events/trace-events-sample.h index b385814..0b45272 100644 --- a/samples/trace_events/trace-events-sample.h +++ b/samples/trace_events/trace-events-sample.h @@ -225,26 +225,36 @@ TRACE_DEFINE_ENUM(TRACE_SAMPLE_FOO); TRACE_DEFINE_ENUM(TRACE_SAMPLE_BAR); TRACE_DEFINE_ENUM(TRACE_SAMPLE_ZOO); +/* + * The same problem as above applies to sizeof(), so there is also + * a macro to solve that problem. In the case show below, foo_bar/format + * contains a string "__print_array(...,sizeof(phys_addr_t))" for which + * the sizeof() result varies depending on the kernel. Adding the following + * macro decodes the size before transferring it to user space. + */ + +TRACE_DEFINE_SIZEOF(phys_addr_t); + TRACE_EVENT(foo_bar, - TP_PROTO(const char *foo, int bar, const int *lst, + TP_PROTO(const char *foo, int bar, const phys_addr_t *lst, const char *string, const struct cpumask *mask), TP_ARGS(foo, bar, lst, string, mask), TP_STRUCT__entry( - __array( char, foo, 10 ) - __field( int, bar ) - __dynamic_array(int, list, __length_of(lst)) - __string( str, string ) - __bitmask( cpus, num_possible_cpus() ) + __array( char, foo, 10 ) + __field( int, bar ) + __dynamic_array(phys_addr_t, list, __length_of(lst) ) + __string( str, string ) + __bitmask( cpus, num_possible_cpus() ) ), TP_fast_assign( strlcpy(__entry->foo, foo, 10); __entry->bar = bar; memcpy(__get_dynamic_array(list), lst, - __length_of(lst) * sizeof(int)); + __length_of(lst) * sizeof(phys_addr_t)); __assign_str(str, string); __assign_bitmask(cpus, cpumask_bits(mask), num_possible_cpus()); ), @@ -291,8 +301,8 @@ TRACE_EVENT(foo_bar, * This prints out the array that is defined by __array in a nice format. */ __print_array(__get_dynamic_array(list), - __get_dynamic_array_len(list) / sizeof(int), - sizeof(int)), + __get_dynamic_array_len(list) / sizeof(phys_addr_t), + sizeof(phys_addr_t)), __get_str(str), __get_bitmask(cpus)) );