From mboxrd@z Thu Jan 1 00:00:00 1970 Return-Path: Received: (majordomo@vger.kernel.org) by vger.kernel.org via listexpand id S1756356AbZDQGXA (ORCPT ); Fri, 17 Apr 2009 02:23:00 -0400 Received: (majordomo@vger.kernel.org) by vger.kernel.org id S1753003AbZDQGWw (ORCPT ); Fri, 17 Apr 2009 02:22:52 -0400 Received: from bombadil.infradead.org ([18.85.46.34]:56940 "EHLO bombadil.infradead.org" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S1751942AbZDQGWv (ORCPT ); Fri, 17 Apr 2009 02:22:51 -0400 Subject: Re: [PATCH 1/2 v2] tracing/events: provide string with undefined size support From: Peter Zijlstra To: =?ISO-8859-1?Q?Fr=E9d=E9ric?= Weisbecker Cc: Ingo Molnar , Steven Rostedt , Zhaolei , Tom Zanussi , Li Zefan , KOSAKI Motohiro , LKML In-Reply-To: References: <1239912047-6282-1-git-send-email-fweisbec@gmail.com> <1239912812.23397.3432.camel@laptop> Content-Type: text/plain; charset="UTF-8" Date: Fri, 17 Apr 2009 08:22:40 +0200 Message-Id: <1239949360.23397.4065.camel@laptop> Mime-Version: 1.0 X-Mailer: Evolution 2.26.0 Content-Transfer-Encoding: 8bit Sender: linux-kernel-owner@vger.kernel.org List-ID: X-Mailing-List: linux-kernel@vger.kernel.org On Thu, 2009-04-16 at 22:28 +0200, Frédéric Weisbecker wrote: > 2009/4/16 Peter Zijlstra : > > On Thu, 2009-04-16 at 22:00 +0200, Frederic Weisbecker wrote: > >> Impact: less memory usage for tracing > >> > >> This patch provides the support for dynamic size strings on > >> event tracing. > >> > >> The key concept is to use a structure with an ending char array field of > >> undefined size and use such ability to allocate the minimal size on the ring > >> buffer to make the entry fit inside as opposite to a fixed length strings with > >> upper bound. > >> > >> This patch provides one new macro: > >> > >> -__ending_string(name, src) > >> > >> This one declares the string to the structure inside TP_STRUCT__entry. > >> You need to provide the name of the string field and the source that will be > >> copied inside. > >> Two constraints: only one __ending_string() per TRACE_EVENT can be added and > >> it must be the last field to be declared. Hence the __ending prefix. > >> > >> This macro will declare the necessary field and will also add the dynamic > >> size of the string needed for the ring buffer entry allocation. > >> > >> It also support filtering because these strings behave essentially > >> like usual fixed length string. > > > > can't we simply do __string(name, src) and output something like: > > > > struct { > > u16 size; > > char str[0]; > > } name; > > > > That would get rid of this __ending_ wart. > > > > > > Hmm, I don't understand. > Such a thing doesn't seem to work. Once we fill the string it would > override the fields that > follow it if it's not at the end. Just grow the thing to fit whatever string length -- rather common pattern: struct foo { int length; char data[0]; }; struct foo *bar = kmalloc(sizeof(struct foo) + data_size); and bob's your uncle.