xref: /rk3399_ARM-atf/include/drivers/arm/dsu.h (revision 6fb6bee1dfd7fd896c44cc21b02b4ef3aad3bbd0)
1 /*
2  * Copyright (c) 2025, Arm Limited and Contributors. All rights reserved.
3  *
4  * SPDX-License-Identifier: BSD-3-Clause
5  */
6 
7 #ifndef DSU_H
8 #define DSU_H
9 
10 #if defined(__aarch64__)
11 #include <dsu_def.h>
12 
13 /*
14  * Power Control Registers enable bit of Auxilary Control register.
15  * ACTLR_EL3_PWREN_BIT definition is same among cores like Cortex-X925,
16  * Cortex-X4, Cortex-A520, Cortex-A725 that are used in a cluster
17  * with DSU.
18  */
19 #define ACTLR_EL3_PWREN_BIT		BIT(7)
20 
21 /* PMU Registers enable bit of Auxilary Control register of EL3 and EL2. */
22 #define ACTLR_CLUSTERPMUEN		BIT(12)
23 
24 #define PMCR_N_MAX			0x1f
25 
26 #define save_pmu_reg(state, reg) state->reg = read_##reg()
27 
28 #define restore_pmu_reg(context, reg) write_##reg(context->reg)
29 
30 typedef struct cluster_pmu_state {
31 	uint64_t clusterpmcr;
32 	uint64_t clusterpmcntenset;
33 	uint64_t clusterpmccntr;
34 	uint64_t clusterpmovsset;
35 	uint64_t clusterpmselr;
36 	uint64_t clusterpmsevtyper;
37 	uint64_t counter_val[PMCR_N_MAX];
38 	uint64_t counter_type[PMCR_N_MAX];
39 } cluster_pmu_state_t;
40 
41 typedef struct dsu_driver_data {
42 	uint8_t clusterpwrdwn_pwrdn;
43 	uint8_t clusterpwrdwn_memret;
44 	uint8_t clusterpwrctlr_cachepwr;
45 	uint8_t clusterpwrctlr_funcret;
46 } dsu_driver_data_t;
47 
48 extern const dsu_driver_data_t plat_dsu_data;
49 
50 static inline unsigned int read_cluster_eventctr_num(void)
51 {
52 	return ((read_clusterpmcr() >> CLUSTERPMCR_N_SHIFT) &
53 			CLUSTERPMCR_N_MASK);
54 }
55 
56 void save_dsu_pmu_state(cluster_pmu_state_t *cluster_pmu_context);
57 
58 void restore_dsu_pmu_state(cluster_pmu_state_t *cluster_pmu_context);
59 
60 void cluster_on_dsu_pmu_context_restore(void);
61 
62 void cluster_off_dsu_pmu_context_save(void);
63 
64 void dsu_driver_init(const dsu_driver_data_t *data);
65 #endif
66 #endif /* DSU_H */
67