xref: /arm-trusted-firmware/plat/imx/imx8m/include/imx8m_csu.h (revision 91f16700b400a8c0651d24a598fc48ee2997a0d7)
1*91f16700Schasinglulu /*
2*91f16700Schasinglulu  * Copyright 2020-2022 NXP
3*91f16700Schasinglulu  *
4*91f16700Schasinglulu  * SPDX-License-Identifier: BSD-3-Clause
5*91f16700Schasinglulu  */
6*91f16700Schasinglulu 
7*91f16700Schasinglulu #ifndef IMX_CSU_H
8*91f16700Schasinglulu #define IMX_CSU_H
9*91f16700Schasinglulu 
10*91f16700Schasinglulu #include <lib/utils_def.h>
11*91f16700Schasinglulu 
12*91f16700Schasinglulu #include <platform_def.h>
13*91f16700Schasinglulu 
14*91f16700Schasinglulu #define CSU_SEC_LEVEL_0		0xff
15*91f16700Schasinglulu #define CSU_SEC_LEVEL_1		0xbb
16*91f16700Schasinglulu #define CSU_SEC_LEVEL_2		0x3f
17*91f16700Schasinglulu #define CSU_SEC_LEVEL_3		0x3b
18*91f16700Schasinglulu #define CSU_SEC_LEVEL_4		0x33
19*91f16700Schasinglulu #define CSU_SEC_LEVEL_5		0x22
20*91f16700Schasinglulu #define CSU_SEC_LEVEL_6		0x03
21*91f16700Schasinglulu #define CSU_SEC_LEVEL_7		0x0
22*91f16700Schasinglulu 
23*91f16700Schasinglulu #define LOCKED			0x1
24*91f16700Schasinglulu #define UNLOCKED		0x0
25*91f16700Schasinglulu 
26*91f16700Schasinglulu #define CSLx_REG(x)		(IMX_CSU_BASE + ((x) / 2) * 4)
27*91f16700Schasinglulu #define CSLx_LOCK(x)		((0x1 << (((x) % 2) * 16 + 8)))
28*91f16700Schasinglulu #define CSLx_CFG(x, n)		((x) << (((n) % 2) * 16))
29*91f16700Schasinglulu 
30*91f16700Schasinglulu #define CSU_HP_REG(x)		(IMX_CSU_BASE + ((x) / 16) * 4 + 0x200)
31*91f16700Schasinglulu #define CSU_HP_LOCK(x)		((0x1 << (((x) % 16) * 2 + 1)))
32*91f16700Schasinglulu #define CSU_HP_CFG(x, n)	((x) << (((n) % 16) * 2))
33*91f16700Schasinglulu 
34*91f16700Schasinglulu #define CSU_SA_REG(x)		(IMX_CSU_BASE + 0x218)
35*91f16700Schasinglulu #define CSU_SA_LOCK(x)		((0x1 << (((x) % 16) * 2 + 1)))
36*91f16700Schasinglulu #define CSU_SA_CFG(x, n)	((x) << (((n) % 16) * 2))
37*91f16700Schasinglulu 
38*91f16700Schasinglulu #define CSU_HPCONTROL_REG(x)		(IMX_CSU_BASE + (((x) / 16) * 4) + 0x358)
39*91f16700Schasinglulu #define CSU_HPCONTROL_LOCK(x)		((0x1 << (((x) % 16) * 2 + 1)))
40*91f16700Schasinglulu #define CSU_HPCONTROL_CFG(x, n)		((x) << (((n) % 16) * 2))
41*91f16700Schasinglulu 
42*91f16700Schasinglulu enum csu_cfg_type {
43*91f16700Schasinglulu 	CSU_INVALID,
44*91f16700Schasinglulu 	CSU_CSL,
45*91f16700Schasinglulu 	CSU_HP,
46*91f16700Schasinglulu 	CSU_SA,
47*91f16700Schasinglulu 	CSU_HPCONTROL,
48*91f16700Schasinglulu };
49*91f16700Schasinglulu 
50*91f16700Schasinglulu struct imx_csu_cfg {
51*91f16700Schasinglulu 	enum csu_cfg_type type;
52*91f16700Schasinglulu 	uint16_t idx;
53*91f16700Schasinglulu 	uint16_t lock : 1;
54*91f16700Schasinglulu 	uint16_t csl_level : 8;
55*91f16700Schasinglulu 	uint16_t hp : 1;
56*91f16700Schasinglulu 	uint16_t sa : 1;
57*91f16700Schasinglulu 	uint16_t hpctrl : 1;
58*91f16700Schasinglulu };
59*91f16700Schasinglulu 
60*91f16700Schasinglulu #define CSU_CSLx(i, level, lk)	\
61*91f16700Schasinglulu 	{CSU_CSL, .idx = (i), .csl_level = (level), .lock = (lk),}
62*91f16700Schasinglulu 
63*91f16700Schasinglulu #define CSU_HPx(i, val, lk)	\
64*91f16700Schasinglulu 	{CSU_HP, .idx = (i), .hp = (val), .lock = (lk), }
65*91f16700Schasinglulu 
66*91f16700Schasinglulu #define CSU_SA(i, val, lk)	\
67*91f16700Schasinglulu 	{CSU_SA, .idx = (i), .sa = (val), .lock = (lk), }
68*91f16700Schasinglulu 
69*91f16700Schasinglulu #define CSU_HPCTRL(i, val, lk)	\
70*91f16700Schasinglulu 	{CSU_HPCONTROL, .idx = (i), .hpctrl = (val), .lock = (lk), }
71*91f16700Schasinglulu 
72*91f16700Schasinglulu void imx_csu_init(const struct imx_csu_cfg *csu_cfg);
73*91f16700Schasinglulu 
74*91f16700Schasinglulu #endif /* IMX_CSU_H */
75