Received: by 2002:a25:824b:0:0:0:0:0 with SMTP id d11csp8029064ybn; Tue, 1 Oct 2019 01:58:18 -0700 (PDT) X-Google-Smtp-Source: APXvYqzvvG89ibe8Bv7mmrDmWpj7XRp8NB8JwlwBRhLORUvr3CqqdJ4cKXDEUjueJYBM0lexWg9O X-Received: by 2002:a17:906:b298:: with SMTP id q24mr23043134ejz.168.1569920298605; Tue, 01 Oct 2019 01:58:18 -0700 (PDT) ARC-Seal: i=1; a=rsa-sha256; t=1569920298; cv=none; d=google.com; s=arc-20160816; b=B4A8q3kTOnrYco60Ux+pEGquE/9oHOSfnsP6zgn7r3SPePOAb8H4NMYp2LDtAFJ0c5 V+x2SI37vF8HFCdA25cwAnwkkRFQCXbrVDOGIlbg9ewmoeExZdApWlam3bvs9XL0FdBk GEG9Gf9OhoN7R/olIxcAaIeYKbIwS5uxJZMLXet07TyjRZCYikT/WtlrlcJac/MfW3gM MbtbnhXd4uapfoPTNfaJykXk7WIxV7q6V4n+2qNn0jMs6zAnu27PZaoSRGc6gf+LmTGm nMQ829BPA1hug8ExkOF7KvXeUe5J4HnQ/BUyPt195GkH1s4z6LV3CRDR4rZI26eq2sm4 VSUQ== ARC-Message-Signature: i=1; a=rsa-sha256; c=relaxed/relaxed; d=google.com; s=arc-20160816; h=list-id:precedence:sender:user-agent:in-reply-to :content-disposition:mime-version:references:message-id:subject:cc :to:from:date; bh=Kf0naOz3xX2LORGO2V33uwhOA5xPuQdR1O4/fvMRdhI=; b=ChQJBFKQcZk086njAqyxbNfSaZB2+MUwLLQNo0RJ2z8OoCOXsDE7tXhGKL0sn0BcM+ qdBgIgVHJy33W6w6vi+vT6jSQHyLCXwzu6lG2Md6o8i0HX3veVKU1grxDJbSJxMVnxTx N6hEkTgY41RyU2N8GnE28CfNE7ob0Dr/G+hRXD9aLgAXtvdYO3pfITtwvk9EzU+qpPmU F6tUNdes/dfARK0syRHzkcK2Fman7UHz1+3e1WTLm1rI3GGanqjbBSouxkjj3D2XGg4I tIbBqRYKpTzNsgtvY/KwKRUuqSZiye/JBOLWpcvXJb9f+FoCaxVPfJPEP6T9zPdBwGN1 LNlQ== ARC-Authentication-Results: i=1; mx.google.com; spf=pass (google.com: best guess record for domain of linux-kernel-owner@vger.kernel.org designates 209.132.180.67 as permitted sender) smtp.mailfrom=linux-kernel-owner@vger.kernel.org; dmarc=fail (p=NONE sp=NONE dis=NONE) header.from=redhat.com Return-Path: Received: from vger.kernel.org (vger.kernel.org. [209.132.180.67]) by mx.google.com with ESMTP id k39si8509979edb.52.2019.10.01.01.57.54; Tue, 01 Oct 2019 01:58:18 -0700 (PDT) Received-SPF: pass (google.com: best guess record for domain of linux-kernel-owner@vger.kernel.org designates 209.132.180.67 as permitted sender) client-ip=209.132.180.67; Authentication-Results: mx.google.com; spf=pass (google.com: best guess record for domain of linux-kernel-owner@vger.kernel.org designates 209.132.180.67 as permitted sender) smtp.mailfrom=linux-kernel-owner@vger.kernel.org; dmarc=fail (p=NONE sp=NONE dis=NONE) header.from=redhat.com Received: (majordomo@vger.kernel.org) by vger.kernel.org via listexpand id S1733157AbfJAIzU (ORCPT + 99 others); Tue, 1 Oct 2019 04:55:20 -0400 Received: from mx1.redhat.com ([209.132.183.28]:39740 "EHLO mx1.redhat.com" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S1726148AbfJAIzU (ORCPT ); Tue, 1 Oct 2019 04:55:20 -0400 Received: from smtp.corp.redhat.com (int-mx04.intmail.prod.int.phx2.redhat.com [10.5.11.14]) (using TLSv1.2 with cipher AECDH-AES256-SHA (256/256 bits)) (No client certificate requested) by mx1.redhat.com (Postfix) with ESMTPS id 9E890C049D7C; Tue, 1 Oct 2019 08:55:18 +0000 (UTC) Received: from krava (ovpn-204-21.brq.redhat.com [10.40.204.21]) by smtp.corp.redhat.com (Postfix) with SMTP id 0BE265D9D5; Tue, 1 Oct 2019 08:55:12 +0000 (UTC) Date: Tue, 1 Oct 2019 10:55:11 +0200 From: Jiri Olsa To: Steve MacLean Cc: Arnaldo Carvalho de Melo , Peter Zijlstra , Ingo Molnar , Mark Rutland , Alexander Shishkin , Namhyung Kim , Eric Saint-Etienne , John Keeping , Andi Kleen , Song Liu , Davidlohr Bueso , Leo Yan , "linux-kernel@vger.kernel.org" , Brian Robbins , Tom McDonald , John Salem , Stephane Eranian Subject: Re: [PATCH 3/4 RESEND] perf inject --jit: Remove //anon mmap events Message-ID: <20191001085511.GB30823@krava> References: MIME-Version: 1.0 Content-Type: text/plain; charset=us-ascii Content-Disposition: inline In-Reply-To: User-Agent: Mutt/1.12.1 (2019-06-15) X-Scanned-By: MIMEDefang 2.79 on 10.5.11.14 X-Greylist: Sender IP whitelisted, not delayed by milter-greylist-4.5.16 (mx1.redhat.com [10.5.110.31]); Tue, 01 Oct 2019 08:55:19 +0000 (UTC) Sender: linux-kernel-owner@vger.kernel.org Precedence: bulk List-ID: X-Mailing-List: linux-kernel@vger.kernel.org On Mon, Sep 30, 2019 at 09:00:01PM +0000, Steve MacLean wrote: > While a JIT is jitting code it will eventually need to commit more pages and > change these pages to executable permissions. > > Typically the JIT will want these collocated to minimize branch displacements. > > The kernel will coalesce these anonymous mapping with identical permissions > before sending an mmap event for the new pages. This means the mmap event for > the new pages will include the older pages. > > These anonymous mmap events will obscure the jitdump injected pseudo events. > This means that the jitdump generated symbols, machine code, debugging info, > and unwind info will no longer be used. > > Observations: > > When a process emits a jit dump marker and a jitdump file, the perf-xxx.map > file represents inferior information which has been superseded by the > jitdump jit-xxx.dump file. > > Further the '//anon*' mmap events are only required for the legacy > perf-xxx.map mapping. > > Summary: > > Add rbtree to track which pids have successfully injected a jitdump file. > > During "perf inject --jit", discard "//anon*" mmap events for any pid which > has successfully processed a jitdump file. > > Committer testing: > > // jitdump case > perf record > perf inject --jit --input perf.data --output perfjit.data > > // verify mmap "//anon" events present initially > perf script --input perf.data --show-mmap-events | grep '//anon' > // verify mmap "//anon" events removed > perf script --input perfjit.data --show-mmap-events | grep '//anon' > > // no jitdump case > perf record > perf inject --jit --input perf.data --output perfjit.data > > // verify mmap "//anon" events present initially > perf script --input perf.data --show-mmap-events | grep '//anon' > // verify mmap "//anon" events not removed > perf script --input perfjit.data --show-mmap-events | grep '//anon' > > Repro: > > This issue was discovered while testing the initial CoreCLR jitdump > implementation. https://github.com/dotnet/coreclr/pull/26897. > > Cc: Peter Zijlstra > Cc: Ingo Molnar > Cc: Arnaldo Carvalho de Melo > Cc: Mark Rutland > Cc: Alexander Shishkin > Cc: Jiri Olsa > Cc: Namhyung Kim > Cc: Stephane Eranian > Cc: linux-kernel@vger.kernel.org > Signed-off-by: Steve MacLean > --- > tools/perf/builtin-inject.c | 4 +-- > tools/perf/util/jitdump.c | 63 +++++++++++++++++++++++++++++++++++++++++++++ > 2 files changed, 65 insertions(+), 2 deletions(-) > > diff --git a/tools/perf/builtin-inject.c b/tools/perf/builtin-inject.c > index c14f40b8..4c921e0 100644 > --- a/tools/perf/builtin-inject.c > +++ b/tools/perf/builtin-inject.c > @@ -261,7 +261,7 @@ static int perf_event__jit_repipe_mmap(struct perf_tool *tool, > * if jit marker, then inject jit mmaps and generate ELF images > */ > ret = jit_process(inject->session, &inject->output, machine, > - event->mmap.filename, sample->pid, &n); > + event->mmap.filename, event->mmap.pid, &n); > if (ret < 0) > return ret; > if (ret) { > @@ -299,7 +299,7 @@ static int perf_event__jit_repipe_mmap2(struct perf_tool *tool, > * if jit marker, then inject jit mmaps and generate ELF images > */ > ret = jit_process(inject->session, &inject->output, machine, > - event->mmap2.filename, sample->pid, &n); > + event->mmap2.filename, event->mmap2.pid, &n); > if (ret < 0) > return ret; > if (ret) { > diff --git a/tools/perf/util/jitdump.c b/tools/perf/util/jitdump.c > index 22d09c4..6a1563f 100644 > --- a/tools/perf/util/jitdump.c > +++ b/tools/perf/util/jitdump.c > @@ -751,6 +751,59 @@ jit_detect(char *mmap_name, pid_t pid) > return 0; > } > > +struct pid_rbtree > +{ > + struct rb_node node; > + pid_t pid; > +}; > + > +static void jit_add_pid(struct rb_root *root, pid_t pid) > +{ > + struct rb_node **new = &(root->rb_node), *parent = NULL; > + struct pid_rbtree* data = NULL; > + > + /* Figure out where to put new node */ > + while (*new) { > + struct pid_rbtree *this = container_of(*new, struct pid_rbtree, node); > + pid_t nodePid = this->pid; looks like Andi is right, I'm still getting malformed patch error the patch has extra characters '=20' and broken lines, like: --- a/tools/perf/util/jitdump.c +++ b/tools/perf/util/jitdump.c @@ -751,6 +751,59 @@ jit_detect(char *mmap_name, pid_t pid) return 0; } =20 +struct pid_rbtree +{ + struct rb_node node; + pid_t pid; +}; + +static void jit_add_pid(struct rb_root *root, pid_t pid) +{ + struct rb_node **new =3D &(root->rb_node), *parent =3D NULL; + struct pid_rbtree* data =3D NULL; + + /* Figure out where to put new node */ + while (*new) { + struct pid_rbtree *this =3D container_of(*new, struct pid_r= btree, node); + pid_t nodePid =3D this->pid; jirka