Received: by 10.213.65.16 with SMTP id m16csp21902imf; Sun, 11 Mar 2018 12:50:25 -0700 (PDT) X-Google-Smtp-Source: AG47ELtumh3rgOlDSJQR8GId2FfF8eaTjo1hyR8mdnXPvsAVmUpVoBA2NLcMQoCXt2/8/6v6uhMe X-Received: by 2002:a17:902:7b95:: with SMTP id w21-v6mr5866075pll.260.1520797825375; Sun, 11 Mar 2018 12:50:25 -0700 (PDT) ARC-Seal: i=1; a=rsa-sha256; t=1520797825; cv=none; d=google.com; s=arc-20160816; b=PVzc8hqdD4cw8fnKlQ2ShiYPI6GQ0SUeo8MPbvcnn7DZB7gSHTBvwWh1tJ9MvTSRK/ lj3IoQdW/yvmQTt6zUiDp43xsX0Xh3B9+e3IKN65ZygCnXb57NwaD9SA+W7wCQxIX3OQ PHWUiNUV9eDH6rLJOqkvsOQL5uTaM1ul4yugJQeEB8Dkwkdq79Gab1GwtOJY3ojCRYFh z+A+ni2B4Qf9EX0xi0ZkfASdAtyX4uJvPBhe3qFOOLRFgYR7K/scyriIT+gdnC1Tgg08 QrrK7x8P5aMZb4FpeOAGRysMC+Y9IVwxcnJhBj+O2FwRYh+WYBh2aoWaGCxoomyV2BRQ Zfgg== 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:arc-authentication-results; bh=4iJ8V4MjcmPNTy1EDB/UWuZ/jB/5KVm542M2gBuiQ7M=; b=k/rLkc0Qw6q+XUmZKFp/+kYCsHYEhPRtF3jdaTiB8s8QgKUhaBkuloeate2tvY5+b7 6VVQG91salMmJMZQgeJI4s0ZtjxQqdVV+06KcaaYqOGou47UbaDIbZAtu1lmfFFuvRdk lw8RFu7W+1Imhm3qU8TWXfPaAjSS3CyS05SYlbyVeWkdQo+vZ2EZJveOTPMdrRtgJlMl WZSUY46jkfTjAraDNddSe0zIduWifvWHTRxEDjNXA3YLeWZpgiR3IzBdVlHx1YBWioyo DSVWVwDwvvU8y2c5pEbedfkIFEynJq6JcxYAx7YBysHb6nJJ5145fafHhQmRbQwQCZvA pCHw== 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 bj1-v6si3692369plb.711.2018.03.11.12.50.11; Sun, 11 Mar 2018 12:50:25 -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 S932259AbeCKTtT (ORCPT + 99 others); Sun, 11 Mar 2018 15:49:19 -0400 Received: from mx3-rdu2.redhat.com ([66.187.233.73]:38920 "EHLO mx1.redhat.com" rhost-flags-OK-OK-OK-FAIL) by vger.kernel.org with ESMTP id S932161AbeCKTtS (ORCPT ); Sun, 11 Mar 2018 15:49:18 -0400 Received: from smtp.corp.redhat.com (int-mx05.intmail.prod.int.rdu2.redhat.com [10.11.54.5]) (using TLSv1.2 with cipher AECDH-AES256-SHA (256/256 bits)) (No client certificate requested) by mx1.redhat.com (Postfix) with ESMTPS id 2BC3584250; Sun, 11 Mar 2018 19:49:18 +0000 (UTC) Received: from krava (ovpn-204-81.brq.redhat.com [10.40.204.81]) by smtp.corp.redhat.com (Postfix) with SMTP id 2B0CF1C705; Sun, 11 Mar 2018 19:49:13 +0000 (UTC) Date: Sun, 11 Mar 2018 20:49:12 +0100 From: Jiri Olsa To: Leo Yan Cc: Peter Zijlstra , Ingo Molnar , Arnaldo Carvalho de Melo , Alexander Shishkin , Namhyung Kim , linux-kernel@vger.kernel.org, Mathieu Poirier Subject: Re: [PATCH v2] perf machine: Fix load kernel symbol with '-k' option Message-ID: <20180311194912.GA13895@krava> References: <1520575523-3838-1-git-send-email-leo.yan@linaro.org> <20180309205600.GB16890@krava> <20180310095056.GA10251@leoy-ThinkPad-X240s> MIME-Version: 1.0 Content-Type: text/plain; charset=us-ascii Content-Disposition: inline In-Reply-To: <20180310095056.GA10251@leoy-ThinkPad-X240s> User-Agent: Mutt/1.9.1 (2017-09-22) X-Scanned-By: MIMEDefang 2.79 on 10.11.54.5 X-Greylist: Sender IP whitelisted, not delayed by milter-greylist-4.5.16 (mx1.redhat.com [10.11.55.2]); Sun, 11 Mar 2018 19:49:18 +0000 (UTC) X-Greylist: inspected by milter-greylist-4.5.16 (mx1.redhat.com [10.11.55.2]); Sun, 11 Mar 2018 19:49:18 +0000 (UTC) for IP:'10.11.54.5' DOMAIN:'int-mx05.intmail.prod.int.rdu2.redhat.com' HELO:'smtp.corp.redhat.com' FROM:'jolsa@redhat.com' RCPT:'' Sender: linux-kernel-owner@vger.kernel.org Precedence: bulk List-ID: X-Mailing-List: linux-kernel@vger.kernel.org On Sat, Mar 10, 2018 at 05:50:56PM +0800, Leo Yan wrote: SNIP > > > diff --git a/tools/perf/util/machine.c b/tools/perf/util/machine.c > > > index 12b7427..3125871 100644 > > > --- a/tools/perf/util/machine.c > > > +++ b/tools/perf/util/machine.c > > > @@ -1299,9 +1299,18 @@ static int machine__process_kernel_mmap_event(struct machine *machine, > > > else > > > kernel_type = DSO_TYPE_GUEST_KERNEL; > > > > > > - is_kernel_mmap = memcmp(event->mmap.filename, > > > - machine->mmap_name, > > > - strlen(machine->mmap_name) - 1) == 0; > > > + /* > > > + * When symbol_conf.vmlinux_name is not NULL, it includes the specified > > > + * kernel vmlinux path with option '-k'. So set 'is_kernel_mmap' to > > > + * true for creating machine symbol map. > > > + */ > > > + if (symbol_conf.vmlinux_name) > > > + is_kernel_mmap = true; > > > + else > > > + is_kernel_mmap = memcmp(event->mmap.filename, > > > + machine->mmap_name, > > > + strlen(machine->mmap_name) - 1) == 0; > > > + > > > if (event->mmap.filename[0] == '/' || > > > (!is_kernel_mmap && event->mmap.filename[0] == '[')) { > > > map = machine__findnew_module_map(machine, event->mmap.start, > > > > right, the mmap gets confused with the vmlinux path, but I wonder > > the fix should be not to include symbol_conf.vmlinux_name in the > > mmap_name like below.. untested > > I tested below fixing at my side, and confirm your fixing also can > resolve this issue. After reviewing the change, it's more neat than my > own change . So you could add my test tag :) > > Tested-by: Leo Yan thanks SNIP > static int machine__set_mmap_name(struct machine *machine) > { > - if (machine__is_host(machine)) { > - if (symbol_conf.vmlinux_name) > - machine->mmap_name = strdup(symbol_conf.vmlinux_name); > - else > - machine->mmap_name = strdup("[kernel.kallsyms]"); > - } else if (machine__is_default_guest(machine)) { > - if (symbol_conf.default_guest_vmlinux_name) > - machine->mmap_name = strdup(symbol_conf.default_guest_vmlinux_name); > - else > - machine->mmap_name = strdup("[guest.kernel.kallsyms]"); > - } else { > - if (asprintf(&machine->mmap_name, "[guest.kernel.kallsyms.%d]", > - machine->pid) < 0) > - machine->mmap_name = NULL; > - } > + if (machine__is_host(machine)) > + machine->mmap_name = strdup("[kernel.kallsyms]"); > + else if (machine__is_default_guest(machine)) > + machine->mmap_name = strdup("[guest.kernel.kallsyms]"); > + else if (asprintf(&machine->mmap_name, "[guest.kernel.kallsyms.%d]", > + machine->pid) < 0) > + machine->mmap_name = NULL; yea, that looks better.. will change jirka