Received: by 2002:a05:6a10:f347:0:0:0:0 with SMTP id d7csp352452pxu; Fri, 11 Dec 2020 04:03:56 -0800 (PST) X-Google-Smtp-Source: ABdhPJyL6SDEE17a7JfzHdsxMRcqCNzjYzJdd79I5CZWL4cHfMqJ95ZaXa2ttAuCNp6riOftZnHB X-Received: by 2002:a05:6402:5:: with SMTP id d5mr11455631edu.77.1607688236217; Fri, 11 Dec 2020 04:03:56 -0800 (PST) ARC-Seal: i=1; a=rsa-sha256; t=1607688236; cv=none; d=google.com; s=arc-20160816; b=yYwHAh27cgdX/jb58oEvvKynZH67JpjD5YtGEBSRYI0Dd24BxnkYE2b5d7t+SlpopL 0alGpncOJU9MlN6zqgsjzkXcBR6fDMa7MUdlGHPk3qKcac2KZYEnTsHoPjg4GX/5SZxO OSW35omhIhtLQkdCMl5ebLzZkY0wWuQKP+jbzyppE4a9UdclzwOvJDY14boYAeD6rI0t V+0hhitT0lJYA8p80Xe+nS/+9WcDvNKju6Jy/mkegutoGed5nf2+TQVjOrPlgMe0Ob6/ oqMWHp56XEPst+4Kxuz9QMTHbZCt0FkYJGg3JUIW2XdLsJrpCSq4cpiDUKAffe/L6Grz lKOw== ARC-Message-Signature: i=1; a=rsa-sha256; c=relaxed/relaxed; d=google.com; s=arc-20160816; h=list-id:precedence: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=2aJ0Nw7XRzd/Kv95dngNLIciIjRdVEn5jI14kAzGw4o=; b=AtG37rn8l6RZroKDpVDpdqKkUDLXZKKgEOpCCSf3Mj+oYLIihMWU4zw9VTV5VXEa6D T4eOrdypeNiYMUQqsZf6kZatuIf1e4xnKGVIhiVEA+OXKostDL861GFfHHTvD43NFoYp AohRsKQRUcb48TdmndgjDKw0Yvf2kbtXZIylMvsLdhJZ9gnanNEboafBO4vyOcE7hO2q 6vU1VSZ2SC5aC5sOzB2KTD2FushCkvIE53+Lk9srBYo1bkdlUITHDSN97UPrwLIkjQ9c UKzS2n0LZ5lcYVomyk3bdYeO5wGFj1gDmUDeoXWHqTote91j0+VKkt8Cc/QTZgYTeSem /jQg== 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 gt24si4423161ejb.248.2020.12.11.04.03.32; Fri, 11 Dec 2020 04:03:56 -0800 (PST) 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 S2405242AbgLKGL6 (ORCPT + 99 others); Fri, 11 Dec 2020 01:11:58 -0500 Received: from mga03.intel.com ([134.134.136.65]:52836 "EHLO mga03.intel.com" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S2389524AbgLKGLY (ORCPT ); Fri, 11 Dec 2020 01:11:24 -0500 IronPort-SDR: +npOG2itrmh9u3edOxObPHlzkWn4qKIuSW9SSK+hYfMa4c3TTp/2TUcmYaawO0fNjXoCt9eORW SjKHrZuMsYew== X-IronPort-AV: E=McAfee;i="6000,8403,9831"; a="174499956" X-IronPort-AV: E=Sophos;i="5.78,410,1599548400"; d="scan'208";a="174499956" Received: from fmsmga005.fm.intel.com ([10.253.24.32]) by orsmga103.jf.intel.com with ESMTP/TLS/ECDHE-RSA-AES256-GCM-SHA384; 10 Dec 2020 22:10:42 -0800 IronPort-SDR: lmIRnu2HZnjGNgHD743NMRlrVHozvDlTHCUPKxYImRWjb8dVtqd4XBM1lBA2BvsJj/eaKoss6C tseFUHQb4r0Q== X-ExtLoop1: 1 X-IronPort-AV: E=Sophos;i="5.78,410,1599548400"; d="scan'208";a="544940183" Received: from ahunter-desktop.fi.intel.com (HELO [10.237.72.94]) ([10.237.72.94]) by fmsmga005.fm.intel.com with ESMTP; 10 Dec 2020 22:10:40 -0800 Subject: Re: [PATCH v2] perf script: Fix overrun issue for dynamically-allocated pmu type number To: Jin Yao , acme@kernel.org, jolsa@kernel.org, peterz@infradead.org, mingo@redhat.com, alexander.shishkin@linux.intel.com Cc: Linux-kernel@vger.kernel.org, ak@linux.intel.com, kan.liang@intel.com, yao.jin@intel.com References: <20201209005828.21302-1-yao.jin@linux.intel.com> From: Adrian Hunter Organization: Intel Finland Oy, Registered Address: PL 281, 00181 Helsinki, Business Identity Code: 0357606 - 4, Domiciled in Helsinki Message-ID: <3fcdc860-d858-0166-de23-34fc6fe5c1cd@intel.com> Date: Fri, 11 Dec 2020 08:10:34 +0200 User-Agent: Mozilla/5.0 (X11; Linux x86_64; rv:68.0) Gecko/20100101 Thunderbird/68.12.0 MIME-Version: 1.0 In-Reply-To: <20201209005828.21302-1-yao.jin@linux.intel.com> Content-Type: text/plain; charset=utf-8 Content-Language: en-US Content-Transfer-Encoding: 7bit Precedence: bulk List-ID: X-Mailing-List: linux-kernel@vger.kernel.org On 9/12/20 2:58 am, Jin Yao wrote: > When unpacking the event which is from dynamic pmu, the array > output[OUTPUT_TYPE_MAX] may be overrun. For example, type number of > SKL uncore_imc is 10, but OUTPUT_TYPE_MAX is 7 now (OUTPUT_TYPE_MAX = > PERF_TYPE_MAX + 1). > > /* In builtin-script.c */ > process_event() > { > unsigned int type = output_type(attr->type); > > if (output[type].fields == 0) > return; > } > > output[10] is overrun. > > Create a type OUTPUT_TYPE_OTHER for dynamic pmu events, then > output_type(attr->type) will return OUTPUT_TYPE_OTHER here. > > Note that if PERF_TYPE_MAX ever changed, then there would be a conflict > between old perf.data files that had a dynamicaliy allocated PMU number > that would then be the same as a fixed PERF_TYPE. > > Example: > > perf record --switch-events -C 0 -e "{cpu-clock,uncore_imc/data_reads/,uncore_imc/data_writes/}:SD" -a -- sleep 1 > perf script > > Before: > swapper 0 [000] 1479253.987551: 277766 cpu-clock: ffffffff9d4ddb6f cpuidle_enter_state+0xdf ([kernel.kallsyms]) > swapper 0 [000] 1479253.987797: 246709 cpu-clock: ffffffff9d4ddb6f cpuidle_enter_state+0xdf ([kernel.kallsyms]) > swapper 0 [000] 1479253.988127: 329883 cpu-clock: ffffffff9d4ddb6f cpuidle_enter_state+0xdf ([kernel.kallsyms]) > swapper 0 [000] 1479253.988273: 146393 cpu-clock: ffffffff9d4ddb6f cpuidle_enter_state+0xdf ([kernel.kallsyms]) > swapper 0 [000] 1479253.988523: 249977 cpu-clock: ffffffff9d4ddb6f cpuidle_enter_state+0xdf ([kernel.kallsyms]) > swapper 0 [000] 1479253.988877: 354090 cpu-clock: ffffffff9d4ddb6f cpuidle_enter_state+0xdf ([kernel.kallsyms]) > swapper 0 [000] 1479253.989023: 145940 cpu-clock: ffffffff9d4ddb6f cpuidle_enter_state+0xdf ([kernel.kallsyms]) > swapper 0 [000] 1479253.989383: 359856 cpu-clock: ffffffff9d4ddb6f cpuidle_enter_state+0xdf ([kernel.kallsyms]) > swapper 0 [000] 1479253.989523: 140082 cpu-clock: ffffffff9d4ddb6f cpuidle_enter_state+0xdf ([kernel.kallsyms]) > > After: > swapper 0 [000] 1397040.402011: 272384 cpu-clock: ffffffff9d4ddb6f cpuidle_enter_state+0xdf ([kernel.kallsyms]) > swapper 0 [000] 1397040.402011: 5396 uncore_imc/data_reads/: > swapper 0 [000] 1397040.402011: 967 uncore_imc/data_writes/: > swapper 0 [000] 1397040.402259: 249153 cpu-clock: ffffffff9d4ddb6f cpuidle_enter_state+0xdf ([kernel.kallsyms]) > swapper 0 [000] 1397040.402259: 7231 uncore_imc/data_reads/: > swapper 0 [000] 1397040.402259: 1297 uncore_imc/data_writes/: > swapper 0 [000] 1397040.402508: 249108 cpu-clock: ffffffff9d4ddb6f cpuidle_enter_state+0xdf ([kernel.kallsyms]) > swapper 0 [000] 1397040.402508: 5333 uncore_imc/data_reads/: > swapper 0 [000] 1397040.402508: 1008 uncore_imc/data_writes/: > > Signed-off-by: Jin Yao Acked-by: Adrian Hunter > --- > v2: > Remove Fixes tag because this issue has always been here, not caused by > 1405720d4f26 ("perf script: Add 'synth' event type for synthesized events"). > No functional change in v2. > > tools/perf/builtin-script.c | 18 +++++++++++++++++- > 1 file changed, 17 insertions(+), 1 deletion(-) > > diff --git a/tools/perf/builtin-script.c b/tools/perf/builtin-script.c > index 1c322c129185..5d8a64836228 100644 > --- a/tools/perf/builtin-script.c > +++ b/tools/perf/builtin-script.c > @@ -183,6 +183,7 @@ struct output_option { > > enum { > OUTPUT_TYPE_SYNTH = PERF_TYPE_MAX, > + OUTPUT_TYPE_OTHER, > OUTPUT_TYPE_MAX > }; > > @@ -279,6 +280,18 @@ static struct { > > .invalid_fields = PERF_OUTPUT_TRACE | PERF_OUTPUT_BPF_OUTPUT, > }, > + > + [OUTPUT_TYPE_OTHER] = { > + .user_set = false, > + > + .fields = PERF_OUTPUT_COMM | PERF_OUTPUT_TID | > + PERF_OUTPUT_CPU | PERF_OUTPUT_TIME | > + PERF_OUTPUT_EVNAME | PERF_OUTPUT_IP | > + PERF_OUTPUT_SYM | PERF_OUTPUT_SYMOFFSET | > + PERF_OUTPUT_DSO | PERF_OUTPUT_PERIOD, > + > + .invalid_fields = PERF_OUTPUT_TRACE | PERF_OUTPUT_BPF_OUTPUT, > + }, > }; > > struct evsel_script { > @@ -339,8 +352,11 @@ static inline int output_type(unsigned int type) > case PERF_TYPE_SYNTH: > return OUTPUT_TYPE_SYNTH; > default: > - return type; > + if (type < PERF_TYPE_MAX) > + return type; > } > + > + return OUTPUT_TYPE_OTHER; > } > > static inline unsigned int attr_type(unsigned int type) >