Received: by 2002:a6b:500f:0:0:0:0:0 with SMTP id e15csp4821174iob; Mon, 9 May 2022 02:23:08 -0700 (PDT) X-Google-Smtp-Source: ABdhPJzA2+lloPDciHdB3Buv62lclLYL906kW6As2+DdCe0/rd/qge2cQT3pjX3USFvVILKkoDBK X-Received: by 2002:a62:15c7:0:b0:50d:dce7:e807 with SMTP id 190-20020a6215c7000000b0050ddce7e807mr15006727pfv.38.1652088188220; Mon, 09 May 2022 02:23:08 -0700 (PDT) ARC-Seal: i=1; a=rsa-sha256; t=1652088188; cv=none; d=google.com; s=arc-20160816; b=OeWrdux7rWCWZGa+x8yJU1boXKtCtfqOJiFUc0OdGRVDDpbmj9EJHtAT0SGGEZ50C6 /ug3d8RxMfhz5SSTFjkkkiXJaNmeKLOijiLz16qhh7TOgpXkk0qsys1Sqo4OSzg9vnVa 8mYVd1fDvEuQ/oWyyH3EMxjuQtsaCnZbahkMEE1Vz2Zt0EO4fEjsTbByNuERtPS2g5Tt p42d8NTQ0FXyTKyQneJ/2keRd8oSamW6wiyVNhqj6nzuhMgFVl7JR7CuumCQynA1V3M9 acOusgUANZYgGGXIlkaQC34V9+nAxuuBhYdA8IJUHdLtqc/0Vm341GbTI7k4dHx95GO6 l74Q== ARC-Message-Signature: i=1; a=rsa-sha256; c=relaxed/relaxed; d=google.com; s=arc-20160816; h=list-id:precedence:content-transfer-encoding:mime-version :references:in-reply-to:message-id:date:subject:cc:to:from :dkim-signature; bh=OU6pd7Lt5oEt5wQwCFS/HKNGGyS7IdmjRp7WJd3VCBc=; b=QrSpG29zF16dXekQk/7yMK681Yp7YS8js2Ic9EPykiHthecQyss1Lj38va7jue1m+O exkjFy+l+hm2er5kfcyJh34bv6S4meIjkRQrWmtfSRo5J1IDDVuB+u2ZYoaAkhK7xptl ozR1HDlJci3BCDVtkIVpr4QDp+8iwQEPQumYw5YQhkEQOluUPBjhXI5tcWta6RNne7Kx WFaVz+Fy87DJFvtyQjc2EJu2ssRR3jA6kDd3CfN+n4by/Yv5PFWLpmeqrO79CElTDt9r PqUv/vJVlE9RgV8lGrwbNaqMHV3qeGJWXJhF8S9B4SIUZx1u/twgXtbAtWY+/vjqLDSp oj5g== ARC-Authentication-Results: i=1; mx.google.com; dkim=pass header.i=@linaro.org header.s=google header.b=VYzAF5l8; spf=pass (google.com: domain of linux-kernel-owner@vger.kernel.org designates 2620:137:e000::1:18 as permitted sender) smtp.mailfrom=linux-kernel-owner@vger.kernel.org; dmarc=pass (p=NONE sp=NONE dis=NONE) header.from=linaro.org Return-Path: Received: from lindbergh.monkeyblade.net (lindbergh.monkeyblade.net. [2620:137:e000::1:18]) by mx.google.com with ESMTPS id b83-20020a621b56000000b0050ac8ed8f31si12670619pfb.132.2022.05.09.02.23.07 (version=TLS1_3 cipher=TLS_AES_256_GCM_SHA384 bits=256/256); Mon, 09 May 2022 02:23:08 -0700 (PDT) Received-SPF: pass (google.com: domain of linux-kernel-owner@vger.kernel.org designates 2620:137:e000::1:18 as permitted sender) client-ip=2620:137:e000::1:18; Authentication-Results: mx.google.com; dkim=pass header.i=@linaro.org header.s=google header.b=VYzAF5l8; spf=pass (google.com: domain of linux-kernel-owner@vger.kernel.org designates 2620:137:e000::1:18 as permitted sender) smtp.mailfrom=linux-kernel-owner@vger.kernel.org; dmarc=pass (p=NONE sp=NONE dis=NONE) header.from=linaro.org Received: from vger.kernel.org (vger.kernel.org [23.128.96.18]) by lindbergh.monkeyblade.net (Postfix) with ESMTP id A39BD16A5EE; Mon, 9 May 2022 02:12:25 -0700 (PDT) Received: (majordomo@vger.kernel.org) by vger.kernel.org via listexpand id S232877AbiEHJ31 (ORCPT + 99 others); Sun, 8 May 2022 05:29:27 -0400 Received: from lindbergh.monkeyblade.net ([23.128.96.19]:55108 "EHLO lindbergh.monkeyblade.net" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S233328AbiEHJ3C (ORCPT ); Sun, 8 May 2022 05:29:02 -0400 Received: from mail-pf1-x429.google.com (mail-pf1-x429.google.com [IPv6:2607:f8b0:4864:20::429]) by lindbergh.monkeyblade.net (Postfix) with ESMTPS id 43043E019 for ; Sun, 8 May 2022 02:25:13 -0700 (PDT) Received: by mail-pf1-x429.google.com with SMTP id v11so9872644pff.6 for ; Sun, 08 May 2022 02:25:13 -0700 (PDT) DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/relaxed; d=linaro.org; s=google; h=from:to:cc:subject:date:message-id:in-reply-to:references :mime-version:content-transfer-encoding; bh=OU6pd7Lt5oEt5wQwCFS/HKNGGyS7IdmjRp7WJd3VCBc=; b=VYzAF5l8qRONudNoXTyyFhGy2XU3HjJxX3qp8CjpbWOCT2IPYWpcvvhZF6tbChhEwY M0jKhE9EwSZMWQfMbvz94GyB9ij1vVR31af+M1PecOl8YEYuTQ5K3C+QkQVNm+RLBKnZ p5AQ5O38clalATtODtnQaw55MF5CmTy7ZnBJpGvABD5YMMP22nZ2iSbsgQAmeIsl/S8c rAuZX1qsUNXW+wsh9BplsYeL53DYHgPUCe82bzjo0cBjP/XWGu/jy1/f5/GIMZnorzlc oqAHLohWmN0NMpFivSIjteroUTobmY3QMy27V+omI0BDtezhgtZCH/JTUI7B1KyH9EOw 2EZQ== X-Google-DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/relaxed; d=1e100.net; s=20210112; h=x-gm-message-state:from:to:cc:subject:date:message-id:in-reply-to :references:mime-version:content-transfer-encoding; bh=OU6pd7Lt5oEt5wQwCFS/HKNGGyS7IdmjRp7WJd3VCBc=; b=t/1bDqFQKf02N8gUj9PxHpSsRQMAECBxsPWPV7VpbsrJ8hIRVgxFLaLuSG2j/hO0S9 GK0i/zXNE6Fijy0MKlw6uW0eEgeAVCgDgcllya6IM3fakxpkJK3ft2O4P9S0NlLjSZF6 SgsBH0xUTaWYuFrMqXubeTScPzUdOybK04kj89iN75vKxCjUjEcfDVzQC/pXp5uZkW2Q rn45gvq//vRyl5u98xi9kXdGtlbD2knhFACoMylAx0vBv3I6J47ZgL7JLgYDra96H5U5 RQqcomOIp41Cg3rfVXajcENvaALr9jEmFAV55TBxWloPlmYHbGq/ykRWv+ZDdrnlRoLr UwAQ== X-Gm-Message-State: AOAM5319M9sBFhqRwMK9USLlBih0pfsmRU1HJk6Q1WJGte/Yjm1TqNbd 7qDeqsFTkH40EoF1IvgJApLRUDkFelgRVSyy2Go= X-Received: by 2002:a05:6a00:88f:b0:510:7a49:b72f with SMTP id q15-20020a056a00088f00b005107a49b72fmr10682181pfj.21.1652001912589; Sun, 08 May 2022 02:25:12 -0700 (PDT) Received: from localhost.localdomain (104-237-153-19.ip.linodeusercontent.com. [104.237.153.19]) by smtp.gmail.com with ESMTPSA id t63-20020a638142000000b003c14af505f7sm6155088pgd.15.2022.05.08.02.25.02 (version=TLS1_3 cipher=TLS_AES_256_GCM_SHA384 bits=256/256); Sun, 08 May 2022 02:25:12 -0700 (PDT) From: Leo Yan To: Arnaldo Carvalho de Melo , Peter Zijlstra , Ingo Molnar , Mark Rutland , Alexander Shishkin , Jiri Olsa , Namhyung Kim , Like Xu , Ian Rogers , Alyssa Ross , Kajol Jain , Li Huafei , German Gomez , James Clark , Kan Liang , Ali Saidi , linux-perf-users@vger.kernel.org, linux-kernel@vger.kernel.org Cc: Leo Yan Subject: [PATCH v2 06/11] perf c2c: Use explicit names for display macros Date: Sun, 8 May 2022 17:23:41 +0800 Message-Id: <20220508092346.255826-7-leo.yan@linaro.org> X-Mailer: git-send-email 2.25.1 In-Reply-To: <20220508092346.255826-1-leo.yan@linaro.org> References: <20220508092346.255826-1-leo.yan@linaro.org> MIME-Version: 1.0 Content-Transfer-Encoding: 8bit X-Spam-Status: No, score=-2.0 required=5.0 tests=BAYES_00,DKIM_SIGNED, DKIM_VALID,DKIM_VALID_AU,HEADER_FROM_DIFFERENT_DOMAINS, MAILING_LIST_MULTI,RDNS_NONE,SPF_HELO_NONE,T_SCC_BODY_TEXT_LINE autolearn=no autolearn_force=no version=3.4.6 X-Spam-Checker-Version: SpamAssassin 3.4.6 (2021-04-09) on lindbergh.monkeyblade.net Precedence: bulk List-ID: X-Mailing-List: linux-kernel@vger.kernel.org Perf c2c tool has an assumption that it heavily depends on HITM snoop type to detect cache false sharing, unfortunately, HITM is not supported on some architectures. Essentially, perf c2c tool wants to find some very costly snooping operations for false cache sharing, this means it's not necessarily to stick using HITM tags and we can explore other snooping types (e.g. SNOOPX_PEER). For this reason, this patch renames HITM related display macros with suffix '_HITM', so it can be distinct if later add more display types for on other snooping type. Signed-off-by: Leo Yan Tested-by: Ali Saidi --- tools/perf/builtin-c2c.c | 58 ++++++++++++++++++++-------------------- 1 file changed, 29 insertions(+), 29 deletions(-) diff --git a/tools/perf/builtin-c2c.c b/tools/perf/builtin-c2c.c index baa003c150b1..180208a4085f 100644 --- a/tools/perf/builtin-c2c.c +++ b/tools/perf/builtin-c2c.c @@ -114,16 +114,16 @@ struct perf_c2c { }; enum { - DISPLAY_LCL, - DISPLAY_RMT, - DISPLAY_TOT, + DISPLAY_LCL_HITM, + DISPLAY_RMT_HITM, + DISPLAY_TOT_HITM, DISPLAY_MAX, }; static const char *display_str[DISPLAY_MAX] = { - [DISPLAY_LCL] = "Local", - [DISPLAY_RMT] = "Remote", - [DISPLAY_TOT] = "Total", + [DISPLAY_LCL_HITM] = "Local", + [DISPLAY_RMT_HITM] = "Remote", + [DISPLAY_TOT_HITM] = "Total", }; static const struct option c2c_options[] = { @@ -807,15 +807,15 @@ static double percent_hitm(struct c2c_hist_entry *c2c_he) total = &hists->stats; switch (c2c.display) { - case DISPLAY_RMT: + case DISPLAY_RMT_HITM: st = stats->rmt_hitm; tot = total->rmt_hitm; break; - case DISPLAY_LCL: + case DISPLAY_LCL_HITM: st = stats->lcl_hitm; tot = total->lcl_hitm; break; - case DISPLAY_TOT: + case DISPLAY_TOT_HITM: st = stats->tot_hitm; tot = total->tot_hitm; default: @@ -1181,15 +1181,15 @@ node_entry(struct perf_hpp_fmt *fmt __maybe_unused, struct perf_hpp *hpp, advance_hpp(hpp, ret); switch (c2c.display) { - case DISPLAY_RMT: + case DISPLAY_RMT_HITM: ret = display_metrics(hpp, stats->rmt_hitm, c2c_he->stats.rmt_hitm); break; - case DISPLAY_LCL: + case DISPLAY_LCL_HITM: ret = display_metrics(hpp, stats->lcl_hitm, c2c_he->stats.lcl_hitm); break; - case DISPLAY_TOT: + case DISPLAY_TOT_HITM: ret = display_metrics(hpp, stats->tot_hitm, c2c_he->stats.tot_hitm); break; @@ -1545,9 +1545,9 @@ static struct c2c_dimension dim_tot_loads = { }; static struct c2c_header percent_hitm_header[] = { - [DISPLAY_LCL] = HEADER_BOTH("Lcl", "Hitm"), - [DISPLAY_RMT] = HEADER_BOTH("Rmt", "Hitm"), - [DISPLAY_TOT] = HEADER_BOTH("Tot", "Hitm"), + [DISPLAY_LCL_HITM] = HEADER_BOTH("Lcl", "Hitm"), + [DISPLAY_RMT_HITM] = HEADER_BOTH("Rmt", "Hitm"), + [DISPLAY_TOT_HITM] = HEADER_BOTH("Tot", "Hitm"), }; static struct c2c_dimension dim_percent_hitm = { @@ -2018,15 +2018,15 @@ static bool he__display(struct hist_entry *he, struct c2c_stats *stats) c2c_he = container_of(he, struct c2c_hist_entry, he); switch (c2c.display) { - case DISPLAY_LCL: + case DISPLAY_LCL_HITM: he->filtered = filter_display(c2c_he->stats.lcl_hitm, stats->lcl_hitm); break; - case DISPLAY_RMT: + case DISPLAY_RMT_HITM: he->filtered = filter_display(c2c_he->stats.rmt_hitm, stats->rmt_hitm); break; - case DISPLAY_TOT: + case DISPLAY_TOT_HITM: he->filtered = filter_display(c2c_he->stats.tot_hitm, stats->tot_hitm); break; @@ -2049,13 +2049,13 @@ static inline bool is_valid_hist_entry(struct hist_entry *he) return true; switch (c2c.display) { - case DISPLAY_LCL: + case DISPLAY_LCL_HITM: has_record = !!c2c_he->stats.lcl_hitm; break; - case DISPLAY_RMT: + case DISPLAY_RMT_HITM: has_record = !!c2c_he->stats.rmt_hitm; break; - case DISPLAY_TOT: + case DISPLAY_TOT_HITM: has_record = !!c2c_he->stats.tot_hitm; break; default: @@ -2752,11 +2752,11 @@ static int setup_display(const char *str) const char *display = str ?: "tot"; if (!strcmp(display, "tot")) - c2c.display = DISPLAY_TOT; + c2c.display = DISPLAY_TOT_HITM; else if (!strcmp(display, "rmt")) - c2c.display = DISPLAY_RMT; + c2c.display = DISPLAY_RMT_HITM; else if (!strcmp(display, "lcl")) - c2c.display = DISPLAY_LCL; + c2c.display = DISPLAY_LCL_HITM; else { pr_err("failed: unknown display type: %s\n", str); return -1; @@ -2846,9 +2846,9 @@ static int setup_coalesce(const char *coalesce, bool no_source) return -1; if (asprintf(&c2c.cl_resort, "offset,%s", - c2c.display == DISPLAY_TOT ? + c2c.display == DISPLAY_TOT_HITM ? "tot_hitm" : - c2c.display == DISPLAY_RMT ? + c2c.display == DISPLAY_RMT_HITM ? "rmt_hitm,lcl_hitm" : "lcl_hitm,rmt_hitm") < 0) return -ENOMEM; @@ -3005,11 +3005,11 @@ static int perf_c2c__report(int argc, const char **argv) "ld_rmthit,rmt_hitm," "dram_lcl,dram_rmt"; - if (c2c.display == DISPLAY_TOT) + if (c2c.display == DISPLAY_TOT_HITM) sort_str = "tot_hitm"; - else if (c2c.display == DISPLAY_RMT) + else if (c2c.display == DISPLAY_RMT_HITM) sort_str = "rmt_hitm"; - else if (c2c.display == DISPLAY_LCL) + else if (c2c.display == DISPLAY_LCL_HITM) sort_str = "lcl_hitm"; c2c_hists__reinit(&c2c.hists, output_str, sort_str); -- 2.25.1