Received: by 2002:ac0:b08d:0:0:0:0:0 with SMTP id l13csp3559928imc; Sun, 24 Feb 2019 07:39:38 -0800 (PST) X-Google-Smtp-Source: AHgI3IY9CC9b6zFfnmUUxE60NfgZI+CCD9h3QkTWItc/biLZIAZitXF1pBb8h0BfSs/wbfebgmu+ X-Received: by 2002:a63:e051:: with SMTP id n17mr13957084pgj.258.1551022778012; Sun, 24 Feb 2019 07:39:38 -0800 (PST) ARC-Seal: i=1; a=rsa-sha256; t=1551022778; cv=none; d=google.com; s=arc-20160816; b=n3kBdxJ86kN6cxcmS3/n1VJKALN3FKh9eM8y2hofQ1KYAxc7In5/jakZtc7Pg3Pu6l 5JBbnZoNgRDRVlo7MtYWB7i+Hg9DWXm4ANL/RlTLmA8xvneC2mw4IptSMEMnuRUpoXKo BQcZxns8cFMqjOKqopPe02480bBRHKcVSe42AzM0TkLCeTOy938s7G65DH6NJaTedXqY q+A91SsghIPWCY3hxSh04cDhomXbLodx6y13EYKRhUEdld8qoBkASykgpiyOTtvLVbLo LOLKGdyGuCGrHHKzUmxY8TyVRPnvDr0fTFMVq4HzWL/G0U4NmffMgKj0pxqjI0solYfh OUjQ== ARC-Message-Signature: i=1; a=rsa-sha256; c=relaxed/relaxed; d=google.com; s=arc-20160816; h=list-id:precedence:sender:references:in-reply-to:message-id:date :subject:cc:to:from; bh=YKTXyqoP3457ezJLmnoGGkq5Tstx5Xz583GyxQae7NU=; b=FujGaKiyavNTvCpHjS1h3Vi3DDB/6N02Fx5QtjJvlpsJgXdoV1qPp/xeKWV8HOS0Pq lzKPvpuqRLvzYCymTa74za7uBUJ5fTb5qEKuN7H+5iYNaUlW1b0of2J1NxZfLXrgcjgB UkECiMqjRCMW2p8OAMTv2N7y5lw4YQgm/w/wPJtTZRUgSqipgfHnCPxFSCWwaInYEPhv 4W5oQYPZnmsXERdxY8dzpNpoKDz/uFxE0DrqTUo7T9AsaasViEmRqFwP4OtLq9CEugSb LX1fgPet3V1PrXSj72wmN8zv0GT8K9xk+Y+6AfddSWtwS8BTRKMD4VQZK/fo78enRUKi UETw== 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 Return-Path: Received: from vger.kernel.org (vger.kernel.org. [209.132.180.67]) by mx.google.com with ESMTP id x12si6251935pgp.286.2019.02.24.07.39.23; Sun, 24 Feb 2019 07:39:38 -0800 (PST) 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 Received: (majordomo@vger.kernel.org) by vger.kernel.org via listexpand id S1728465AbfBXPhc (ORCPT + 99 others); Sun, 24 Feb 2019 10:37:32 -0500 Received: from mga18.intel.com ([134.134.136.126]:17101 "EHLO mga18.intel.com" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S1728431AbfBXPhb (ORCPT ); Sun, 24 Feb 2019 10:37:31 -0500 X-Amp-Result: SKIPPED(no attachment in message) X-Amp-File-Uploaded: False Received: from fmsmga006.fm.intel.com ([10.253.24.20]) by orsmga106.jf.intel.com with ESMTP/TLS/DHE-RSA-AES256-GCM-SHA384; 24 Feb 2019 07:37:30 -0800 X-ExtLoop1: 1 X-IronPort-AV: E=Sophos;i="5.58,407,1544515200"; d="scan'208";a="321674207" Received: from tassilo.jf.intel.com (HELO tassilo.localdomain) ([10.7.201.137]) by fmsmga006.fm.intel.com with ESMTP; 24 Feb 2019 07:37:30 -0800 Received: by tassilo.localdomain (Postfix, from userid 1000) id 8C8133010AD; Sun, 24 Feb 2019 07:37:30 -0800 (PST) From: Andi Kleen To: acme@kernel.org, linux-perf-users@vger.kernel.org Cc: linux-kernel@vger.kernel.org, jolsa@kernel.org, namhyung@kernel.org, eranian@google.com, Andi Kleen Subject: [PATCH 02/11] perf tools script: Support insn output for normal samples Date: Sun, 24 Feb 2019 07:37:13 -0800 Message-Id: <20190224153722.27020-3-andi@firstfloor.org> X-Mailer: git-send-email 2.17.2 In-Reply-To: <20190224153722.27020-1-andi@firstfloor.org> References: <20190224153722.27020-1-andi@firstfloor.org> Sender: linux-kernel-owner@vger.kernel.org Precedence: bulk List-ID: X-Mailing-List: linux-kernel@vger.kernel.org From: Andi Kleen perf script -F +insn was only working for PT traces because the PT instruction decoder was filling in the insn/insn_len sample attributes. Support it for non PT samples too on x86 using the existing x86 instruction decoder. % perf record -a sleep 1 % perf script -F ip,sym,insn --xed ffffffff811704c9 remote_function movl %eax, 0x18(%rbx) ffffffff8100bb50 intel_bts_enable_local retq ffffffff81048612 native_apic_mem_write movl %esi, -0xa04000(%rdi) ffffffff81048612 native_apic_mem_write movl %esi, -0xa04000(%rdi) ffffffff81048612 native_apic_mem_write movl %esi, -0xa04000(%rdi) ffffffff810f1f79 generic_exec_single xor %eax, %eax ffffffff811704c9 remote_function movl %eax, 0x18(%rbx) ffffffff8100bb34 intel_bts_enable_local movl 0x2000(%rax), %edx ffffffff81048610 native_apic_mem_write mov %edi, %edi ... Signed-off-by: Andi Kleen --- tools/perf/arch/x86/util/Build | 1 + tools/perf/arch/x86/util/archinsn.c | 41 +++++++++++++++++++++++++++++ tools/perf/builtin-script.c | 10 +++++++ tools/perf/util/archinsn.h | 12 +++++++++ 4 files changed, 64 insertions(+) create mode 100644 tools/perf/arch/x86/util/archinsn.c create mode 100644 tools/perf/util/archinsn.h diff --git a/tools/perf/arch/x86/util/Build b/tools/perf/arch/x86/util/Build index 7aab0be5fc5f..7b8e69bbbdfe 100644 --- a/tools/perf/arch/x86/util/Build +++ b/tools/perf/arch/x86/util/Build @@ -6,6 +6,7 @@ perf-y += perf_regs.o perf-y += group.o perf-y += machine.o perf-y += event.o +perf-y += archinsn.o perf-$(CONFIG_DWARF) += dwarf-regs.o perf-$(CONFIG_BPF_PROLOGUE) += dwarf-regs.o diff --git a/tools/perf/arch/x86/util/archinsn.c b/tools/perf/arch/x86/util/archinsn.c new file mode 100644 index 000000000000..9e3b0828b018 --- /dev/null +++ b/tools/perf/arch/x86/util/archinsn.c @@ -0,0 +1,41 @@ +// SPDX-License-Identifier: GPL-2.0 +#include "perf.h" +#include "archinsn.h" +#include "util/intel-pt-decoder/insn.h" +#include "machine.h" +#include "thread.h" +#include "symbol.h" +#include "map.h" + +void arch_fetch_insn(struct perf_sample *sample, + struct thread *thread, + struct machine *machine) +{ + struct addr_location al; + u8 cpumode; + long offset; + struct insn insn; + int len; + + if (!sample->ip) + return; + + if (machine__kernel_ip(machine, sample->ip)) + cpumode = PERF_RECORD_MISC_KERNEL; + else + cpumode = PERF_RECORD_MISC_USER; + if (!thread__find_map(thread, cpumode, sample->ip, &al) || !al.map->dso) + return; + if (al.map->dso->data.status == DSO_DATA_STATUS_ERROR) + return; + map__load(al.map); + offset = al.map->map_ip(al.map, sample->ip); + len = dso__data_read_offset(al.map->dso, machine, offset, (u8 *)sample->insn, + sizeof(sample->insn)); + if (len <= 0) + return; + insn_init(&insn, sample->insn, len, al.map->dso->is_64_bit); + insn_get_length(&insn); + if (insn_complete(&insn) && insn.length <= len) + sample->insn_len = insn.length; +} diff --git a/tools/perf/builtin-script.c b/tools/perf/builtin-script.c index 29e95a25c6e6..261055302d08 100644 --- a/tools/perf/builtin-script.c +++ b/tools/perf/builtin-script.c @@ -29,6 +29,7 @@ #include "util/time-utils.h" #include "util/path.h" #include "print_binary.h" +#include "archinsn.h" #include #include #include @@ -1227,6 +1228,12 @@ static int perf_sample__fprintf_callindent(struct perf_sample *sample, return len + dlen; } +__weak void arch_fetch_insn(struct perf_sample *sample __maybe_unused, + struct thread *thread __maybe_unused, + struct machine *machine __maybe_unused) +{ +} + static int perf_sample__fprintf_insn(struct perf_sample *sample, struct perf_event_attr *attr, struct thread *thread, @@ -1234,6 +1241,9 @@ static int perf_sample__fprintf_insn(struct perf_sample *sample, { int printed = 0; + if (sample->insn_len == 0) + arch_fetch_insn(sample, thread, machine); + if (PRINT_FIELD(INSNLEN)) printed += fprintf(fp, " ilen: %d", sample->insn_len); if (PRINT_FIELD(INSN)) { diff --git a/tools/perf/util/archinsn.h b/tools/perf/util/archinsn.h new file mode 100644 index 000000000000..448cbb6b8d7e --- /dev/null +++ b/tools/perf/util/archinsn.h @@ -0,0 +1,12 @@ +#ifndef INSN_H +#define INSN_H 1 + +struct perf_sample; +struct machine; +struct thread; + +void arch_fetch_insn(struct perf_sample *sample, + struct thread *thread, + struct machine *machine); + +#endif -- 2.17.2