Received: by 2002:a05:6a10:22f:0:0:0:0 with SMTP id 15csp3279961pxk; Tue, 15 Sep 2020 15:11:01 -0700 (PDT) X-Google-Smtp-Source: ABdhPJyWAlxkZ5RKROMBbwoeHl01RLcBXde7f+DcG5vgg71QGmbzqEQ48TM+DN60IyfA/eYqKnMc X-Received: by 2002:aa7:cd06:: with SMTP id b6mr23841669edw.196.1600207860977; Tue, 15 Sep 2020 15:11:00 -0700 (PDT) ARC-Seal: i=1; a=rsa-sha256; t=1600207860; cv=none; d=google.com; s=arc-20160816; b=P+h5GcF5eROH8qx0kSgaLGgrG6KLNsmodN2QZTJMfHk3vM3oYDdbQeABO1EC0fR8F8 ScMzwJPIv3O+2V3RbL/56NoFo7b4ylLzmDZOgeDSbFYt48G60oLkvOobMNccX5WV1rv/ D55nq2bs3o1+1iDOtByo/Vnj9k5laFYTP2iih+Q2LtAGk92PL1Gp9YqmzMFEBEovfwck qVgd8V6HBLixWcfKQ/+OtIdq8GhJ/s88rYyoYaIZmoVaD1LsAAGNjfj7nnPT/nPmSLjR 67Jd9xOWB/MOWF+/0FyzNNrsy8A/zfpHgcde8l4tgBN8na/aKGI1jS1IN6a7S6+ZhYVu iFZg== ARC-Message-Signature: i=1; a=rsa-sha256; c=relaxed/relaxed; d=google.com; s=arc-20160816; h=list-id:precedence:sender:cc:to:subject:message-id:date:from :in-reply-to:references:mime-version:dkim-signature; bh=+9d3ORlPeAR882gC4oV6nUcXhz3M650ABYnqtiBLMu0=; b=NdQ8mxL+O5lrjP9PrIjX27vwuo6hqXb+S/3vWst1dYqVcmTkzuLyeXMz+gbeVGQ+FA /eimXyF43L+m+qNMH1+ustwfpIENLMmVR5cLpxDV2/bGUlvscoTk7FTMTCI6C/fGNBdX 9TIM2q6C1gIHu4DprOm/zP9vRHLccatMa6syn74wcoShbduWw45bL5wCBgBd/13EBV6f dSEiP6030BdJ+vuuU8gfFaCSUvlTDO8cG6ueatl9ln4+SSCVkUiDU7ylBRjWGIhNyTmy FT34xuGFnaRgRiFHXpuKiTMR8Yzz3kwOQVzcC2b94UmpAD9kQDVHGBtJHYfFtqVzixqz Zdmg== ARC-Authentication-Results: i=1; mx.google.com; dkim=pass header.i=@google.com header.s=20161025 header.b=WqHVyu8Q; 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=REJECT sp=REJECT dis=NONE) header.from=google.com Return-Path: Received: from vger.kernel.org (vger.kernel.org. [23.128.96.18]) by mx.google.com with ESMTP id ha21si10174112ejb.147.2020.09.15.15.10.38; Tue, 15 Sep 2020 15:11:00 -0700 (PDT) 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=@google.com header.s=20161025 header.b=WqHVyu8Q; 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=REJECT sp=REJECT dis=NONE) header.from=google.com Received: (majordomo@vger.kernel.org) by vger.kernel.org via listexpand id S1728055AbgIOWJo (ORCPT + 99 others); Tue, 15 Sep 2020 18:09:44 -0400 Received: from lindbergh.monkeyblade.net ([23.128.96.19]:60826 "EHLO lindbergh.monkeyblade.net" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S1727937AbgIOUSZ (ORCPT ); Tue, 15 Sep 2020 16:18:25 -0400 Received: from mail-wr1-x442.google.com (mail-wr1-x442.google.com [IPv6:2a00:1450:4864:20::442]) by lindbergh.monkeyblade.net (Postfix) with ESMTPS id C7B96C06174A for ; Tue, 15 Sep 2020 13:18:01 -0700 (PDT) Received: by mail-wr1-x442.google.com with SMTP id e16so4671188wrm.2 for ; Tue, 15 Sep 2020 13:18:01 -0700 (PDT) DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/relaxed; d=google.com; s=20161025; h=mime-version:references:in-reply-to:from:date:message-id:subject:to :cc; bh=+9d3ORlPeAR882gC4oV6nUcXhz3M650ABYnqtiBLMu0=; b=WqHVyu8Q4sCmq7ey1374ySo4PZvSixntEN2TVDdIGP80nkMc7yXnThenwrqFEMYGMN s6LIoDUM9wclPNVdRY4pRC2AadwzbG9sKSTgi9hN1h4dsOVYrgvbsGkGdZvLCb0/g3+z yjyli8DxrqD6H/VQ5AhWb0IPMwxq90o++ApITC9AUUnioUOFVFQi//lEPIOnnxmDaVMb fWtWILKN5R3jgRlGZSHJIbWPwwQr5X/DkLamrBCLb+pJMyhmZDuaT1IKZE/E5YyQUjWz 60XKoJif5fdF+Nw425RlG5c+Dk6iFmZXjiH5LZbzOOAJz8dMvouaffXFK3cRSHS99DI6 zBdg== X-Google-DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/relaxed; d=1e100.net; s=20161025; h=x-gm-message-state:mime-version:references:in-reply-to:from:date :message-id:subject:to:cc; bh=+9d3ORlPeAR882gC4oV6nUcXhz3M650ABYnqtiBLMu0=; b=FnDvPFaWJAuwIlP3iZiFrHVAJIAF4czo5achwoNeUIpbKyg0vpslLmR2TcV711j2L8 IFonWquPS6JAErwHKU5YA7Ev5NhQRpXjFowT2fvg1giOM9nHyUP8O7lGpXm5zqkTvYtC qSG98YlWXvTW6nYdwLUiM+iV6TO6Umw26akmhezmd0eaUxCFyfkL9gGuAmbDXFwlFq1z GoxjpOhL24oQONy/w4Psf4SsT/JmdMZWMGpy6m6+BzaCp0cJDdmbmcL9Tcdqtw+nHl3n YXn9RA/oMCDX3HGJ6Gy+elVgqW3HVQMq32BzbxUB05AkQaoUpPEyvq5OcdKaMWMe/0hI 5h3g== X-Gm-Message-State: AOAM533qaPy5MStQuOj+sfi+FjtWhdMOaIAcew9vJ0SX8rql7z5V5AUu ZRhZn3cmVQ+P9OkQrwk2eXADT5lSiL3GQpR0Fawe7Q== X-Received: by 2002:a5d:5583:: with SMTP id i3mr22372673wrv.119.1600201080279; Tue, 15 Sep 2020 13:18:00 -0700 (PDT) MIME-Version: 1.0 References: <20200913210313.1985612-1-jolsa@kernel.org> <20200913210313.1985612-17-jolsa@kernel.org> <20200914160758.GK160517@kernel.org> In-Reply-To: <20200914160758.GK160517@kernel.org> From: Ian Rogers Date: Tue, 15 Sep 2020 13:17:44 -0700 Message-ID: Subject: Re: [PATCH 16/26] perf tools: Synthesize modules with mmap3 To: Arnaldo Carvalho de Melo Cc: Jiri Olsa , lkml , Peter Zijlstra , Ingo Molnar , Mark Rutland , Namhyung Kim , Alexander Shishkin , Michael Petlan , Song Liu , "Frank Ch. Eigler" , Stephane Eranian , Alexey Budankov , Andi Kleen , Adrian Hunter Content-Type: text/plain; charset="UTF-8" Sender: linux-kernel-owner@vger.kernel.org Precedence: bulk List-ID: X-Mailing-List: linux-kernel@vger.kernel.org On Mon, Sep 14, 2020 at 9:08 AM Arnaldo Carvalho de Melo wrote: > > Em Sun, Sep 13, 2020 at 11:03:03PM +0200, Jiri Olsa escreveu: > > Synthesizing modules with mmap3 events so we can > > get build id data for module's maps as well. > > Ditto as for 15/26 > > > Signed-off-by: Jiri Olsa > > --- > > tools/perf/util/synthetic-events.c | 37 +++++++++++++++++++----------- > > 1 file changed, 24 insertions(+), 13 deletions(-) > > > > diff --git a/tools/perf/util/synthetic-events.c b/tools/perf/util/synthetic-events.c > > index bd6e7b84283d..6bd2423ce2f3 100644 > > --- a/tools/perf/util/synthetic-events.c > > +++ b/tools/perf/util/synthetic-events.c > > @@ -605,7 +605,7 @@ int perf_event__synthesize_modules(struct perf_tool *tool, perf_event__handler_t > > int rc = 0; > > struct map *pos; > > struct maps *maps = machine__kernel_maps(machine); > > - union perf_event *event = zalloc((sizeof(event->mmap) + > > + union perf_event *event = zalloc((sizeof(event->mmap3) + > > machine->id_hdr_size)); > > if (event == NULL) { > > pr_debug("Not enough memory synthesizing mmap event " > > @@ -613,8 +613,6 @@ int perf_event__synthesize_modules(struct perf_tool *tool, perf_event__handler_t > > return -1; > > } > > > > - event->header.type = PERF_RECORD_MMAP; > > - > > /* > > * kernel uses 0 for user space maps, see kernel/perf_event.c > > * __perf_event_mmap > > @@ -631,17 +629,30 @@ int perf_event__synthesize_modules(struct perf_tool *tool, perf_event__handler_t > > continue; > > > > size = PERF_ALIGN(pos->dso->long_name_len + 1, sizeof(u64)); > > - event->mmap.header.type = PERF_RECORD_MMAP; > > - event->mmap.header.size = (sizeof(event->mmap) - > > - (sizeof(event->mmap.filename) - size)); > > - memset(event->mmap.filename + size, 0, machine->id_hdr_size); > > - event->mmap.header.size += machine->id_hdr_size; > > - event->mmap.start = pos->start; > > - event->mmap.len = pos->end - pos->start; > > - event->mmap.pid = machine->pid; > > - > > - memcpy(event->mmap.filename, pos->dso->long_name, > > + event->mmap3.header.type = PERF_RECORD_MMAP3; > > + event->mmap3.header.size = (sizeof(event->mmap3) - > > + (sizeof(event->mmap3.filename) - size)); > > + memset(event->mmap3.filename + size, 0, machine->id_hdr_size); > > + event->mmap3.header.size += machine->id_hdr_size; > > + event->mmap3.start = pos->start; > > + event->mmap3.len = pos->end - pos->start; > > + event->mmap3.pid = machine->pid; > > + > > + memcpy(event->mmap3.filename, pos->dso->long_name, > > pos->dso->long_name_len + 1); > > + > > + rc = filename__read_build_id(event->mmap3.filename, event->mmap3.buildid, > > + BUILD_ID_SIZE); > > + if (rc != BUILD_ID_SIZE) { IIRC BUILD_ID_SIZE is 20 bytes which is the correct size for SHA-1. A build ID may be 128-bits (16 bytes) if md5 or uuid hashes are used. Should this test just be "> 0" ? Thanks, Ian > > + if (event->mmap3.filename[0] == '/') { > > + pr_debug2("Failed to read build ID for %s\n", > > + event->mmap3.filename); > > + } > > + memset(event->mmap3.buildid, 0x0, sizeof(event->mmap3.buildid)); > > + } > > + > > + rc = 0; > > + > > if (perf_tool__process_synth_event(tool, event, machine, process) != 0) { > > rc = -1; > > break; > > -- > > 2.26.2 > > > > -- > > - Arnaldo