xref: /rk3399_ARM-atf/bl32/tsp/tsp_context.c (revision 7623e085cb5396054b72f1ea3f02e8c7a34568b5)
1*7623e085SJayanth Dodderi Chidanand /*
2*7623e085SJayanth Dodderi Chidanand  * Copyright (c) 2024, Arm Limited and Contributors. All rights reserved.
3*7623e085SJayanth Dodderi Chidanand  *
4*7623e085SJayanth Dodderi Chidanand  * SPDX-License-Identifier: BSD-3-Clause
5*7623e085SJayanth Dodderi Chidanand  */
6*7623e085SJayanth Dodderi Chidanand 
7*7623e085SJayanth Dodderi Chidanand #include <arch_features.h>
8*7623e085SJayanth Dodderi Chidanand #include <arch_helpers.h>
9*7623e085SJayanth Dodderi Chidanand #include <bl32/tsp/tsp_el1_context.h>
10*7623e085SJayanth Dodderi Chidanand #include <common/debug.h>
11*7623e085SJayanth Dodderi Chidanand 
12*7623e085SJayanth Dodderi Chidanand #define DUMMY_CTX_VALUE		ULL(0xffffffff)
13*7623e085SJayanth Dodderi Chidanand #define DUMMY_CTX_TCR_VALUE	ULL(0xffff0000)
14*7623e085SJayanth Dodderi Chidanand #define DUMMY_CTX_TRF_VALUE	ULL(0xf)
15*7623e085SJayanth Dodderi Chidanand #define DUMMY_CTX_GCS_VALUE	ULL(0xffff0000)
16*7623e085SJayanth Dodderi Chidanand #define DEFAULT_CTX_VALUE	ULL(0x0)
17*7623e085SJayanth Dodderi Chidanand 
18*7623e085SJayanth Dodderi Chidanand /**
19*7623e085SJayanth Dodderi Chidanand  * -------------------------------------------------------
20*7623e085SJayanth Dodderi Chidanand  * Private Helper functions required to access and modify
21*7623e085SJayanth Dodderi Chidanand  * EL1 context registers at S-EL1.
22*7623e085SJayanth Dodderi Chidanand  * -------------------------------------------------------
23*7623e085SJayanth Dodderi Chidanand  */
24*7623e085SJayanth Dodderi Chidanand static void modify_el1_common_regs(uint64_t cm_value)
25*7623e085SJayanth Dodderi Chidanand {
26*7623e085SJayanth Dodderi Chidanand 	/**
27*7623e085SJayanth Dodderi Chidanand 	 * NOTE: Few EL1 registers "SCTLR_EL1, SPSR_EL1, ELR_EL1" are
28*7623e085SJayanth Dodderi Chidanand 	 *       left out consciously as those are important registers for
29*7623e085SJayanth Dodderi Chidanand 	 *       execution in each world and overwriting them with dummy value
30*7623e085SJayanth Dodderi Chidanand 	 *       would cause unintended crash while executing the test.
31*7623e085SJayanth Dodderi Chidanand 	 */
32*7623e085SJayanth Dodderi Chidanand 	write_tcr_el1(cm_value);
33*7623e085SJayanth Dodderi Chidanand 	write_cpacr_el1(cm_value);
34*7623e085SJayanth Dodderi Chidanand 	write_csselr_el1(cm_value);
35*7623e085SJayanth Dodderi Chidanand 	write_esr_el1(cm_value);
36*7623e085SJayanth Dodderi Chidanand 	write_ttbr0_el1(cm_value);
37*7623e085SJayanth Dodderi Chidanand 	write_ttbr1_el1(cm_value);
38*7623e085SJayanth Dodderi Chidanand 	write_mair_el1(cm_value);
39*7623e085SJayanth Dodderi Chidanand 	write_amair_el1(cm_value);
40*7623e085SJayanth Dodderi Chidanand 	write_actlr_el1(cm_value);
41*7623e085SJayanth Dodderi Chidanand 	write_tpidr_el1(cm_value);
42*7623e085SJayanth Dodderi Chidanand 	write_tpidr_el0(cm_value);
43*7623e085SJayanth Dodderi Chidanand 	write_tpidrro_el0(cm_value);
44*7623e085SJayanth Dodderi Chidanand 	write_par_el1(cm_value);
45*7623e085SJayanth Dodderi Chidanand 	write_far_el1(cm_value);
46*7623e085SJayanth Dodderi Chidanand 	write_afsr0_el1(cm_value);
47*7623e085SJayanth Dodderi Chidanand 	write_afsr1_el1(cm_value);
48*7623e085SJayanth Dodderi Chidanand 	write_contextidr_el1(cm_value);
49*7623e085SJayanth Dodderi Chidanand 	write_vbar_el1(cm_value);
50*7623e085SJayanth Dodderi Chidanand 	write_mdccint_el1(cm_value);
51*7623e085SJayanth Dodderi Chidanand 	write_mdscr_el1(cm_value);
52*7623e085SJayanth Dodderi Chidanand }
53*7623e085SJayanth Dodderi Chidanand 
54*7623e085SJayanth Dodderi Chidanand static void modify_el1_mte2_regs(uint64_t mte_value)
55*7623e085SJayanth Dodderi Chidanand {
56*7623e085SJayanth Dodderi Chidanand 	if (is_feat_mte2_supported()) {
57*7623e085SJayanth Dodderi Chidanand 		write_tfsre0_el1(mte_value);
58*7623e085SJayanth Dodderi Chidanand 		write_tfsr_el1(mte_value);
59*7623e085SJayanth Dodderi Chidanand 		write_rgsr_el1(mte_value);
60*7623e085SJayanth Dodderi Chidanand 		write_gcr_el1(mte_value);
61*7623e085SJayanth Dodderi Chidanand 	}
62*7623e085SJayanth Dodderi Chidanand }
63*7623e085SJayanth Dodderi Chidanand 
64*7623e085SJayanth Dodderi Chidanand static void modify_el1_ras_regs(uint64_t ras_value)
65*7623e085SJayanth Dodderi Chidanand {
66*7623e085SJayanth Dodderi Chidanand 	if (is_feat_ras_supported()) {
67*7623e085SJayanth Dodderi Chidanand 		write_disr_el1(ras_value);
68*7623e085SJayanth Dodderi Chidanand 	}
69*7623e085SJayanth Dodderi Chidanand }
70*7623e085SJayanth Dodderi Chidanand 
71*7623e085SJayanth Dodderi Chidanand static void modify_el1_s1pie_regs(uint64_t s1pie_value)
72*7623e085SJayanth Dodderi Chidanand {
73*7623e085SJayanth Dodderi Chidanand 	if (is_feat_s1pie_supported()) {
74*7623e085SJayanth Dodderi Chidanand 		write_pire0_el1(s1pie_value);
75*7623e085SJayanth Dodderi Chidanand 		write_pir_el1(s1pie_value);
76*7623e085SJayanth Dodderi Chidanand 	}
77*7623e085SJayanth Dodderi Chidanand }
78*7623e085SJayanth Dodderi Chidanand 
79*7623e085SJayanth Dodderi Chidanand static void modify_el1_s1poe_regs(uint64_t s1poe_value)
80*7623e085SJayanth Dodderi Chidanand {
81*7623e085SJayanth Dodderi Chidanand 	if (is_feat_s1poe_supported()) {
82*7623e085SJayanth Dodderi Chidanand 		write_por_el1(s1poe_value);
83*7623e085SJayanth Dodderi Chidanand 	}
84*7623e085SJayanth Dodderi Chidanand }
85*7623e085SJayanth Dodderi Chidanand 
86*7623e085SJayanth Dodderi Chidanand static void modify_el1_s2poe_regs(uint64_t s2poe_value)
87*7623e085SJayanth Dodderi Chidanand {
88*7623e085SJayanth Dodderi Chidanand 	if (is_feat_s2poe_supported()) {
89*7623e085SJayanth Dodderi Chidanand 		write_s2por_el1(s2poe_value);
90*7623e085SJayanth Dodderi Chidanand 	}
91*7623e085SJayanth Dodderi Chidanand }
92*7623e085SJayanth Dodderi Chidanand 
93*7623e085SJayanth Dodderi Chidanand static void modify_el1_tcr2_regs(uint64_t tcr_value)
94*7623e085SJayanth Dodderi Chidanand {
95*7623e085SJayanth Dodderi Chidanand 	if (is_feat_tcr2_supported()) {
96*7623e085SJayanth Dodderi Chidanand 		write_tcr2_el1(tcr_value & DUMMY_CTX_TCR_VALUE);
97*7623e085SJayanth Dodderi Chidanand 	}
98*7623e085SJayanth Dodderi Chidanand }
99*7623e085SJayanth Dodderi Chidanand 
100*7623e085SJayanth Dodderi Chidanand static void modify_el1_trf_regs(uint64_t trf_value)
101*7623e085SJayanth Dodderi Chidanand {
102*7623e085SJayanth Dodderi Chidanand 	if (is_feat_trf_supported()) {
103*7623e085SJayanth Dodderi Chidanand 		write_trfcr_el1(trf_value & DUMMY_CTX_TRF_VALUE);
104*7623e085SJayanth Dodderi Chidanand 	}
105*7623e085SJayanth Dodderi Chidanand }
106*7623e085SJayanth Dodderi Chidanand 
107*7623e085SJayanth Dodderi Chidanand static void modify_el1_gcs_regs(uint64_t gcs_value)
108*7623e085SJayanth Dodderi Chidanand {
109*7623e085SJayanth Dodderi Chidanand 	if (is_feat_gcs_supported()) {
110*7623e085SJayanth Dodderi Chidanand 		write_gcscr_el1(gcs_value & DUMMY_CTX_GCS_VALUE);
111*7623e085SJayanth Dodderi Chidanand 		write_gcscre0_el1(gcs_value & DUMMY_CTX_GCS_VALUE);
112*7623e085SJayanth Dodderi Chidanand 		write_gcspr_el1(gcs_value & DUMMY_CTX_GCS_VALUE);
113*7623e085SJayanth Dodderi Chidanand 		write_gcspr_el0(gcs_value & DUMMY_CTX_GCS_VALUE);
114*7623e085SJayanth Dodderi Chidanand 	}
115*7623e085SJayanth Dodderi Chidanand }
116*7623e085SJayanth Dodderi Chidanand 
117*7623e085SJayanth Dodderi Chidanand /**
118*7623e085SJayanth Dodderi Chidanand  * -----------------------------------------------------
119*7623e085SJayanth Dodderi Chidanand  * Public API, to modify/restore EL1 ctx registers:
120*7623e085SJayanth Dodderi Chidanand  * -----------------------------------------------------
121*7623e085SJayanth Dodderi Chidanand  */
122*7623e085SJayanth Dodderi Chidanand void modify_el1_ctx_regs(const bool modify_option)
123*7623e085SJayanth Dodderi Chidanand {
124*7623e085SJayanth Dodderi Chidanand 	uint64_t mask;
125*7623e085SJayanth Dodderi Chidanand 
126*7623e085SJayanth Dodderi Chidanand 	if (modify_option == TSP_CORRUPT_EL1_REGS) {
127*7623e085SJayanth Dodderi Chidanand 		VERBOSE("TSP(S-EL1): Corrupt EL1 Registers with Dummy values\n");
128*7623e085SJayanth Dodderi Chidanand 		mask = DUMMY_CTX_VALUE;
129*7623e085SJayanth Dodderi Chidanand 	} else {
130*7623e085SJayanth Dodderi Chidanand 		VERBOSE("TSP(S-EL1): Restore EL1 Registers with Default values\n");
131*7623e085SJayanth Dodderi Chidanand 		mask = DEFAULT_CTX_VALUE;
132*7623e085SJayanth Dodderi Chidanand 	}
133*7623e085SJayanth Dodderi Chidanand 
134*7623e085SJayanth Dodderi Chidanand 	modify_el1_common_regs(mask);
135*7623e085SJayanth Dodderi Chidanand 	modify_el1_mte2_regs(mask);
136*7623e085SJayanth Dodderi Chidanand 	modify_el1_ras_regs(mask);
137*7623e085SJayanth Dodderi Chidanand 	modify_el1_s1pie_regs(mask);
138*7623e085SJayanth Dodderi Chidanand 	modify_el1_s1poe_regs(mask);
139*7623e085SJayanth Dodderi Chidanand 	modify_el1_s2poe_regs(mask);
140*7623e085SJayanth Dodderi Chidanand 	modify_el1_tcr2_regs(mask);
141*7623e085SJayanth Dodderi Chidanand 	modify_el1_trf_regs(mask);
142*7623e085SJayanth Dodderi Chidanand 	modify_el1_gcs_regs(mask);
143*7623e085SJayanth Dodderi Chidanand }
144