Received: by 2002:a05:6a10:af89:0:0:0:0 with SMTP id iu9csp5787586pxb; Wed, 26 Jan 2022 22:25:06 -0800 (PST) X-Google-Smtp-Source: ABdhPJzAqj4sB07dDNmS5tawAP0YBRqrEYzfdbVP2tihzo8wpGWuD+PZAQlxcFKPdegC5zHqsfL8 X-Received: by 2002:a17:907:1c11:: with SMTP id nc17mr1835772ejc.320.1643264706389; Wed, 26 Jan 2022 22:25:06 -0800 (PST) ARC-Seal: i=1; a=rsa-sha256; t=1643264706; cv=none; d=google.com; s=arc-20160816; b=PG0+1mxWsoZCFZ+Pex3U+S9Ii4PwoerpUW7hnSJyKNTQodA0+kCELFg9aEUlVscPha o4B/physyDyXmAKVWgUhS0MNm7d0LwKyoNh3G7aMBrtIQ45TD7l6P1ntq6qSmZnrIzC2 S+T0g0T6E9R65fTbppqb4TEPimz6CoCIpESAqnDpnxnvHPed+izKVgL43UsENWAqbT9J h6/M5Sebnx5uVklVH/Hzu9Ni1g55Y2IV3v2jcMR+D7KVa61XSu0QyDBQ1a6H21RPY3e6 okJV3cgTXy+6xYL4hgNemDlnZ0SHHdz/rMHZ7prt2FTZ6c4uIcY3Dw7Rb7neEgyIVYoF ypzw== 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=/x8UT6OHwNZk2oDIrUxyBKL03hhewb0+Y3ttSVyTmgQ=; b=gs7QAcRZL3DQ5zbuwWatLHhInxqEoCzDASILFgnC/5rKPuS7YIfEhxj+uVv8mj+6e2 DnB7cqzU2w3sc6f4azttVhexxZEB1es2FOlFubwxmXc3sBd0UVUUPEmg/vmDmQKwA6/S m3mNp8svUSQTUjmqXVQTNLlFXi1fd1RAkXKXDhaWurl4aBwQfjGZzFU8/iZj8S7kY/4r HIy9AornE47j1Ie6XxHpe3i0sZfriLpstiohsXC79RSeU3l1iBefGIYse0c84sxmbAsd hrwyhgu1paDwrXmXm0MV96TaZDm+uPKeZnd1GAyNsHjI4VShJZP3edajmsD003OwAm8j mnHA== ARC-Authentication-Results: i=1; mx.google.com; dkim=pass header.i=@google.com header.s=20210112 header.b=A6bLsYgG; 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=REJECT sp=REJECT dis=NONE) header.from=google.com Return-Path: Received: from vger.kernel.org (vger.kernel.org. [23.128.96.18]) by mx.google.com with ESMTP id w12si839277edu.255.2022.01.26.22.24.42; Wed, 26 Jan 2022 22:25:06 -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; dkim=pass header.i=@google.com header.s=20210112 header.b=A6bLsYgG; 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=REJECT sp=REJECT dis=NONE) header.from=google.com Received: (majordomo@vger.kernel.org) by vger.kernel.org via listexpand id S233709AbiAZXfd (ORCPT + 99 others); Wed, 26 Jan 2022 18:35:33 -0500 Received: from lindbergh.monkeyblade.net ([23.128.96.19]:44712 "EHLO lindbergh.monkeyblade.net" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S233702AbiAZXfY (ORCPT ); Wed, 26 Jan 2022 18:35:24 -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 9B06EC061749 for ; Wed, 26 Jan 2022 15:35:24 -0800 (PST) Received: by mail-yb1-xb49.google.com with SMTP id n2-20020a255902000000b0060f9d75eafeso2514003ybb.1 for ; Wed, 26 Jan 2022 15:35:24 -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=/x8UT6OHwNZk2oDIrUxyBKL03hhewb0+Y3ttSVyTmgQ=; b=A6bLsYgG1zkWkfe4m2XZTOjuirX/KBhuA46s7HjnKWxCeVNOEjeL+1dY2nWSl4vfcm FFuu8DVEb7ExOMLs2VlAOsXncYDF+IYO38uA8wsysJUh518AswCOClh9WIAC02hdTge1 fP9mKIyfCWLH193ZlmRPe/fbtvxxU7pUCMUY9oVmh58NelKbKM4DS9ErFviJ1xg5AS3+ RoGKe2o8523jCVa+jBZEjpN3Uh2/3Zy5DJsnf1XtMOVM8WMyb5R/kTbh7/tnUGhRsiAa tNDO31w8GmZoz8h9TZxD1y/rq9VhQ82f6C4Stj8yxMmvJmpMWXMTXdgrZvLAio+YFGVr GRmw== 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=/x8UT6OHwNZk2oDIrUxyBKL03hhewb0+Y3ttSVyTmgQ=; b=dNcdpRWRyPuKrcqE1MzRhwOK5OA+IYFM7IXrTEYqldJjZXgRjBb/gqLa4g0PEQE4ZQ e8Be5QGol6IxkgIsOy7UXo7EtM/KP1PVr9f24KJT+8+3of4RR0BKZWuWMm7KQRGEOOvu GVSb4wIiasLk/sXKgZOw0cNg1fZ7RpsvpIitoLJr29PyDQIBbKTMAiG1Xlo0av49/IDm 7S4SylhOeg2V95r32v9zKd9j2v4nmEUyUvP/SMcP5fHK50qcQl3ke1r95+0sHKUBg/AB lbwRZLvIqvjIZ3lzL6USOhuPunBuSUkwZ2DA5sYZI8idS2o8AUhhuasr2TFtHNWQKaaS rAJQ== X-Gm-Message-State: AOAM533DS0Qq0xDr3JI0orky87YLmyU0vssLnEQiwFjtUJ5d3xe2HSby QqkFu7P5xtj31+QhCjQnO3m4j8FEuKtHrPpKS0t5Fp1pB1/yCN7B8e7/dkvHGWul7zXPDazGroc 7kFAXFhhcm8XWZ2qyWguk/dBnW1KtwTjqFk1kmm05BBZ9WezQbmebbHt7Lmvp0UxhYTS62Ck+ X-Received: from uluru3.svl.corp.google.com ([2620:15c:2cd:202:9ce0:6f20:c145:eac]) (user=eranian job=sendgmr) by 2002:a81:347:: with SMTP id 68mr1ywd.40.1643240123407; Wed, 26 Jan 2022 15:35:23 -0800 (PST) Date: Wed, 26 Jan 2022 15:34:45 -0800 In-Reply-To: <20220126233454.3362047-1-eranian@google.com> Message-Id: <20220126233454.3362047-5-eranian@google.com> Mime-Version: 1.0 References: <20220126233454.3362047-1-eranian@google.com> X-Mailer: git-send-email 2.35.0.rc0.227.g00780c9af4-goog Subject: [PATCH v5 04/13] 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" Precedence: bulk List-ID: X-Mailing-List: linux-kernel@vger.kernel.org This patch adds 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.rc0.227.g00780c9af4-goog