Received: by 2002:a05:6a10:16a7:0:0:0:0 with SMTP id gp39csp3535500pxb; Mon, 9 Nov 2020 13:57:36 -0800 (PST) X-Google-Smtp-Source: ABdhPJx8z1XL4fly7pPW3mCjoJ/aV0AFXRSmb9F3euRS9RjK6t88hNrcS/VLc7PNkpanVPidTu4H X-Received: by 2002:a17:906:dbf4:: with SMTP id yd20mr16900068ejb.53.1604959056646; Mon, 09 Nov 2020 13:57:36 -0800 (PST) ARC-Seal: i=1; a=rsa-sha256; t=1604959056; cv=none; d=google.com; s=arc-20160816; b=MyuJw7ihOLPQUZSS3GQ1mb7X3FOob6h0K7D/mq0OrpICcvb0L0jhU1lkk8eZhMdqax krPWGxaVMCRxEH84aCf7pfM56rJGp0OsKTt82Lp+T+r/eEfLhtFgc24pmU0JIKCQ6r1z KoN7Q27GIki4pRoXgt3NvDcwP9xf2uEUPHbrtOw1GJM6HE0KB7+q0uNbTYzWYpzZt1Wx GP8ezR3OO7nJYE+kFK7el3KlHL9PgahnGomWs+ceNwFq9b0mCqfdkjtauwTwUHNUucWR 788vmAC5suVahJukQ5Y3Auv89XgMX/mVd/ZnWobir2lVJMpce06gD+4nAZvXOrIv4Hy7 JRdg== ARC-Message-Signature: i=1; a=rsa-sha256; c=relaxed/relaxed; d=google.com; s=arc-20160816; h=list-id:precedence:content-transfer-encoding:mime-version :references:in-reply-to:message-id:date:subject:cc:to:from; bh=FUKa77/zUAW0Iwn7T/26tCSHUEapXx5HMARkYmbKP/w=; b=iWaODkwHkq+o/YWZSbFf5RDiFKnTEC5neKTFL8L8xhQm4fRuMdZikTJuUkjkPxsqJU u3KpKryDJWtiHbxf6xiK/uqNgZcqaVCrSoDx59VSuwDGpCS1bmcOh4HbqfpV7lqn5cdo w/DCXtZM7q7nd0gBXPVHa8OdU0MV4SW7HProLGejHoGDyqCbSoMWu/biW5bB+J7pCEl4 vzVJifYvqRTBesNx5/Lt3rhrI50yIMPhb+pj0PkxkwCuZ5IH4aWhaftGGdP6iocMTDvs WKl9I95D9z/E96L8926mRijc01QbyblfHEKr6OZ8hj4TFD9D8ucsVaeTcpNFZV3wN0f3 Pz3g== ARC-Authentication-Results: i=1; mx.google.com; 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 t9si7906373ejx.145.2020.11.09.13.57.11; Mon, 09 Nov 2020 13:57:36 -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; 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 S1731606AbgKIVzU convert rfc822-to-8bit (ORCPT + 99 others); Mon, 9 Nov 2020 16:55:20 -0500 Received: from us-smtp-delivery-44.mimecast.com ([205.139.111.44]:35536 "EHLO us-smtp-delivery-44.mimecast.com" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S1731318AbgKIVzR (ORCPT ); Mon, 9 Nov 2020 16:55:17 -0500 Received: from mimecast-mx01.redhat.com (mimecast-mx01.redhat.com [209.132.183.4]) (Using TLS) by relay.mimecast.com with ESMTP id us-mta-328-Q9is-1TmP8iI5rLP_bx9wg-1; Mon, 09 Nov 2020 16:55:07 -0500 X-MC-Unique: Q9is-1TmP8iI5rLP_bx9wg-1 Received: from smtp.corp.redhat.com (int-mx03.intmail.prod.int.phx2.redhat.com [10.5.11.13]) (using TLSv1.2 with cipher AECDH-AES256-SHA (256/256 bits)) (No client certificate requested) by mimecast-mx01.redhat.com (Postfix) with ESMTPS id 9609D8030DD; Mon, 9 Nov 2020 21:55:05 +0000 (UTC) Received: from krava.redhat.com (unknown [10.40.192.57]) by smtp.corp.redhat.com (Postfix) with ESMTP id 97ACA6EF46; Mon, 9 Nov 2020 21:55:02 +0000 (UTC) From: Jiri Olsa To: Arnaldo Carvalho de Melo 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: [PATCH 12/24] perf tools: Store build id from mmap2 events Date: Mon, 9 Nov 2020 22:54:03 +0100 Message-Id: <20201109215415.400153-13-jolsa@kernel.org> In-Reply-To: <20201109215415.400153-1-jolsa@kernel.org> References: <20201109215415.400153-1-jolsa@kernel.org> MIME-Version: 1.0 X-Scanned-By: MIMEDefang 2.79 on 10.5.11.13 Authentication-Results: relay.mimecast.com; auth=pass smtp.auth=CUSA124A263 smtp.mailfrom=jolsa@kernel.org X-Mimecast-Spam-Score: 0 X-Mimecast-Originator: kernel.org Content-Transfer-Encoding: 8BIT Content-Type: text/plain; charset=WINDOWS-1252 Precedence: bulk List-ID: X-Mailing-List: linux-kernel@vger.kernel.org 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 --- 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 ++- 4 files changed, 41 insertions(+), 12 deletions(-) diff --git a/tools/lib/perf/include/perf/event.h b/tools/lib/perf/include/perf/event.h index 988c539bedb6..91984cfe8010 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[20]; + __u8 build_id_size; + __u8 __reserved_1; + __u16 __reserved_2; + }; + }; __u32 prot; __u32 flags; char filename[PATH_MAX]; diff --git a/tools/perf/util/machine.c b/tools/perf/util/machine.c index 1ae32a81639c..1a2d01cc24ec 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_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