Received: by 2002:a05:6a10:f347:0:0:0:0 with SMTP id d7csp520895pxu; Thu, 3 Dec 2020 06:20:17 -0800 (PST) X-Google-Smtp-Source: ABdhPJxDqNwh83rbIK0jhyIJpJZ5aqoxnkwaSR1+RHrUlf18mv3dNhV6SbtMw0QxojVXXeAdvLk3 X-Received: by 2002:a17:906:7a18:: with SMTP id d24mr2742463ejo.324.1607005217033; Thu, 03 Dec 2020 06:20:17 -0800 (PST) ARC-Seal: i=1; a=rsa-sha256; t=1607005217; cv=none; d=google.com; s=arc-20160816; b=ybDeL67WiqxZXUZVZ/1oSEMRN+at23KpPULy7uHgCaUmlChv8f3xzKfMVYOFBcx+Zo VqtLxVvIsBptkbpUeqcpWRR0z46/K+evWkjjpKLxdNTGFv3UTZ5yOwx7IUT6Uiw/GIaT 3SFk+ojtZL+dSS9fWWEyeBIj3jf17mktBsnfJ3DMCFGVRH1IKeBOmqUqyK1rmmNP1iOa cBlk/mIRQn2EBqYOvuKHCRuuigPm2i9ItzvrTVw+uX5XoEQhmjrGq5qwJk59Kmfi/wBN /+Z6Fds4U2ohC+Aui9wEDOPjgIMu3306pZOmhZQpXEEQDlGf9p2xFWqlD3oaVV/gNWgc FrBA== ARC-Message-Signature: i=1; a=rsa-sha256; c=relaxed/relaxed; d=google.com; s=arc-20160816; h=list-id:precedence:mime-version:message-id:date:subject:cc:to:from; bh=cGX+kFecAZE9AEhkdUGbMfAuNDwlT5AYRxFqXAc6zYs=; b=NlrfYRHBede/UE1CUbnjvIpzejdrhxxz7OT1X/41IdWnXiEZJscD+eHhC/pcMlrdgz R0KnB8bB7rEFvheTTJDcfoF7ORUW65YUO1SlutzBM3OnBIYJ8mAxiGgsGw0sxntxAC9U oXe7IF2kGAb8cduCZBDRJP9/2leD9C5T6QwgPkUZtYaFa9rRcOTGodB989hYONHVETdQ peY1hNlESrDV1cIHh44mYHEqnOfN2EpLX5F7RNGuUSLdodqtPSDNH6W7kTYEfSrK6+WT mA0nBQBcIYsNB6izU8yk/PILGnFFcq7qCOqbpTctbqK5D32EVSBQ2oWLCaB6gdZYk1Nb 6P8A== 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 Return-Path: Received: from vger.kernel.org (vger.kernel.org. [23.128.96.18]) by mx.google.com with ESMTP id t2si1216842ejd.302.2020.12.03.06.19.52; Thu, 03 Dec 2020 06:20:17 -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 Received: (majordomo@vger.kernel.org) by vger.kernel.org via listexpand id S1730911AbgLCORE (ORCPT + 99 others); Thu, 3 Dec 2020 09:17:04 -0500 Received: from szxga04-in.huawei.com ([45.249.212.190]:8628 "EHLO szxga04-in.huawei.com" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S1726361AbgLCORD (ORCPT ); Thu, 3 Dec 2020 09:17:03 -0500 Received: from DGGEMS410-HUB.china.huawei.com (unknown [172.30.72.60]) by szxga04-in.huawei.com (SkyGuard) with ESMTP id 4CmyYN3B3sz15WyR; Thu, 3 Dec 2020 22:15:52 +0800 (CST) Received: from euler.huawei.com (10.175.124.27) by DGGEMS410-HUB.china.huawei.com (10.3.19.210) with Microsoft SMTP Server id 14.3.487.0; Thu, 3 Dec 2020 22:16:13 +0800 From: Wei Li To: Catalin Marinas , Will Deacon , Mark Rutland , Suzuki K Poulose , Anshuman Khandual , Vincenzo Frascino , Marc Zyngier , Ionela Voinescu , Ard Biesheuvel , Amit Daniel Kachhap , Vladimir Murzin CC: , , Subject: [PATCH v4] drivers/perf: Add support for ARMv8.3-SPE Date: Thu, 3 Dec 2020 22:16:09 +0800 Message-ID: <20201203141609.14148-1-liwei391@huawei.com> X-Mailer: git-send-email 2.17.1 MIME-Version: 1.0 Content-Type: text/plain X-Originating-IP: [10.175.124.27] X-CFilter-Loop: Reflected Precedence: bulk List-ID: X-Mailing-List: linux-kernel@vger.kernel.org Armv8.3 extends the SPE by adding: - Alignment field in the Events packet, and filtering on this event using PMSEVFR_EL1. - Support for the Scalable Vector Extension (SVE). The main additions for SVE are: - Recording the vector length for SVE operations in the Operation Type packet. It is not possible to filter on vector length. - Incomplete predicate and empty predicate fields in the Events packet, and filtering on these events using PMSEVFR_EL1. Update the check of pmsevfr for empty/partial predicated SVE and alignment event in SPE driver. Signed-off-by: Wei Li --- v3 -> v4: - Return the highest supported version in default in arm_spe_pmsevfr_res0(). - Drop the exposing of 'pmsver'. (Suggested by Will.) --- v2 -> v3: - Make the definition of 'pmsevfr_res0' progressive and easy to check. (Suggested by Will.) --- v1 -> v2: - Rename 'pmuver' to 'pmsver', change it's type to 'u16' from 'int'. (Suggested by Will and Leo.) - Expose 'pmsver' as cap attribute through sysfs, instead of printing. (Suggested by Will.) --- arch/arm64/include/asm/sysreg.h | 9 ++++++++- drivers/perf/arm_spe_pmu.c | 17 +++++++++++++++-- 2 files changed, 23 insertions(+), 3 deletions(-) diff --git a/arch/arm64/include/asm/sysreg.h b/arch/arm64/include/asm/sysreg.h index d52c1b3ce589..57e5aee6f7e6 100644 --- a/arch/arm64/include/asm/sysreg.h +++ b/arch/arm64/include/asm/sysreg.h @@ -287,7 +287,11 @@ #define SYS_PMSFCR_EL1_ST_SHIFT 18 #define SYS_PMSEVFR_EL1 sys_reg(3, 0, 9, 9, 5) -#define SYS_PMSEVFR_EL1_RES0 0x0000ffff00ff0f55UL +#define SYS_PMSEVFR_EL1_RES0_8_2 \ + (GENMASK_ULL(47, 32) | GENMASK_ULL(23, 16) | GENMASK_ULL(11, 8) |\ + BIT_ULL(6) | BIT_ULL(4) | BIT_ULL(2) | BIT_ULL(0)) +#define SYS_PMSEVFR_EL1_RES0_8_3 \ + (SYS_PMSEVFR_EL1_RES0_8_2 & ~(BIT_ULL(18) | BIT_ULL(17) | BIT_ULL(11))) #define SYS_PMSLATFR_EL1 sys_reg(3, 0, 9, 9, 6) #define SYS_PMSLATFR_EL1_MINLAT_SHIFT 0 @@ -829,6 +833,9 @@ #define ID_AA64DFR0_PMUVER_8_5 0x6 #define ID_AA64DFR0_PMUVER_IMP_DEF 0xf +#define ID_AA64DFR0_PMSVER_8_2 0x1 +#define ID_AA64DFR0_PMSVER_8_3 0x2 + #define ID_DFR0_PERFMON_SHIFT 24 #define ID_DFR0_PERFMON_8_1 0x4 diff --git a/drivers/perf/arm_spe_pmu.c b/drivers/perf/arm_spe_pmu.c index cc00915ad6d1..bce9aff9f546 100644 --- a/drivers/perf/arm_spe_pmu.c +++ b/drivers/perf/arm_spe_pmu.c @@ -54,7 +54,7 @@ struct arm_spe_pmu { struct hlist_node hotplug_node; int irq; /* PPI */ - + u16 pmsver; u16 min_period; u16 counter_sz; @@ -655,6 +655,18 @@ static irqreturn_t arm_spe_pmu_irq_handler(int irq, void *dev) return IRQ_HANDLED; } +static u64 arm_spe_pmsevfr_res0(u16 pmsver) +{ + switch (pmsver) { + case ID_AA64DFR0_PMSVER_8_2: + return SYS_PMSEVFR_EL1_RES0_8_2; + case ID_AA64DFR0_PMSVER_8_3: + /* Return the highest version we support in default */ + default: + return SYS_PMSEVFR_EL1_RES0_8_3; + } +} + /* Perf callbacks */ static int arm_spe_pmu_event_init(struct perf_event *event) { @@ -670,7 +682,7 @@ static int arm_spe_pmu_event_init(struct perf_event *event) !cpumask_test_cpu(event->cpu, &spe_pmu->supported_cpus)) return -ENOENT; - if (arm_spe_event_to_pmsevfr(event) & SYS_PMSEVFR_EL1_RES0) + if (arm_spe_event_to_pmsevfr(event) & arm_spe_pmsevfr_res0(spe_pmu->pmsver)) return -EOPNOTSUPP; if (attr->exclude_idle) @@ -937,6 +949,7 @@ static void __arm_spe_pmu_dev_probe(void *info) fld, smp_processor_id()); return; } + spe_pmu->pmsver = (u16)fld; /* Read PMBIDR first to determine whether or not we have access */ reg = read_sysreg_s(SYS_PMBIDR_EL1); -- 2.17.1