Received: by 2002:a05:6a10:1a4d:0:0:0:0 with SMTP id nk13csp1580306pxb; Tue, 8 Feb 2022 23:01:20 -0800 (PST) X-Google-Smtp-Source: ABdhPJx3mGESMYiT8ZTuOGs/UjsKf0etPYSSle9jfGsmmNOgXIlPrJLOX+XnYkoWflJmzNfb4sxn X-Received: by 2002:a17:90b:4f85:: with SMTP id qe5mr1894059pjb.142.1644390080174; Tue, 08 Feb 2022 23:01:20 -0800 (PST) ARC-Seal: i=1; a=rsa-sha256; t=1644390080; cv=none; d=google.com; s=arc-20160816; b=dO3WlGM5+osC8gD3LQVffMkzAwCbP5gUOc5mydcIoIp3xt5PIYEqIQlkGTv3uTDb4t TlIJN27GthGs7+gugOXnb9bl3bY/Fws/ijuSCrsSYIfQNVm+fgRYBMB2PyNBykFhMvV0 LhV+rDrLNAd101GJ/N4qj5ABlqu+miTrxNAFV0pba7dCopYOsRE5RWCWXEoMyDK0eIwV VI4ax1Y6ctwfCZTDtVWvdeKjyk5mfPYrFCcdHmtobhvVhLEze9jCrv4volTUfDhcLk7F n9CbNtGOHyFO8an+HXbZ7XYEFBWI6RH4N9VOygHnxj2V6iS0Lig+p2Oder+ot6xgvitg 5Nkg== ARC-Message-Signature: i=1; a=rsa-sha256; c=relaxed/relaxed; d=google.com; s=arc-20160816; h=list-id:precedence:cc:to:from:subject:references:mime-version :message-id:in-reply-to:date:dkim-signature; bh=hpYRwQLRBekfx+PCqt9/1HSAYQriRfUkssje8sUgZSw=; b=ESHHJOwMaa3hsOXu9VmvfaJv1f+wd4lCw6QZxjq/V6xApo5IxPU9YQ2q2YgDuwWXLV 1U8gJ3i4y1QPQfUkK+hBNZiBswZuxKi/Q7JfyK30I8P7aJ5NMaJSxAw9GuRN4J1e6y3m QXHO35KjT3gTO/0vZwl73L8RRSxMNrbx4J3OtbWUaO/2iJqBCm7kkcXlrHCMS1L17UV5 LvYTyXcF93oDEKlrpDtp3J4ZC0wryv4nPPEF41bQM2O1688tqyDmUTdHxcGut1DfJyeN ve/PmWjLXmpps/VhDQ1xXlDSH7DUoUuBbwkK7qwr/4Kqw4FfEeDIiveZSMdL7rQOz2/0 8uZw== ARC-Authentication-Results: i=1; mx.google.com; dkim=pass header.i=@google.com header.s=20210112 header.b=sOK4RMt8; spf=softfail (google.com: domain of transitioning linux-kernel-owner@vger.kernel.org does not designate 23.128.96.19 as permitted sender) smtp.mailfrom=linux-kernel-owner@vger.kernel.org; dmarc=pass (p=REJECT sp=REJECT dis=NONE) header.from=google.com Return-Path: Received: from lindbergh.monkeyblade.net (lindbergh.monkeyblade.net. [23.128.96.19]) by mx.google.com with ESMTPS id s9si14872696pfu.100.2022.02.08.23.01.14 (version=TLS1_3 cipher=TLS_AES_256_GCM_SHA384 bits=256/256); Tue, 08 Feb 2022 23:01:20 -0800 (PST) Received-SPF: softfail (google.com: domain of transitioning linux-kernel-owner@vger.kernel.org does not designate 23.128.96.19 as permitted sender) client-ip=23.128.96.19; Authentication-Results: mx.google.com; dkim=pass header.i=@google.com header.s=20210112 header.b=sOK4RMt8; spf=softfail (google.com: domain of transitioning linux-kernel-owner@vger.kernel.org does not designate 23.128.96.19 as permitted sender) smtp.mailfrom=linux-kernel-owner@vger.kernel.org; dmarc=pass (p=REJECT sp=REJECT dis=NONE) header.from=google.com Received: from vger.kernel.org (vger.kernel.org [23.128.96.18]) by lindbergh.monkeyblade.net (Postfix) with ESMTP id A7834E024615; Tue, 8 Feb 2022 22:28:10 -0800 (PST) Received: (majordomo@vger.kernel.org) by vger.kernel.org via listexpand id S1387514AbiBHWbY (ORCPT + 99 others); Tue, 8 Feb 2022 17:31:24 -0500 Received: from lindbergh.monkeyblade.net ([23.128.96.19]:37544 "EHLO lindbergh.monkeyblade.net" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S1386846AbiBHVRD (ORCPT ); Tue, 8 Feb 2022 16:17:03 -0500 Received: from mail-yb1-xb49.google.com (mail-yb1-xb49.google.com [IPv6:2607:f8b0:4864:20::b49]) by lindbergh.monkeyblade.net (Postfix) with ESMTPS id 5E5C8C0612B8 for ; Tue, 8 Feb 2022 13:17:02 -0800 (PST) Received: by mail-yb1-xb49.google.com with SMTP id a12-20020a056902056c00b0061dc0f2a94aso387895ybt.6 for ; Tue, 08 Feb 2022 13:17:02 -0800 (PST) DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/relaxed; d=google.com; s=20210112; h=date:in-reply-to:message-id:mime-version:references:subject:from:to :cc; bh=hpYRwQLRBekfx+PCqt9/1HSAYQriRfUkssje8sUgZSw=; b=sOK4RMt818cUZPOEOHeyV19TBhn5uBFBKquSjktW5SYy6qRp9nBkRB82fA/OVrQjbT zau9QpGFLq0wy5gqkLyktdJ/aVwh/ojsgDGOtbvxJZf1hkv5G/7vXYBwFrpS1Uq3HNEI ue/kBM5PmsKiJMkyb6+pSVEC8gVxrSvyPnpj1zhvFbVmCaT4SVVJ1VUniIDOkdaBGCZi RhIurQT6LcLl3Db57CNeL4P9lc7NX4fzwSg5TwmKlwme9XdHYekJeq5d55zAR6qnAf84 nkcHMYvnUwAWz1l4fHySz7vdZYVT+Vh4z/3jNBoPfLTrPKiZeUlfQT4zZ9AE9hlG2A++ ftCQ== X-Google-DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/relaxed; d=1e100.net; s=20210112; h=x-gm-message-state:date:in-reply-to:message-id:mime-version :references:subject:from:to:cc; bh=hpYRwQLRBekfx+PCqt9/1HSAYQriRfUkssje8sUgZSw=; b=hGti+he40Usil3qtJAxTfBSNRVnKBk3Kc+TiGa8agcqc7HYWqfeXslM+nm2PK3X94L v5zLsONo9PnK74Dbi60CsLCBRndO20sWP/V9wLaTKPsytDkaCPTsrB0zbhORjh13pVtN SP+1EGlt7fu5yX242mSzgfD0t++7XRhYoYoI9ziAS+nq4cxi4Ny3sZbHVnrtVmvVw6bB xZ3/YxjgM52uzej41gaoGAgP9BZGzzJaXBtRyiO9mkdQDxhK2Y5WE0LbiI3+HNqki8IG Tc6dLhs3ph6T74HhBBTa3XJN8aHCXrptJo+RSDtoekf+xTCH4Caa6ABIrnVNBJm1GSR/ wNIA== X-Gm-Message-State: AOAM5308KorsR5YhbklsNIe+JUUGWymk6ZSpd7vAa/jX8jJ9S/2KH/Je Iq98h3PtLG/m11xmi8bnuZ/fPvYCD2CrIbGz3l7cCovQkPJAzfncKMHdCds0oHaXEWXq3HQQnZJ +H1m6lt6dl6LkgEsg4d2Uefnc0LmqMFGNjR0i9pSzlX8I4lGUjS/SNKZ1WXYjjGkWeWZ37XEl X-Received: from uluru3.svl.corp.google.com ([2620:15c:2cd:202:6875:3c51:69be:6e2c]) (user=eranian job=sendgmr) by 2002:a25:e803:: with SMTP id k3mr6732621ybd.571.1644355021597; Tue, 08 Feb 2022 13:17:01 -0800 (PST) Date: Tue, 8 Feb 2022 13:16:29 -0800 In-Reply-To: <20220208211637.2221872-1-eranian@google.com> Message-Id: <20220208211637.2221872-5-eranian@google.com> Mime-Version: 1.0 References: <20220208211637.2221872-1-eranian@google.com> X-Mailer: git-send-email 2.35.0.263.gb82422642f-goog Subject: [PATCH v6 04/12] perf/x86/amd: add branch-brs helper event for Fam19h BRS From: Stephane Eranian To: linux-kernel@vger.kernel.org Cc: peterz@infradead.org, kim.phillips@amd.com, acme@redhat.com, jolsa@redhat.com, songliubraving@fb.com Content-Type: text/plain; charset="UTF-8" X-Spam-Status: No, score=-15.3 required=5.0 tests=BAYES_00,DKIMWL_WL_MED, DKIM_SIGNED,DKIM_VALID,DKIM_VALID_AU,HEADER_FROM_DIFFERENT_DOMAINS, MAILING_LIST_MULTI,RCVD_IN_DNSWL_HI,SPF_HELO_PASS,SPF_PASS, T_SCC_BODY_TEXT_LINE,USER_IN_DEF_DKIM_WL autolearn=unavailable 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 Add a pseudo event called branch-brs to help use the FAM Fam19h Branch Sampling feature (BRS). BRS samples taken branches, so it is best used when sampling on a retired taken branch event (0xc4) which is what BRS captures. Instead of trying to remember the event code or actual event name, users can simply do: $ perf record -b -e cpu/branch-brs/ -c 1000037 ..... Signed-off-by: Stephane Eranian --- arch/x86/events/amd/core.c | 16 ++++++++++++++++ 1 file changed, 16 insertions(+) diff --git a/arch/x86/events/amd/core.c b/arch/x86/events/amd/core.c index 44d8f618bb3e..597defee1e02 100644 --- a/arch/x86/events/amd/core.c +++ b/arch/x86/events/amd/core.c @@ -1105,8 +1105,24 @@ static struct attribute_group group_caps_amd_brs = { .is_visible = amd_brs_is_visible, }; +#define AMD_FAM19H_BRS_EVENT 0xc4 /* Fam19h RETIRED_TAKEN_BRANCH_INSTRUCTIONS */ +EVENT_ATTR_STR(branch-brs, amd_branch_brs, + "event=" __stringify(AMD_FAM19H_BRS_EVENT)"\n"); + +static struct attribute *amd_brs_events_attrs[] = { + EVENT_PTR(amd_branch_brs), + NULL, +}; + +static struct attribute_group group_events_amd_brs = { + .name = "events", + .attrs = amd_brs_events_attrs, + .is_visible = amd_brs_is_visible, +}; + static const struct attribute_group *amd_attr_update[] = { &group_caps_amd_brs, + &group_events_amd_brs, NULL, }; -- 2.35.0.263.gb82422642f-goog