Received: by 2002:a25:1985:0:0:0:0:0 with SMTP id 127csp164143ybz; Tue, 21 Apr 2020 06:48:05 -0700 (PDT) X-Google-Smtp-Source: APiQypLAI5yXCuVXLnF7LpDZ3w/HauY4FsmOld6Sn2XKqBQbVnfToJRbgbT0t6dDaYgObVyyElEi X-Received: by 2002:a17:906:edb5:: with SMTP id sa21mr21685899ejb.270.1587476885293; Tue, 21 Apr 2020 06:48:05 -0700 (PDT) ARC-Seal: i=1; a=rsa-sha256; t=1587476885; cv=none; d=google.com; s=arc-20160816; b=Liv+cOfTQuEo2Z5XsuzWT53r0JcXkT1NbNParyONSl8NBrlM+5KXPd4IhBwMokCgRx Em5hB85YgeCqpH9C/pPThwT1QRgDOjewKbooagk6QDtB2BqK5dN1bPgawQnEBMHzVadd IB5i9r7CUbK0UisJeLkKl7lwcmPA7hqZNTCmM1twIfcSOoM/yBRJPVLg7ik9QvNm44Ho LOyEJ7Rspl0BASjkhrYXC7wEJK9o4vYKxHneIwpCyNKo0ayL8lsPTQjMTTVBcfK+tNHK 5ETSWshxe2LfVyO32tSfyJ6HKLuaFWyR8752OfhEq0EayRjNmujEZE5B/9qSeefAospJ ikxA== ARC-Message-Signature: i=1; a=rsa-sha256; c=relaxed/relaxed; d=google.com; s=arc-20160816; h=list-id:precedence:sender:content-transfer-encoding :content-language:in-reply-to:mime-version:user-agent:date :message-id:organization:from:references:cc:to:subject:ironport-sdr :ironport-sdr; bh=/EB8ev/ibVYtIOREpgpvTwXiDWnS/pNgBYDM90lKHnM=; b=gJQz9eeNeJZd3I2+KBRiCn982LuX+8scImaBu9NSWsnYpmxuo0S1BOEOietUhSvayS tXtlRUunON6WPliSLO70agUmv/S56B2xrq6Eyk4l1VYVWkChsvnZvhYO/7XT6ck3+TDB g/RmFyYaGH+1vRiA2qCFjepplhwX/lbmkqFXiJYXqWNDU0kblk/Zc/FsB+8LLpEta06k LvPl72hx9sRGf5rdCCOB/MauINEvlnG3Rf9DvHlEsYs+gQLmb1PvROZuPh15hWW98ALG kzT6dvojXrsmvr9irZ0g+QbY6+Y0T52vB76EvoS9VWMEWxiW5Ri4mQJeSNM7SNRBtqE9 vpLQ== 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=fail (p=NONE sp=NONE dis=NONE) header.from=intel.com Return-Path: Received: from vger.kernel.org (vger.kernel.org. [23.128.96.18]) by mx.google.com with ESMTP id b3si1485634edn.402.2020.04.21.06.47.42; Tue, 21 Apr 2020 06:48:05 -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; 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=fail (p=NONE sp=NONE dis=NONE) header.from=intel.com Received: (majordomo@vger.kernel.org) by vger.kernel.org via listexpand id S1728948AbgDUNq1 (ORCPT + 99 others); Tue, 21 Apr 2020 09:46:27 -0400 Received: from mga11.intel.com ([192.55.52.93]:24956 "EHLO mga11.intel.com" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S1728479AbgDUNq0 (ORCPT ); Tue, 21 Apr 2020 09:46:26 -0400 IronPort-SDR: WK2ZbXs25jQ1I8l+ZyvmGOZU6fHpaO1syIs4EaHg64Okk+xL6P3xPqEzm+Gp+zHW7pnAfyB0Jp /OO5JcehnEYw== X-Amp-Result: SKIPPED(no attachment in message) X-Amp-File-Uploaded: False Received: from fmsmga007.fm.intel.com ([10.253.24.52]) by fmsmga102.fm.intel.com with ESMTP/TLS/ECDHE-RSA-AES256-GCM-SHA384; 21 Apr 2020 06:46:22 -0700 IronPort-SDR: UPESVjSCK3u5cE0PeP9C+Axzz/PnExtVdu1cmtUEqGtdm+HtC7h08U8LySC5nVoRBfVrTyfGpw SCJoDMTjvLIA== X-ExtLoop1: 1 X-IronPort-AV: E=Sophos;i="5.72,410,1580803200"; d="scan'208";a="245686844" Received: from ahunter-desktop.fi.intel.com (HELO [10.237.72.157]) ([10.237.72.157]) by fmsmga007.fm.intel.com with ESMTP; 21 Apr 2020 06:46:19 -0700 Subject: Re: [PATCH V6 13/15] perf intel-pt: Add support for text poke events To: Jiri Olsa Cc: Peter Zijlstra , Ingo Molnar , Masami Hiramatsu , Steven Rostedt , Borislav Petkov , "H . Peter Anvin" , x86@kernel.org, Mark Rutland , Alexander Shishkin , Mathieu Poirier , Leo Yan , Arnaldo Carvalho de Melo , linux-kernel@vger.kernel.org References: <20200405201327.7332-1-adrian.hunter@intel.com> <20200405201327.7332-14-adrian.hunter@intel.com> <20200421125050.GG809467@krava> <4308a61d-cbed-e0ed-d8a9-c7306a933e7b@intel.com> <20200421130613.GH809467@krava> <65e3e544-62cc-1d0c-4daa-9425f06d903e@intel.com> <20200421133540.GJ809467@krava> From: Adrian Hunter Organization: Intel Finland Oy, Registered Address: PL 281, 00181 Helsinki, Business Identity Code: 0357606 - 4, Domiciled in Helsinki Message-ID: Date: Tue, 21 Apr 2020 16:45:45 +0300 User-Agent: Mozilla/5.0 (X11; Linux x86_64; rv:68.0) Gecko/20100101 Thunderbird/68.7.0 MIME-Version: 1.0 In-Reply-To: <20200421133540.GJ809467@krava> Content-Type: text/plain; charset=utf-8 Content-Language: en-US Content-Transfer-Encoding: 7bit Sender: linux-kernel-owner@vger.kernel.org Precedence: bulk List-ID: X-Mailing-List: linux-kernel@vger.kernel.org On 21/04/20 4:35 pm, Jiri Olsa wrote: > On Tue, Apr 21, 2020 at 04:10:33PM +0300, Adrian Hunter wrote: > > SNIP > >>>>> I'm still seeing some, probably I'm missing some CONFIG, will check >>>>> >>>>> # ./perf record -o perf.data.after --kcore -a -e intel_pt//k -m,64M & >>>>> [1] 5880 >>>>> # cat /proc/sys/kernel/sched_schedstats >>>>> 0 >>>>> # echo 1 > /proc/sys/kernel/sched_schedstats >>>>> # cat /proc/sys/kernel/sched_schedstats >>>>> 1 >>>>> # echo 0 > /proc/sys/kernel/sched_schedstats >>>>> # kill %1 >>>>> # [ perf record: Woken up 1 times to write data ] >>>>> [ perf record: Captured and wrote 6.181 MB perf.data.after ] >>>>> [1]+ Terminated ./perf record -o perf.data.after --kcore -a -e intel_pt//k -m,64M >>>>> # ./perf script --itrace=e -i perf.data.after > /dev/null >>>>> Warning: >>>>> 18837 instruction trace errors >>>>> >>>>> # ./perf script --itrace=e -i perf.data.after | head >>>>> instruction trace error type 1 time 9274.420582345 cpu 9 pid 845 tid 845 ip 0xffffffff814e6cf2 code 6: Trace doesn't match instruction >>>>> instruction trace error type 1 time 9274.422229726 cpu 39 pid 5880 tid 5880 ip 0xffffffffa030a320 code 6: Trace doesn't match instruction >>>>> instruction trace error type 1 time 9274.422231972 cpu 39 pid 5880 tid 5880 ip 0xffffffffa0315c1c code 6: Trace doesn't match instruction >>>>> instruction trace error type 1 time 9274.422236141 cpu 39 pid 5880 tid 5880 ip 0xffffffff81143263 code 6: Trace doesn't match instruction >>>>> instruction trace error type 1 time 9274.422237424 cpu 39 pid 5880 tid 5880 ip 0xffffffff8115c388 code 6: Trace doesn't match instruction >>>>> instruction trace error type 1 time 9274.422239028 cpu 39 pid 5880 tid 5880 ip 0xffffffff811428c9 code 6: Trace doesn't match instruction >>>>> instruction trace error type 1 time 9274.422239028 cpu 39 pid 5880 tid 5880 ip 0xffffffffa13279fb code 5: Failed to get instruction >>>>> instruction trace error type 1 time 9274.422242556 cpu 39 pid 5880 tid 5880 ip 0xffffffff814e9c73 code 6: Trace doesn't match instruction >>>>> instruction trace error type 1 time 9274.422258915 cpu 39 pid 5880 tid 5880 ip 0xffffffff810d7da2 code 6: Trace doesn't match instruction >>>>> instruction trace error type 1 time 9274.422258915 cpu 39 pid 5880 tid 5880 ip 0xffffffffa030a0b2 code 6: Trace doesn't match instruction >>>> >>>> I don't think it can be CONFIG. Can you share the branch you are using? >>>> Then I can test it. >>>> >>> >>> I built the one you mentioned in cover email: >>> git://git.infradead.org/users/ahunter/linux-perf.git text_poke >> >> The tools and the kernel? > > both from that branch > >> >> Does it successfully decode anything? e.g. >> ./perf script --itrace=be -i perf.data.after | head >> > > # ./perf script --itrace=be -i perf.data.after | head > perf 5880 [000] 9274.419884: 1 branches:k: 0 [unknown] ([unknown]) => ffffffff8106a4a6 native_write_msr+0x6 (/lib/modules/5.6.0-rc6+/build/vmlinux) > perf 5880 [000] 9274.419884: 1 branches:k: ffffffff8106a4ab native_write_msr+0xb (/lib/modules/5.6.0-rc6+/build/vmlinux) => ffffffff810152f9 pt_config_start+0x59 (/lib/modules/5.6.0-rc6+/build/vmlinux) > perf 5880 [000] 9274.419884: 1 branches:k: ffffffff81015304 pt_config_start+0x64 (/lib/modules/5.6.0-rc6+/build/vmlinux) => ffffffff81015648 pt_event_add+0x38 (/lib/modules/5.6.0-rc6+/build/vmlinux) > perf 5880 [000] 9274.419884: 1 branches:k: ffffffff8101565d pt_event_add+0x4d (/lib/modules/5.6.0-rc6+/build/vmlinux) => ffffffff8121d3ca event_sched_in.isra.0+0xea (/lib/modules/5.6.0-rc6+/build/vmlinux) > perf 5880 [000] 9274.419884: 1 branches:k: ffffffff8121d3dc event_sched_in.isra.0+0xfc (/lib/modules/5.6.0-rc6+/build/vmlinux) => ffffffff8121d3e3 event_sched_in.isra.0+0x103 (/lib/modules/5.6.0-rc6+/build/vmlinux) > perf 5880 [000] 9274.419884: 1 branches:k: ffffffff8121d3f4 event_sched_in.isra.0+0x114 (/lib/modules/5.6.0-rc6+/build/vmlinux) => ffffffff8121d497 event_sched_in.isra.0+0x1b7 (/lib/modules/5.6.0-rc6+/build/vmlinux) > perf 5880 [000] 9274.419884: 1 branches:k: ffffffff8121d4c1 event_sched_in.isra.0+0x1e1 (/lib/modules/5.6.0-rc6+/build/vmlinux) => ffffffff814f9560 __list_add_valid+0x0 (/lib/modules/5.6.0-rc6+/build/vmlinux) > perf 5880 [000] 9274.419884: 1 branches:k: ffffffff814f9593 __list_add_valid+0x33 (/lib/modules/5.6.0-rc6+/build/vmlinux) => ffffffff8121d4c6 event_sched_in.isra.0+0x1e6 (/lib/modules/5.6.0-rc6+/build/vmlinux) > perf 5880 [000] 9274.419884: 1 branches:k: ffffffff8121d4e2 event_sched_in.isra.0+0x202 (/lib/modules/5.6.0-rc6+/build/vmlinux) => ffffffff8121d3fa event_sched_in.isra.0+0x11a (/lib/modules/5.6.0-rc6+/build/vmlinux) > perf 5880 [000] 9274.419884: 1 branches:k: ffffffff8121d401 event_sched_in.isra.0+0x121 (/lib/modules/5.6.0-rc6+/build/vmlinux) => ffffffff8121d40d event_sched_in.isra.0+0x12d (/lib/modules/5.6.0-rc6+/build/vmlinux) > > # ./perf script --call-trace -i perf.data.after | head > perf 5880 [000] 9274.419884188: cbr: 8 freq: 798 MHz ( 36%) > perf 5880 [000] 9274.419884389: (/lib/modules/5.6.0-rc6+/build/vmlinux ) __list_add_valid > perf 5880 [000] 9274.419884389: (/lib/modules/5.6.0-rc6+/build/vmlinux ) perf_pmu_enable.part.0 > perf 5880 [000] 9274.419884389: (/lib/modules/5.6.0-rc6+/build/vmlinux ) __x86_indirect_thunk_rax > perf 5880 [000] 9274.419884389: (/lib/modules/5.6.0-rc6+/build/vmlinux ) __x86_indirect_thunk_rax > perf 5880 [000] 9274.419884389: (/lib/modules/5.6.0-rc6+/build/vmlinux ) __x86_indirect_thunk_rax > perf 5880 [000] 9274.419884709: (/lib/modules/5.6.0-rc6+/build/vmlinux ) __list_add_valid > perf 5880 [000] 9274.419884709: (/lib/modules/5.6.0-rc6+/build/vmlinux ) rb_next > perf 5880 [000] 9274.419884709: (/lib/modules/5.6.0-rc6+/build/vmlinux ) merge_sched_in > perf 5880 [000] 9274.419884709: (/lib/modules/5.6.0-rc6+/build/vmlinux ) __x86_indirect_thunk_rax > perf is not using kcore, which explains the errors. Not sure why it prefers vmlinux. It should effectively be doing: perf script -i perf.data.after --itrace=e --kallsyms perf.data.after/kcore_dir/kallsyms What is in the perf.data.after directory?