Received: by 2002:a05:6a10:16a7:0:0:0:0 with SMTP id gp39csp3823332pxb; Tue, 17 Nov 2020 04:39:53 -0800 (PST) X-Google-Smtp-Source: ABdhPJwkEKcQvOxvliGkwiw4Sm3rnh85CJM0uiCC9xLSM+RAf5kQJ1rahBKyR6oQbdj1J/HDHs+h X-Received: by 2002:a17:906:af47:: with SMTP id ly7mr20148057ejb.532.1605616793330; Tue, 17 Nov 2020 04:39:53 -0800 (PST) ARC-Seal: i=1; a=rsa-sha256; t=1605616793; cv=none; d=google.com; s=arc-20160816; b=0Bqau394917KYk1f5qWyc1dx3Uc6nXVqYynmMGRBNJpi8aWOE36Wud7jj5hkAObHOG EbQQVSAj3d0KFDn6sGQc63PP/IeS/OkUYPfLH5Nx+uYhh3QygVZn715OArrTPy7bg4// LAb1oI/3CM1Bf3vN40ige4jOoXz9x1fmM3puyrruR0X+L+SxFvor7GmQ9NgRrLMwvC8R imVHOpjh+eni1gl0y2b4sVq2l4tjlMfYYiJQbe+zQB1rzWizKH+XFmRJYD0kygmH+24j NFejFXqL9mdgL+u5sgUM/pw0xjNXOKJbSb8ic4fOx3/LOtvSCFs4J6txhPLeHc6yyBu1 VK1g== ARC-Message-Signature: i=1; a=rsa-sha256; c=relaxed/relaxed; d=google.com; s=arc-20160816; h=list-id:precedence:in-reply-to:content-disposition:mime-version :references:message-id:subject:cc:to:from:date:dkim-signature; bh=9T+aDxfqVKTx62xhlXoOXupPepyjs5c1sarMGlCRsCs=; b=gAGHEDudqWKIYYCSOgGOQDtlqqmd7cBwYIcn0fgwf03+A7zNeSUaNppoDcXaR9XurN E7eA4Bv4TDRWi8h33TVks1Vf54jt/yJjFPWDPy3bLpm9N1sEtpDqCuUFyOlxefIgwCOf zgnynjPHVx3AHm48NyxoDQ19FRaEi0Uo9GAkLpmXdl+LthKMEdgfzPKjXAbE82CtBZAu 7lu6tEwjS7NiArEMq1xTzlAGg0mdV7MCoFnjOYFvokjTnGKImOkvP4xmCPNJr5CbD45F pg7nOfRTEylazVzJldULZVy5litacbGeO3cp+yWB54oARwlq5hrqs5Zdz0GdTWV6PwBU HA+Q== ARC-Authentication-Results: i=1; mx.google.com; dkim=pass header.i=@kernel.org header.s=default header.b=Du+B6ZlF; spf=pass (google.com: domain of linux-kernel-owner@vger.kernel.org designates 23.128.96.18 as permitted sender) smtp.mailfrom=linux-kernel-owner@vger.kernel.org; dmarc=pass (p=NONE sp=NONE dis=NONE) header.from=kernel.org Return-Path: Received: from vger.kernel.org (vger.kernel.org. [23.128.96.18]) by mx.google.com with ESMTP id y1si13369908edm.279.2020.11.17.04.39.30; Tue, 17 Nov 2020 04:39:53 -0800 (PST) Received-SPF: pass (google.com: domain of linux-kernel-owner@vger.kernel.org designates 23.128.96.18 as permitted sender) client-ip=23.128.96.18; Authentication-Results: mx.google.com; dkim=pass header.i=@kernel.org header.s=default header.b=Du+B6ZlF; spf=pass (google.com: domain of linux-kernel-owner@vger.kernel.org designates 23.128.96.18 as permitted sender) smtp.mailfrom=linux-kernel-owner@vger.kernel.org; dmarc=pass (p=NONE sp=NONE dis=NONE) header.from=kernel.org Received: (majordomo@vger.kernel.org) by vger.kernel.org via listexpand id S1728013AbgKQMiJ (ORCPT + 99 others); Tue, 17 Nov 2020 07:38:09 -0500 Received: from mail.kernel.org ([198.145.29.99]:46878 "EHLO mail.kernel.org" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S1725779AbgKQMiI (ORCPT ); Tue, 17 Nov 2020 07:38:08 -0500 Received: from quaco.ghostprotocols.net (unknown [179.97.37.151]) (using TLSv1.2 with cipher ECDHE-RSA-AES256-GCM-SHA384 (256/256 bits)) (No client certificate requested) by mail.kernel.org (Postfix) with ESMTPSA id 442A522203; Tue, 17 Nov 2020 12:38:07 +0000 (UTC) DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/simple; d=kernel.org; s=default; t=1605616687; bh=uo/agYJkAgzfzIgEBsigSKpOM7d9pDOv93T+/jVRLK8=; h=Date:From:To:Cc:Subject:References:In-Reply-To:From; b=Du+B6ZlFeQJle6D3RUnPtvdpwWnVE3ClRmWuTY5+Md1Tx+RLot3oizAMUeZlqxksI cjK15s9dtCW60iZp89kn8kNC95DK1H/HURAQSmX+bhnGnJV+QCTJpHrX91QWMJQpkM RR42mfC+9fxdyV869UWQLAsZL1JrFmVdH9J4splY= Received: by quaco.ghostprotocols.net (Postfix, from userid 1000) id 138ED40E29; Tue, 17 Nov 2020 09:38:05 -0300 (-03) Date: Tue, 17 Nov 2020 09:38:05 -0300 From: Arnaldo Carvalho de Melo To: Jiri Olsa Cc: lkml , Peter Zijlstra , Ingo Molnar , Mark Rutland , Namhyung Kim , Alexander Shishkin , Michael Petlan , Song Liu , Ian Rogers , Stephane Eranian , Alexey Budankov , Andi Kleen , Adrian Hunter Subject: Re: [PATCH 12/24] perf tools: Store build id from mmap2 events Message-ID: <20201117123805.GN614220@kernel.org> References: <20201117110053.1303113-1-jolsa@kernel.org> <20201117110053.1303113-13-jolsa@kernel.org> MIME-Version: 1.0 Content-Type: text/plain; charset=us-ascii Content-Disposition: inline In-Reply-To: <20201117110053.1303113-13-jolsa@kernel.org> X-Url: http://acmel.wordpress.com Precedence: bulk List-ID: X-Mailing-List: linux-kernel@vger.kernel.org Em Tue, Nov 17, 2020 at 12:00:41PM +0100, Jiri Olsa escreveu: > When processing mmap2 event, check on the build id > misc bit: PERF_RECORD_MISC_BUILD_ID and if it's set, > store the build id in mmap's dso object. > > Also adding the build id data arts to struct > perf_record_mmap2 event definition. > > Signed-off-by: Jiri Olsa > --- > kernel/events/core.c | 4 ++++ > tools/lib/perf/include/perf/event.h | 18 ++++++++++++++---- > tools/perf/util/machine.c | 24 +++++++++++++++++++----- > tools/perf/util/map.c | 8 ++++++-- > tools/perf/util/map.h | 3 ++- > 5 files changed, 45 insertions(+), 12 deletions(-) You mixed up kernel changes with tools/ changes, can you please split this up? Also there is an indentation problem in the kernel changes, which, I think, is just debugging cruft that you forgot to excise? :-) - Arnaldo > diff --git a/kernel/events/core.c b/kernel/events/core.c > index 5841b5bca68d..fa7f392c6c0c 100644 > --- a/kernel/events/core.c > +++ b/kernel/events/core.c > @@ -8017,6 +8017,10 @@ static void perf_event_mmap_output(struct perf_event *event, > > __output_copy(&handle, size, 4); > __output_copy(&handle, mmap_event->build_id, BUILD_ID_SIZE); > + > +if (mmap_event->build_id_size > 20) > + trace_printk("build_id_size %u %s\n", mmap_event->build_id_size, mmap_event->file_name); > + > } else { > perf_output_put(&handle, mmap_event->maj); > perf_output_put(&handle, mmap_event->min); > diff --git a/tools/lib/perf/include/perf/event.h b/tools/lib/perf/include/perf/event.h > index 988c539bedb6..d82054225fcc 100644 > --- a/tools/lib/perf/include/perf/event.h > +++ b/tools/lib/perf/include/perf/event.h > @@ -23,10 +23,20 @@ struct perf_record_mmap2 { > __u64 start; > __u64 len; > __u64 pgoff; > - __u32 maj; > - __u32 min; > - __u64 ino; > - __u64 ino_generation; > + union { > + struct { > + __u32 maj; > + __u32 min; > + __u64 ino; > + __u64 ino_generation; > + }; > + struct { > + __u8 build_id_size; > + __u8 __reserved_1; > + __u16 __reserved_2; > + __u8 build_id[20]; > + }; > + }; > __u32 prot; > __u32 flags; > char filename[PATH_MAX]; > diff --git a/tools/perf/util/machine.c b/tools/perf/util/machine.c > index 1ae32a81639c..1edb7d10b042 100644 > --- a/tools/perf/util/machine.c > +++ b/tools/perf/util/machine.c > @@ -1599,7 +1599,8 @@ static int machine__process_extra_kernel_map(struct machine *machine, > } > > static int machine__process_kernel_mmap_event(struct machine *machine, > - struct extra_kernel_map *xm) > + struct extra_kernel_map *xm, > + struct build_id *bid) > { > struct map *map; > enum dso_space_type dso_space; > @@ -1624,6 +1625,10 @@ static int machine__process_kernel_mmap_event(struct machine *machine, > goto out_problem; > > map->end = map->start + xm->end - xm->start; > + > + if (build_id__is_defined(bid)) > + dso__set_build_id(map->dso, bid); > + > } else if (is_kernel_mmap) { > const char *symbol_name = (xm->name + strlen(machine->mmap_name)); > /* > @@ -1681,6 +1686,9 @@ static int machine__process_kernel_mmap_event(struct machine *machine, > > machine__update_kernel_mmap(machine, xm->start, xm->end); > > + if (build_id__is_defined(bid)) > + dso__set_build_id(kernel, bid); > + > /* > * Avoid using a zero address (kptr_restrict) for the ref reloc > * symbol. Effectively having zero here means that at record > @@ -1718,11 +1726,17 @@ int machine__process_mmap2_event(struct machine *machine, > .ino = event->mmap2.ino, > .ino_generation = event->mmap2.ino_generation, > }; > + struct build_id __bid, *bid = NULL; > int ret = 0; > > if (dump_trace) > perf_event__fprintf_mmap2(event, stdout); > > + if (event->header.misc & PERF_RECORD_MISC_MMAP_BUILD_ID) { > + bid = &__bid; > + build_id__init(bid, event->mmap2.build_id, event->mmap2.build_id_size); > + } > + > if (sample->cpumode == PERF_RECORD_MISC_GUEST_KERNEL || > sample->cpumode == PERF_RECORD_MISC_KERNEL) { > struct extra_kernel_map xm = { > @@ -1732,7 +1746,7 @@ int machine__process_mmap2_event(struct machine *machine, > }; > > strlcpy(xm.name, event->mmap2.filename, KMAP_NAME_LEN); > - ret = machine__process_kernel_mmap_event(machine, &xm); > + ret = machine__process_kernel_mmap_event(machine, &xm, bid); > if (ret < 0) > goto out_problem; > return 0; > @@ -1746,7 +1760,7 @@ int machine__process_mmap2_event(struct machine *machine, > map = map__new(machine, event->mmap2.start, > event->mmap2.len, event->mmap2.pgoff, > &dso_id, event->mmap2.prot, > - event->mmap2.flags, > + event->mmap2.flags, bid, > event->mmap2.filename, thread); > > if (map == NULL) > @@ -1789,7 +1803,7 @@ int machine__process_mmap_event(struct machine *machine, union perf_event *event > }; > > strlcpy(xm.name, event->mmap.filename, KMAP_NAME_LEN); > - ret = machine__process_kernel_mmap_event(machine, &xm); > + ret = machine__process_kernel_mmap_event(machine, &xm, NULL); > if (ret < 0) > goto out_problem; > return 0; > @@ -1805,7 +1819,7 @@ int machine__process_mmap_event(struct machine *machine, union perf_event *event > > map = map__new(machine, event->mmap.start, > event->mmap.len, event->mmap.pgoff, > - NULL, prot, 0, event->mmap.filename, thread); > + NULL, prot, 0, NULL, event->mmap.filename, thread); > > if (map == NULL) > goto out_problem_map; > diff --git a/tools/perf/util/map.c b/tools/perf/util/map.c > index f44ede437dc7..692e56dc832e 100644 > --- a/tools/perf/util/map.c > +++ b/tools/perf/util/map.c > @@ -130,8 +130,8 @@ void map__init(struct map *map, u64 start, u64 end, u64 pgoff, struct dso *dso) > > struct map *map__new(struct machine *machine, u64 start, u64 len, > u64 pgoff, struct dso_id *id, > - u32 prot, u32 flags, char *filename, > - struct thread *thread) > + u32 prot, u32 flags, struct build_id *bid, > + char *filename, struct thread *thread) > { > struct map *map = malloc(sizeof(*map)); > struct nsinfo *nsi = NULL; > @@ -194,6 +194,10 @@ struct map *map__new(struct machine *machine, u64 start, u64 len, > dso__set_loaded(dso); > } > dso->nsinfo = nsi; > + > + if (build_id__is_defined(bid)) > + dso__set_build_id(dso, bid); > + > dso__put(dso); > } > return map; > diff --git a/tools/perf/util/map.h b/tools/perf/util/map.h > index b1c0686db1b7..9f32825c98d8 100644 > --- a/tools/perf/util/map.h > +++ b/tools/perf/util/map.h > @@ -104,10 +104,11 @@ void map__init(struct map *map, > u64 start, u64 end, u64 pgoff, struct dso *dso); > > struct dso_id; > +struct build_id; > > struct map *map__new(struct machine *machine, u64 start, u64 len, > u64 pgoff, struct dso_id *id, u32 prot, u32 flags, > - char *filename, struct thread *thread); > + struct build_id *bid, char *filename, struct thread *thread); > struct map *map__new2(u64 start, struct dso *dso); > void map__delete(struct map *map); > struct map *map__clone(struct map *map); > -- > 2.26.2 > -- - Arnaldo