/* * Copyright (c) 2023, Arm Limited. All rights reserved. * * SPDX-License-Identifier: BSD-3-Clause */ #include #include #include #include /* * Applies to all PMU versions. Name is PMUv3 for compatibility with aarch64 and * to not clash with platforms which reuse the PMU name */ void pmuv3_disable_el3(void) { u_register_t sdcr = read_sdcr(); /* --------------------------------------------------------------------- * Initialise SDCR, setting all the fields rather than relying on hw. * * SDCR.SCCD: Set to one so that cycle counting by PMCCNTR is prohibited * in Secure state. This bit is RES0 in versions of the architecture * earlier than ARMv8.5 * * SDCR.SPME: Set to zero so that event counting is prohibited in Secure * state (and explicitly EL3 with later revisions). If ARMv8.2 Debug is * not implemented this bit does not have any effect on the counters * unless there is support for the implementation defined * authentication interface ExternalSecureNoninvasiveDebugEnabled(). * --------------------------------------------------------------------- */ sdcr = (sdcr | SDCR_SCCD_BIT) & ~SDCR_SPME_BIT; write_sdcr(sdcr); /* --------------------------------------------------------------------- * Initialise PMCR, setting all fields rather than relying * on hw. Some fields are architecturally UNKNOWN on reset. * * PMCR.DP: Set to one to prohibit cycle counting whilst in Secure mode. * * PMCR.X: Set to zero to disable export of events. * * PMCR.C: Set to one to reset PMCCNTR. * * PMCR.P: Set to one to reset each event counter PMEVCNTR to zero. * * PMCR.E: Set to zero to disable cycle and event counters. * --------------------------------------------------------------------- */ write_pmcr(read_pmcr() | PMCR_DP_BIT | PMCR_C_BIT | PMCR_P_BIT | ~(PMCR_X_BIT | PMCR_E_BIT)); }