Received: by 2002:a05:6a10:6744:0:0:0:0 with SMTP id w4csp445910pxu; Thu, 15 Oct 2020 07:55:17 -0700 (PDT) X-Google-Smtp-Source: ABdhPJzljIRoXezRWg1QXuBCIr3Y3idtP6syJ4wx28VcIx3Pi9ADue5jannSFZisVwkyyhjTpr6N X-Received: by 2002:a50:d2d3:: with SMTP id q19mr4895061edg.22.1602773717087; Thu, 15 Oct 2020 07:55:17 -0700 (PDT) ARC-Seal: i=1; a=rsa-sha256; t=1602773717; cv=none; d=google.com; s=arc-20160816; b=gaBOCmB/Zbs3OM6izp5pygVWv8QrkPzbuL3ICgGyhe59SRKgIm78Jq0OlrfkUw9JOq GStUQ8PDk/tcctaNi7P5fdvSdpA9AMUSFEk4bWVPGmdTSuufkmsBL66jRA97/t7TMAzl M/t1kY9Y0KpV5IO5G2k3DGjyO6NiQvR+MtkVurYdb8TcAb+goTev2ERsZIWGgIxRXCOR Dd8Sz/AfnQ5JlQiz8bvLFbUd2XrgbG1MDMISjqxxq7a8bY5Chd9otDM7yvL1hLgOouLI 1t8HE5u/YrEM+/47fALHJrchQz7R5m0uDLuffeEa+y99wclu/xKLqcuH8Y26OND6bEQD rbyw== 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:dkim-signature; bh=7cicsW6Li2DqvBdneepFP2/mKSl/GNLOAR6RTpCOJCs=; b=r10cUdl0LJebSlDo6DkeLaXXUNLEowcnXc0YbSwKIO/KdapB4aU+1gJsETJV4N0GTZ yDNCwtCE71H58Mk91A1qAK0GHyl/OuHHDHWBEEVxXZf5UFHW0/+BbNUzSmhbMc45j/pA Vneo+S61yQPPe4T9UESxkJpZ23Q2rP+iNrOzA8vCj884Mzh+h2Wyky6GAmca48mjHJq/ oXtqwabinTy4Y6a6JKrF1t6UlpwsX0kQQD4cDzTtZzQDHMLfH0tVzMLymh+J+Kme48rJ IlvTt1CIWYLKUt50/obgLxw0E6KvRPCDsVbcW3aL0/qJFGspzgncyMLKCzMYUY4zMqXS DHOg== ARC-Authentication-Results: i=1; mx.google.com; dkim=pass header.i=@linaro.org header.s=google header.b=uDW3hfYA; 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=pass (p=NONE sp=NONE dis=NONE) header.from=linaro.org Return-Path: Received: from vger.kernel.org (vger.kernel.org. [23.128.96.18]) by mx.google.com with ESMTP id a15si2062037edx.281.2020.10.15.07.54.44; Thu, 15 Oct 2020 07:55:17 -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; dkim=pass header.i=@linaro.org header.s=google header.b=uDW3hfYA; 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=pass (p=NONE sp=NONE dis=NONE) header.from=linaro.org Received: (majordomo@vger.kernel.org) by vger.kernel.org via listexpand id S2389376AbgJOOvS (ORCPT + 99 others); Thu, 15 Oct 2020 10:51:18 -0400 Received: from lindbergh.monkeyblade.net ([23.128.96.19]:60660 "EHLO lindbergh.monkeyblade.net" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S2389119AbgJOOvL (ORCPT ); Thu, 15 Oct 2020 10:51:11 -0400 Received: from mail-wr1-x444.google.com (mail-wr1-x444.google.com [IPv6:2a00:1450:4864:20::444]) by lindbergh.monkeyblade.net (Postfix) with ESMTPS id 86D9BC0613D3 for ; Thu, 15 Oct 2020 07:51:10 -0700 (PDT) Received: by mail-wr1-x444.google.com with SMTP id e17so3802400wru.12 for ; Thu, 15 Oct 2020 07:51:10 -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; bh=7cicsW6Li2DqvBdneepFP2/mKSl/GNLOAR6RTpCOJCs=; b=uDW3hfYA61HwBotGREnzjHEJ/YDWly8W5WOOEzSgiWkZpVIbH4zamH6iDyr8ynhTU9 vc69E/j0FAbT8fo+3AnpoHB+9La1gCGQ1HvTbrm+dPKntzfXTKwxQWt00SB+sGXqDpyO Vvb2JJz52ttYUGj496KpBi25f6yge0U2zIgiIfn9tfe2PKz2j9rRJjfQ4l7DLJk2h2nJ s8noNTxnKXDN4f3eNCFnw99CC0jFdGBf21gb0SxBbTJB2grsrmVl3yvTniEHPG9OMLFa 9izWmXfF7RnjYK8JZR0WVGJn0mkc/cV/0+5LhzjcpjlI19YGKqYcJjSL4xdNVZrksRIC 1R9g== X-Google-DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/relaxed; d=1e100.net; s=20161025; h=x-gm-message-state:from:to:cc:subject:date:message-id:in-reply-to :references; bh=7cicsW6Li2DqvBdneepFP2/mKSl/GNLOAR6RTpCOJCs=; b=hT7zHTUoj4QHn1U6CSnbSMYzaN9K6NO3gYASzHK2oOhyNuL53RuSvVo1JtTmlL9Zc2 khVLf4K7s9JG70mayjKqYWvYCxac9BmJfJ7buUnG4uAFQLu9C5JfubfYCIJfEf9/T50d 9fYMdIF8/kRmFEfY0BTXrjU7zvfCh5BnyssXYFfBDeHwpUpyRjYDRkj9XWPhV7pwmgP3 0V/ajk1RvTCWO9lOJsum3xOB8TLvIswNce1/TUjc31zhqEUyA0U4i0whAGdlDEVdvda8 BOd0dmtaaOG32GtwIYQt/76Df//o7UdqtcJ5c+TnK6myIVPJOyRYRQlBS79smhIAOMsa Md5Q== X-Gm-Message-State: AOAM531/QWqzg7RYEaLRhbvD0EME2QRRv/l/tehp2N3LsXAnuHB0Bv5n 07879PJUyV1cHiYnmVAbLFWwqw== X-Received: by 2002:a5d:6744:: with SMTP id l4mr4948264wrw.18.1602773469195; Thu, 15 Oct 2020 07:51:09 -0700 (PDT) Received: from hackbox2.linaro.org ([81.128.185.34]) by smtp.gmail.com with ESMTPSA id x65sm5144733wmg.1.2020.10.15.07.51.07 (version=TLS1_3 cipher=TLS_AES_256_GCM_SHA384 bits=256/256); Thu, 15 Oct 2020 07:51:08 -0700 (PDT) From: Leo Yan To: Arnaldo Carvalho de Melo , Peter Zijlstra , Ingo Molnar , Mark Rutland , Alexander Shishkin , Jiri Olsa , Namhyung Kim , Kan Liang , Andi Kleen , Ian Rogers , Joe Mario , David Ahern , Don Zickus , Al Grant , James Clark , linux-kernel@vger.kernel.org Cc: Leo Yan Subject: [PATCH v1 6/8] perf c2c: Refactor hist entry validation Date: Thu, 15 Oct 2020 15:50:39 +0100 Message-Id: <20201015145041.10953-7-leo.yan@linaro.org> X-Mailer: git-send-email 2.17.1 In-Reply-To: <20201015145041.10953-1-leo.yan@linaro.org> References: <20201015145041.10953-1-leo.yan@linaro.org> Precedence: bulk List-ID: X-Mailing-List: linux-kernel@vger.kernel.org This patch has no any functionality change but only refactors hist entry validation for cacheline resorting. It renames function "valid_hitm_or_store()" to "is_valid_hist_entry()", changes return type from integer type to bool type. In the function, it uses switch-case instead of ternary operators for better readability. Signed-off-by: Leo Yan --- tools/perf/builtin-c2c.c | 30 +++++++++++++++++++++++------- 1 file changed, 23 insertions(+), 7 deletions(-) diff --git a/tools/perf/builtin-c2c.c b/tools/perf/builtin-c2c.c index 7962cc70b855..d15a6220bfd0 100644 --- a/tools/perf/builtin-c2c.c +++ b/tools/perf/builtin-c2c.c @@ -2011,16 +2011,32 @@ static bool he__display(struct hist_entry *he, struct c2c_stats *stats) return he->filtered == 0; } -static inline int valid_hitm_or_store(struct hist_entry *he) +static inline bool is_valid_hist_entry(struct hist_entry *he) { struct c2c_hist_entry *c2c_he; - bool has_hitm; + bool has_record = false; c2c_he = container_of(he, struct c2c_hist_entry, he); - has_hitm = c2c.display == DISPLAY_TOT ? c2c_he->stats.tot_hitm : - c2c.display == DISPLAY_LCL ? c2c_he->stats.lcl_hitm : - c2c_he->stats.rmt_hitm; - return has_hitm || c2c_he->stats.store; + + /* It's a valid entry if contains stores */ + if (c2c_he->stats.store) + return true; + + switch (c2c.display) { + case DISPLAY_LCL: + has_record = !!c2c_he->stats.lcl_hitm; + break; + case DISPLAY_RMT: + has_record = !!c2c_he->stats.rmt_hitm; + break; + case DISPLAY_TOT: + has_record = !!c2c_he->stats.tot_hitm; + break; + default: + break; + } + + return has_record; } static void set_node_width(struct c2c_hist_entry *c2c_he, int len) @@ -2074,7 +2090,7 @@ static int filter_cb(struct hist_entry *he, void *arg __maybe_unused) calc_width(c2c_he); - if (!valid_hitm_or_store(he)) + if (!is_valid_hist_entry(he)) he->filtered = HIST_FILTER__C2C; return 0; -- 2.17.1