Return-Path: Received: (majordomo@vger.kernel.org) by vger.kernel.org via listexpand id S1758375Ab0LMRJd (ORCPT ); Mon, 13 Dec 2010 12:09:33 -0500 Received: from mail-ey0-f171.google.com ([209.85.215.171]:38036 "EHLO mail-ey0-f171.google.com" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S1753739Ab0LMRJb (ORCPT ); Mon, 13 Dec 2010 12:09:31 -0500 DomainKey-Signature: a=rsa-sha1; c=nofws; d=gmail.com; s=gamma; h=date:from:to:cc:subject:message-id:references:mime-version :content-type:content-disposition:in-reply-to:user-agent; b=VVl8EzbeMRiO5Z0WpIJvtvqRrU9PpZ/4dqCSPgbbmZgWhpbGUC3y8xT79RTLwRYLry rgdArPdgbb2fOBKMdpkmPgIBQQVAceEQLKBPa1RQdONgpfs/oXRg3qlMqCVaiJr0OR1w JXHAGyeFSWAjgdsoxlV/5eHcAxIewfstTfhl8= Date: Mon, 13 Dec 2010 18:09:26 +0100 From: Frederic Weisbecker To: Arnaldo Carvalho de Melo , Peter Zijlstra Cc: "David S. Ahern" , linux-perf-users@vger.kernel.org, linux-kernel@vger.kernel.org Subject: Re: [PATCH 1/2] perf tools: Add reference timestamp to perf header Message-ID: <20101213170923.GB1691@nowhere> References: <1291773285-16254-1-git-send-email-daahern@cisco.com> <1291773285-16254-2-git-send-email-daahern@cisco.com> <20101212201613.GA1784@nowhere> <4D06301C.2090309@cisco.com> <20101213155451.GA1691@nowhere> <20101213164854.GL5407@ghostprotocols.net> MIME-Version: 1.0 Content-Type: text/plain; charset=us-ascii Content-Disposition: inline In-Reply-To: <20101213164854.GL5407@ghostprotocols.net> User-Agent: Mutt/1.5.20 (2009-06-14) Sender: linux-kernel-owner@vger.kernel.org List-ID: X-Mailing-List: linux-kernel@vger.kernel.org Content-Length: 2510 Lines: 69 On Mon, Dec 13, 2010 at 02:48:54PM -0200, Arnaldo Carvalho de Melo wrote: > Em Mon, Dec 13, 2010 at 04:54:56PM +0100, Frederic Weisbecker escreveu: > > On Mon, Dec 13, 2010 at 07:39:24AM -0700, David S. Ahern wrote: > > > On 12/12/10 13:16, Frederic Weisbecker wrote: > > > >> int perf_session__create_kernel_maps(struct perf_session *self) > > > >> { > > > >> int ret = machine__create_kernel_maps(&self->host_machine); > > > >> @@ -167,6 +190,9 @@ struct perf_session *perf_session__new(const char *filename, int mode, bool forc > > > >> */ > > > >> if (perf_session__create_kernel_maps(self) < 0) > > > >> goto out_delete; > > > >> + > > > >> + if (perf_session__create_ref_time(self) < 0) > > > >> + goto out_delete; > > > > > So, it does record it anytime? > > > > Simplest to always add it the header as it does no harm if not used. > > > To make it conditional means adding an input parameter to > > > perf_session__new() and then updating all the callers. > > > > Is the preference to make it conditional? > > > No, I suspect the overhead is plain unnoticeable. And if it becomes > > any problem one day, we can still make that conditional later. > > Right, but it just ocurred to me, can't we encode this in the file stat? > Also, how do we deal with: > > $ perf record --help > > -A, --append > Append to the output file to do incremental profiling. > > > ? > > I now think this should be implemented as a PERF_RECORD_WALL_CLOCK > synthesized event, to be inserted just before we start collecting the > other events. > > That way, when --appending, we just insert another and use that from > that point on. > > Look at tools/perf/util/event.h, enum perf_user_event_type and look how > those are synthesized. > > Thanks, > > - Arnaldo (Adding peterz) Right, but Peter wanted us to get rid of these user events types. I guess we can't really do this as new perf tools must be able to support old perf files. So this should be the last one to add. Something like PERF_RECORD_GEN_EVT that has a field in its headers containing a sub-type which can be this wall clock but can also host about everything in the future. This way we don't propagate more the possible overlap with the kernel. Hm? -- To unsubscribe from this list: send the line "unsubscribe linux-kernel" in the body of a message to majordomo@vger.kernel.org More majordomo info at http://vger.kernel.org/majordomo-info.html Please read the FAQ at http://www.tux.org/lkml/