Received: by 2002:a05:6a10:22f:0:0:0:0 with SMTP id 15csp3235608pxk; Mon, 21 Sep 2020 08:31:08 -0700 (PDT) X-Google-Smtp-Source: ABdhPJwbRvhuW8aMOb1urPVhih/wXYuGlOYAYiU20SIfdrLUXJHgJeORwL6TdrGU2NKLt6LZocc3 X-Received: by 2002:a05:6402:1b0f:: with SMTP id by15mr164404edb.289.1600702268466; Mon, 21 Sep 2020 08:31:08 -0700 (PDT) ARC-Seal: i=1; a=rsa-sha256; t=1600702268; cv=none; d=google.com; s=arc-20160816; b=QvY43EbGm+LAto9NtE09dDmVVRSxYk1MHEyQHDDii0nkpttqHzXY/pbhfcOlQfpow0 9CdhrLeK9ehzjQv400x+H6HIV3Yp9/TA1/DBJgVJ/k3vRk6hN7+ZxCWz9CW1Ku9T629H kWHngFX+2en/aNmUJGy5e97xoHVEW4rswwGadsGDbgnzxb14c/zWTEZDpO3YUmBnLbFi zfeQ+TLMJTSphGcDH7+y+OE5JlR0jGuhgvayfUU2II3JInYoCnnUkdV5x3XRjYihhoV9 6AYLuuXdx4jLBUUjHupauSX8Ictfw8mHu6Q8bgWYOXOinwIQVTU64spgveHgWSxRvYaP R9gw== ARC-Message-Signature: i=1; a=rsa-sha256; c=relaxed/relaxed; d=google.com; s=arc-20160816; h=list-id:precedence:references:in-reply-to:message-id:date:subject :cc:to:from:ironport-sdr:ironport-sdr; bh=gK0nfHs+yg3733wdsNZlWRZOHzvWRki7hbzIhR+q2fQ=; b=Gg54t8/ss1iDR+iKfvjvS7Yp7LOkw5zn/KREI0bNEdzhWtD+BQeFU9lZDqIaU50rzg c+WqiMREq2lij5qk7BzlWLQUGwJ33DAv5YkVQcskkL8uwd2kSM7hZ0xypQeQ5Px7kMj5 VEklTab/Wgvk11qpzBKQJVrbzCNhm/7EgjZwGZU/p5hUZ8MsK0ogtP+wKadSlV8AEfAt 8IJHL4XGLhOT5lsxSbhvH3iEnwWSTqOJbM7GVtS7/ndNLKdj0s6FBAhV8skS+beZ4cgO 42uLhjF2l0RBWMZOVN/J0XaGZVla90d8nMTIv6pE0JICHDL3rlMCOR5l8acVtsr4qIA+ E8pA== 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 y25si8153022edt.563.2020.09.21.08.30.44; Mon, 21 Sep 2020 08:31:08 -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 S1727926AbgIUP3S (ORCPT + 99 others); Mon, 21 Sep 2020 11:29:18 -0400 Received: from mga05.intel.com ([192.55.52.43]:52267 "EHLO mga05.intel.com" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S1726720AbgIUP3P (ORCPT ); Mon, 21 Sep 2020 11:29:15 -0400 IronPort-SDR: 4WzJ0s+u/no02CFI9lt27R0cqMklTKwxzeBxqipTmgwXjN9HFQlJSBSBDiex/dP7iZta/N/mxt JI+8aIsshzlA== X-IronPort-AV: E=McAfee;i="6000,8403,9751"; a="245243283" X-IronPort-AV: E=Sophos;i="5.77,286,1596524400"; d="scan'208";a="245243283" X-Amp-Result: SKIPPED(no attachment in message) X-Amp-File-Uploaded: False Received: from orsmga006.jf.intel.com ([10.7.209.51]) by fmsmga105.fm.intel.com with ESMTP/TLS/ECDHE-RSA-AES256-GCM-SHA384; 21 Sep 2020 08:29:10 -0700 IronPort-SDR: 4R5go57xc40Ecq/MbXPBGSa6lVrrWqJ90KDqtx9Row8VJlgLBnWvDzRmPGyoyt3lUuKNPPE1V3 Lsh3ys319sxw== X-ExtLoop1: 1 X-IronPort-AV: E=Sophos;i="5.77,286,1596524400"; d="scan'208";a="309079419" Received: from labuser-ice-lake-client-platform.jf.intel.com ([10.54.55.65]) by orsmga006.jf.intel.com with ESMTP; 21 Sep 2020 08:29:10 -0700 From: kan.liang@linux.intel.com To: peterz@infradead.org, mingo@redhat.com, acme@kernel.org, linux-kernel@vger.kernel.org Cc: mark.rutland@arm.com, alexander.shishkin@linux.intel.com, jolsa@redhat.com, eranian@google.com, ak@linux.intel.com, dave.hansen@intel.com, kirill.shutemov@linux.intel.com, mpe@ellerman.id.au, benh@kernel.crashing.org, paulus@samba.org, Kan Liang Subject: [PATCH V8 4/4] perf/core: Add support for PERF_SAMPLE_CODE_PAGE_SIZE Date: Mon, 21 Sep 2020 08:26:53 -0700 Message-Id: <20200921152653.3924-5-kan.liang@linux.intel.com> X-Mailer: git-send-email 2.17.1 In-Reply-To: <20200921152653.3924-1-kan.liang@linux.intel.com> References: <20200921152653.3924-1-kan.liang@linux.intel.com> Precedence: bulk List-ID: X-Mailing-List: linux-kernel@vger.kernel.org From: Stephane Eranian When studying code layout, it is useful to capture the page size of the sampled code address. Add a new sample type for code page size. The new sample type requires collecting the ip. The code page size can be calculated from the NMI-safe perf_get_page_size(). For large PEBS, it's very unlikely that the mapping is gone for the earlier PEBS records. Enable the feature for the large PEBS. The worst case is that page-size '0' is returned. Co-developed-by: Kan Liang Signed-off-by: Kan Liang Signed-off-by: Stephane Eranian --- arch/x86/events/perf_event.h | 2 +- include/linux/perf_event.h | 1 + include/uapi/linux/perf_event.h | 4 +++- kernel/events/core.c | 11 ++++++++++- 4 files changed, 15 insertions(+), 3 deletions(-) diff --git a/arch/x86/events/perf_event.h b/arch/x86/events/perf_event.h index 345442410a4d..10629ef1b626 100644 --- a/arch/x86/events/perf_event.h +++ b/arch/x86/events/perf_event.h @@ -132,7 +132,7 @@ struct amd_nb { PERF_SAMPLE_DATA_SRC | PERF_SAMPLE_IDENTIFIER | \ PERF_SAMPLE_TRANSACTION | PERF_SAMPLE_PHYS_ADDR | \ PERF_SAMPLE_REGS_INTR | PERF_SAMPLE_REGS_USER | \ - PERF_SAMPLE_PERIOD) + PERF_SAMPLE_PERIOD | PERF_SAMPLE_CODE_PAGE_SIZE) #define PEBS_GP_REGS \ ((1ULL << PERF_REG_X86_AX) | \ diff --git a/include/linux/perf_event.h b/include/linux/perf_event.h index 7e3785dd27d9..e533b03af053 100644 --- a/include/linux/perf_event.h +++ b/include/linux/perf_event.h @@ -1035,6 +1035,7 @@ struct perf_sample_data { u64 phys_addr; u64 cgroup; u64 data_page_size; + u64 code_page_size; } ____cacheline_aligned; /* default value for data source */ diff --git a/include/uapi/linux/perf_event.h b/include/uapi/linux/perf_event.h index cc6ea346e9f9..c2f20ee3124d 100644 --- a/include/uapi/linux/perf_event.h +++ b/include/uapi/linux/perf_event.h @@ -144,8 +144,9 @@ enum perf_event_sample_format { PERF_SAMPLE_AUX = 1U << 20, PERF_SAMPLE_CGROUP = 1U << 21, PERF_SAMPLE_DATA_PAGE_SIZE = 1U << 22, + PERF_SAMPLE_CODE_PAGE_SIZE = 1U << 23, - PERF_SAMPLE_MAX = 1U << 23, /* non-ABI */ + PERF_SAMPLE_MAX = 1U << 24, /* non-ABI */ __PERF_SAMPLE_CALLCHAIN_EARLY = 1ULL << 63, /* non-ABI; internal use */ }; @@ -898,6 +899,7 @@ enum perf_event_type { * { u64 size; * char data[size]; } && PERF_SAMPLE_AUX * { u64 data_page_size;} && PERF_SAMPLE_DATA_PAGE_SIZE + * { u64 code_page_size;} && PERF_SAMPLE_CODE_PAGE_SIZE * }; */ PERF_RECORD_SAMPLE = 9, diff --git a/kernel/events/core.c b/kernel/events/core.c index dd329a8f99f7..5fb27cb845fb 100644 --- a/kernel/events/core.c +++ b/kernel/events/core.c @@ -1898,6 +1898,9 @@ static void __perf_event_header_size(struct perf_event *event, u64 sample_type) if (sample_type & PERF_SAMPLE_DATA_PAGE_SIZE) size += sizeof(data->data_page_size); + if (sample_type & PERF_SAMPLE_CODE_PAGE_SIZE) + size += sizeof(data->code_page_size); + event->header_size = size; } @@ -6944,6 +6947,9 @@ void perf_output_sample(struct perf_output_handle *handle, if (sample_type & PERF_SAMPLE_DATA_PAGE_SIZE) perf_output_put(handle, data->data_page_size); + if (sample_type & PERF_SAMPLE_CODE_PAGE_SIZE) + perf_output_put(handle, data->code_page_size); + if (sample_type & PERF_SAMPLE_AUX) { perf_output_put(handle, data->aux_size); @@ -7114,7 +7120,7 @@ void perf_prepare_sample(struct perf_event_header *header, __perf_event_header__init_id(header, data, event); - if (sample_type & PERF_SAMPLE_IP) + if (sample_type & (PERF_SAMPLE_IP | PERF_SAMPLE_CODE_PAGE_SIZE)) data->ip = perf_instruction_pointer(regs); if (sample_type & PERF_SAMPLE_CALLCHAIN) { @@ -7242,6 +7248,9 @@ void perf_prepare_sample(struct perf_event_header *header, if (sample_type & PERF_SAMPLE_DATA_PAGE_SIZE) data->data_page_size = perf_get_page_size(data->addr); + if (sample_type & PERF_SAMPLE_CODE_PAGE_SIZE) + data->code_page_size = perf_get_page_size(data->ip); + if (sample_type & PERF_SAMPLE_AUX) { u64 size; -- 2.17.1