Book a Demo!
CoCalc Logo Icon
StoreFeaturesDocsShareSupportNewsAboutPoliciesSign UpSign In
CTCaer
GitHub Repository: CTCaer/hekate
Path: blob/master/bdk/soc/pmc.h
1476 views
1
/*
2
* Copyright (c) 2018 naehrwert
3
* Copyright (c) 2018 st4rk
4
* Copyright (c) 2018-2024 CTCaer
5
*
6
* This program is free software; you can redistribute it and/or modify it
7
* under the terms and conditions of the GNU General Public License,
8
* version 2, as published by the Free Software Foundation.
9
*
10
* This program is distributed in the hope it will be useful, but WITHOUT
11
* ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
12
* FITNESS FOR A PARTICULAR PURPOSE. See the GNU General Public License for
13
* more details.
14
*
15
* You should have received a copy of the GNU General Public License
16
* along with this program. If not, see <http://www.gnu.org/licenses/>.
17
*/
18
19
#ifndef _PMC_H_
20
#define _PMC_H_
21
22
#include <utils/types.h>
23
24
/*! PMC registers. */
25
#define APBDEV_PMC_CNTRL 0x0
26
#define PMC_CNTRL_RTC_CLK_DIS BIT(1)
27
#define PMC_CNTRL_RTC_RST BIT(2)
28
#define PMC_CNTRL_MAIN_RST BIT(4)
29
#define PMC_CNTRL_LATCHWAKE_EN BIT(5)
30
#define PMC_CNTRL_BLINK_EN BIT(7)
31
#define PMC_CNTRL_PWRREQ_OE BIT(9)
32
#define PMC_CNTRL_SYSCLK_OE BIT(11)
33
#define PMC_CNTRL_PWRGATE_DIS BIT(12)
34
#define PMC_CNTRL_SIDE_EFFECT_LP0 BIT(14)
35
#define PMC_CNTRL_CPUPWRREQ_OE BIT(16)
36
#define PMC_CNTRL_FUSE_OVERRIDE BIT(18)
37
#define PMC_CNTRL_SHUTDOWN_OE BIT(22)
38
#define APBDEV_PMC_SEC_DISABLE 0x4
39
#define APBDEV_PMC_PWRGATE_TOGGLE 0x30
40
#define APBDEV_PMC_PWRGATE_STATUS 0x38
41
#define APBDEV_PMC_NO_IOPOWER 0x44
42
#define PMC_NO_IOPOWER_MEM BIT(7)
43
#define PMC_NO_IOPOWER_SDMMC1 BIT(12)
44
#define PMC_NO_IOPOWER_SDMMC4 BIT(14)
45
#define PMC_NO_IOPOWER_MEM_COMP BIT(16)
46
#define PMC_NO_IOPOWER_AUDIO_HV BIT(18)
47
#define PMC_NO_IOPOWER_GPIO BIT(21)
48
#define APBDEV_PMC_SCRATCH0 0x50
49
#define PMC_SCRATCH0_MODE_WARMBOOT BIT(0)
50
#define PMC_SCRATCH0_MODE_RCM BIT(1)
51
#define PMC_SCRATCH0_MODE_PAYLOAD BIT(29)
52
#define PMC_SCRATCH0_MODE_BOOTLOADER BIT(30)
53
#define PMC_SCRATCH0_MODE_RECOVERY BIT(31)
54
#define PMC_SCRATCH0_MODE_CUSTOM_ALL (PMC_SCRATCH0_MODE_RECOVERY | \
55
PMC_SCRATCH0_MODE_BOOTLOADER | \
56
PMC_SCRATCH0_MODE_PAYLOAD)
57
#define APBDEV_PMC_BLINK_TIMER 0x40
58
#define PMC_BLINK_ON(n) ((n & 0x7FFF))
59
#define PMC_BLINK_FORCE BIT(15)
60
#define PMC_BLINK_OFF(n) ((u32)(n & 0xFFFF) << 16)
61
#define APBDEV_PMC_SCRATCH1 0x54
62
#define APBDEV_PMC_SCRATCH20 0xA0 // ODM data/config scratch.
63
#define APBDEV_PMC_SECURE_SCRATCH4 0xC0
64
#define APBDEV_PMC_SECURE_SCRATCH5 0xC4
65
#define APBDEV_PMC_PWR_DET_VAL 0xE4
66
#define PMC_PWR_DET_33V_SDMMC1 BIT(12)
67
#define PMC_PWR_DET_33V_AUDIO_HV BIT(18)
68
#define PMC_PWR_DET_33V_GPIO BIT(21)
69
#define APBDEV_PMC_DDR_PWR 0xE8
70
#define APBDEV_PMC_USB_AO 0xF0
71
#define APBDEV_PMC_CRYPTO_OP 0xF4
72
#define PMC_CRYPTO_OP_SE_ENABLE 0
73
#define PMC_CRYPTO_OP_SE_DISABLE 1
74
#define APBDEV_PMC_PLLP_WB0_OVERRIDE 0xF8
75
#define PMC_PLLP_WB0_OVERRIDE_PLLM_OVERRIDE_ENABLE BIT(11)
76
#define PMC_PLLP_WB0_OVERRIDE_PLLM_ENABLE BIT(12)
77
#define APBDEV_PMC_SCRATCH33 0x120
78
#define APBDEV_PMC_SCRATCH37 0x130
79
#define PMC_SCRATCH37_KERNEL_PANIC_MAGIC 0x4E415054 // "TPAN"
80
#define APBDEV_PMC_SCRATCH39 0x138
81
#define APBDEV_PMC_SCRATCH40 0x13C
82
#define APBDEV_PMC_OSC_EDPD_OVER 0x1A4
83
#define PMC_OSC_EDPD_OVER_OSC_CTRL_OVER BIT(22)
84
#define APBDEV_PMC_CLK_OUT_CNTRL 0x1A8
85
#define PMC_CLK_OUT_CNTRL_CLK1_FORCE_EN BIT(2)
86
#define PMC_CLK_OUT_CNTRL_CLK2_FORCE_EN BIT(10)
87
#define PMC_CLK_OUT_CNTRL_CLK3_FORCE_EN BIT(18)
88
#define PMC_CLK_OUT_CNTRL_CLK1_SRC_SEL(src) (((src) & 3) << 6)
89
#define PMC_CLK_OUT_CNTRL_CLK2_SRC_SEL(src) (((src) & 3) << 14)
90
#define PMC_CLK_OUT_CNTRL_CLK3_SRC_SEL(src) (((src) & 3) << 22)
91
#define OSC_DIV1 0
92
#define OSC_DIV2 1
93
#define OSC_DIV4 2
94
#define OSC_CAR 3
95
#define APBDEV_PMC_RST_STATUS 0x1B4
96
#define PMC_RST_STATUS_MASK 7
97
#define PMC_RST_STATUS_POR 0
98
#define PMC_RST_STATUS_WATCHDOG 1
99
#define PMC_RST_STATUS_SENSOR 2
100
#define PMC_RST_STATUS_SW_MAIN 3
101
#define PMC_RST_STATUS_LP0 4
102
#define PMC_RST_STATUS_AOTAG 5
103
#define APBDEV_PMC_IO_DPD_REQ 0x1B8
104
#define PMC_IO_DPD_REQ_DPD_IDLE (0 << 30u)
105
#define PMC_IO_DPD_REQ_DPD_OFF (1 << 30u)
106
#define PMC_IO_DPD_REQ_DPD_ON (2 << 30u)
107
#define APBDEV_PMC_IO_DPD2_REQ 0x1C0
108
#define APBDEV_PMC_VDDP_SEL 0x1CC
109
#define APBDEV_PMC_DDR_CFG 0x1D0
110
#define APBDEV_PMC_SECURE_SCRATCH6 0x224
111
#define APBDEV_PMC_SECURE_SCRATCH7 0x228
112
#define APBDEV_PMC_SCRATCH45 0x234
113
#define APBDEV_PMC_SCRATCH46 0x238
114
#define APBDEV_PMC_SCRATCH49 0x244
115
#define APBDEV_PMC_SCRATCH52 0x250
116
#define APBDEV_PMC_SCRATCH53 0x254
117
#define APBDEV_PMC_SCRATCH54 0x258
118
#define APBDEV_PMC_SCRATCH55 0x25C
119
#define APBDEV_PMC_TSC_MULT 0x2B4
120
#define APBDEV_PMC_STICKY_BITS 0x2C0
121
#define PMC_STICKY_BITS_HDA_LPBK_DIS BIT(0)
122
#define APBDEV_PMC_SEC_DISABLE2 0x2C4
123
#define APBDEV_PMC_WEAK_BIAS 0x2C8
124
#define APBDEV_PMC_REG_SHORT 0x2CC
125
#define APBDEV_PMC_SEC_DISABLE3 0x2D8
126
#define APBDEV_PMC_SECURE_SCRATCH21 0x334
127
#define PMC_FUSE_PRIVATEKEYDISABLE_TZ_STICKY_BIT BIT(4)
128
#define APBDEV_PMC_SECURE_SCRATCH22 0x338 // AArch32 reset address.
129
#define APBDEV_PMC_SECURE_SCRATCH32 0x360
130
#define APBDEV_PMC_SECURE_SCRATCH34 0x368 // AArch64 reset address.
131
#define APBDEV_PMC_SECURE_SCRATCH35 0x36C // AArch64 reset hi-address.
132
#define APBDEV_PMC_SECURE_SCRATCH49 0x3A4
133
#define APBDEV_PMC_CNTRL2 0x440
134
#define PMC_CNTRL2_WAKE_INT_EN BIT(0)
135
#define PMC_CNTRL2_WAKE_DET_EN BIT(9)
136
#define PMC_CNTRL2_SYSCLK_ORRIDE BIT(10)
137
#define PMC_CNTRL2_HOLD_CKE_LOW_EN BIT(12)
138
#define PMC_CNTRL2_ALLOW_PULSE_WAKE BIT(14)
139
#define APBDEV_PMC_FUSE_CONTROL 0x450
140
#define PMC_FUSE_CONTROL_PS18_LATCH_SET BIT(8)
141
#define PMC_FUSE_CONTROL_PS18_LATCH_CLR BIT(9)
142
#define APBDEV_PMC_IO_DPD3_REQ 0x45C
143
#define APBDEV_PMC_IO_DPD4_REQ 0x464
144
#define APBDEV_PMC_UTMIP_PAD_CFG1 0x4C4
145
#define APBDEV_PMC_UTMIP_PAD_CFG3 0x4CC
146
#define APBDEV_PMC_DDR_CNTRL 0x4E4
147
#define APBDEV_PMC_SEC_DISABLE4 0x5B0
148
#define APBDEV_PMC_SEC_DISABLE5 0x5B4
149
#define APBDEV_PMC_SEC_DISABLE6 0x5B8
150
#define APBDEV_PMC_SEC_DISABLE7 0x5BC
151
#define APBDEV_PMC_SEC_DISABLE8 0x5C0
152
#define APBDEV_PMC_SEC_DISABLE9 0x5C4
153
#define APBDEV_PMC_SEC_DISABLE10 0x5C8
154
#define APBDEV_PMC_SCRATCH188 0x810
155
#define APBDEV_PMC_SCRATCH190 0x818
156
#define APBDEV_PMC_SCRATCH200 0x840
157
#define APBDEV_PMC_SCRATCH201 0x844
158
#define APBDEV_PMC_SCRATCH250 0x908
159
#define APBDEV_PMC_SECURE_SCRATCH108 0xB08
160
#define APBDEV_PMC_SECURE_SCRATCH109 0xB0C
161
#define APBDEV_PMC_SECURE_SCRATCH110 0xB10
162
#define APBDEV_PMC_SECURE_SCRATCH112 0xB18
163
#define APBDEV_PMC_SECURE_SCRATCH113 0xB1C
164
#define APBDEV_PMC_SECURE_SCRATCH114 0xB20
165
#define APBDEV_PMC_SECURE_SCRATCH119 0xB34
166
167
// Only in T210B01.
168
#define APBDEV_PMC_SCRATCH_WRITE_DISABLE0 0xA48
169
#define APBDEV_PMC_SCRATCH_WRITE_DISABLE1 0xA4C
170
#define APBDEV_PMC_SCRATCH_WRITE_DISABLE2 0xA50
171
#define APBDEV_PMC_SCRATCH_WRITE_DISABLE3 0xA54
172
#define APBDEV_PMC_SCRATCH_WRITE_DISABLE4 0xA58
173
#define APBDEV_PMC_SCRATCH_WRITE_DISABLE5 0xA5C
174
#define APBDEV_PMC_SCRATCH_WRITE_DISABLE6 0xA60
175
#define APBDEV_PMC_SCRATCH_WRITE_DISABLE7 0xA64
176
#define APBDEV_PMC_SCRATCH_WRITE_DISABLE8 0xA68
177
#define APBDEV_PMC_LED_BREATHING_CTRL 0xB48
178
#define PMC_LED_BREATHING_CTRL_ENABLE BIT(0)
179
#define PMC_LED_BREATHING_CTRL_COUNTER1_EN BIT(1)
180
#define APBDEV_PMC_LED_BREATHING_SLOPE_STEPS 0xB4C
181
#define APBDEV_PMC_LED_BREATHING_ON_COUNTER 0xB50
182
#define APBDEV_PMC_LED_BREATHING_OFF_COUNTER1 0xB54
183
#define APBDEV_PMC_LED_BREATHING_OFF_COUNTER0 0xB58
184
#define PMC_LED_BREATHING_COUNTER_HZ 32768
185
#define APBDEV_PMC_LED_BREATHING_STATUS 0xB5C
186
#define PMC_LED_BREATHING_FSM_STATUS_MASK 0x7
187
#define PMC_LED_BREATHING_FSM_STS_IDLE 0
188
#define PMC_LED_BREATHING_FSM_STS_UP_RAMP 1
189
#define PMC_LED_BREATHING_FSM_STS_PLATEAU 2
190
#define PMC_LED_BREATHING_FSM_STS_DOWN_RAMP 3
191
#define PMC_LED_BREATHING_FSM_STS_SHORT_LOW_PERIOD 4
192
#define PMC_LED_BREATHING_FSM_STS_LONG_LOW_PERIOD 5
193
#define APBDEV_PMC_TZRAM_PWR_CNTRL 0xBE8
194
#define PMC_TZRAM_PWR_CNTRL_SD BIT(0)
195
#define APBDEV_PMC_TZRAM_SEC_DISABLE 0xBEC
196
#define APBDEV_PMC_TZRAM_NON_SEC_DISABLE 0xBF0
197
#define PMC_TZRAM_DISABLE_REG_WRITE BIT(0)
198
#define PMC_TZRAM_DISABLE_REG_READ BIT(1)
199
200
typedef enum _pmc_sec_lock_t
201
{
202
PMC_SEC_LOCK_MISC = BIT(0),
203
PMC_SEC_LOCK_LP0_PARAMS = BIT(1),
204
PMC_SEC_LOCK_RST_VECTOR = BIT(2),
205
PMC_SEC_LOCK_CARVEOUTS = BIT(3),
206
PMC_SEC_LOCK_TZ_CMAC_W = BIT(4),
207
PMC_SEC_LOCK_TZ_CMAC_R = BIT(5),
208
PMC_SEC_LOCK_TZ_KEK_W = BIT(6),
209
PMC_SEC_LOCK_TZ_KEK_R = BIT(7),
210
PMC_SEC_LOCK_SE_SRK = BIT(8),
211
PMC_SEC_LOCK_SE2_SRK_B01 = BIT(9),
212
PMC_SEC_LOCK_MISC_B01 = BIT(10),
213
PMC_SEC_LOCK_CARVEOUTS_L4T = BIT(11),
214
PMC_SEC_LOCK_LP0_PARAMS_B01 = BIT(12),
215
} pmc_sec_lock_t;
216
217
typedef enum _pmc_power_rail_t
218
{
219
POWER_RAIL_CRAIL = 0,
220
POWER_RAIL_3D0 = 1,
221
POWER_RAIL_VENC = 2,
222
POWER_RAIL_PCIE = 3,
223
POWER_RAIL_VDEC = 4,
224
POWER_RAIL_L2C = 5,
225
POWER_RAIL_MPE = 6,
226
POWER_RAIL_HEG = 7,
227
POWER_RAIL_SATA = 8,
228
POWER_RAIL_CE1 = 9,
229
POWER_RAIL_CE2 = 10,
230
POWER_RAIL_CE3 = 11,
231
POWER_RAIL_CELP = 12,
232
POWER_RAIL_3D1 = 13,
233
POWER_RAIL_CE0 = 14,
234
POWER_RAIL_C0NC = 15,
235
POWER_RAIL_C1NC = 16,
236
POWER_RAIL_SOR = 17,
237
POWER_RAIL_DIS = 18,
238
POWER_RAIL_DISB = 19,
239
POWER_RAIL_XUSBA = 20,
240
POWER_RAIL_XUSBB = 21,
241
POWER_RAIL_XUSBC = 22,
242
POWER_RAIL_VIC = 23,
243
POWER_RAIL_IRAM = 24,
244
POWER_RAIL_NVDEC = 25,
245
POWER_RAIL_NVJPG = 26,
246
POWER_RAIL_AUD = 27,
247
POWER_RAIL_DFD = 28,
248
POWER_RAIL_VE2 = 29
249
} pmc_power_rail_t;
250
251
void pmc_scratch_lock(pmc_sec_lock_t lock_mask);
252
int pmc_enable_partition(pmc_power_rail_t part, u32 enable);
253
254
#endif
255
256