summaryrefslogtreecommitdiffstats
path: root/plat/mediatek/mt8195/include/mcucfg.h
blob: 046cf7314f2f7645c2998a072daaa9c874691cdb (plain)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
126
127
128
129
130
131
132
133
134
135
136
137
138
139
140
141
142
143
144
145
146
147
148
149
150
151
152
153
154
155
156
157
158
159
160
161
162
163
164
165
166
167
168
169
170
171
172
173
174
175
176
177
178
179
180
181
182
183
184
185
186
187
188
189
190
191
192
193
194
195
196
197
198
199
200
201
202
203
204
205
206
207
208
209
210
211
212
213
214
215
216
217
218
219
220
221
222
223
224
225
226
227
228
229
230
231
232
233
234
235
236
237
238
239
240
241
242
243
244
245
246
247
248
249
250
251
252
253
254
255
256
257
/*
 * Copyright (c) 2020, MediaTek Inc. All rights reserved.
 *
 * SPDX-License-Identifier: BSD-3-Clause
 */

#ifndef MCUCFG_H
#define MCUCFG_H

#ifndef __ASSEMBLER__
#include <stdint.h>
#endif /* __ASSEMBLER__ */

#include <platform_def.h>

#define MCUCFG_REG(ofs)			(uint32_t)(MCUCFG_BASE + (ofs))

#define MP2_MISC_CONFIG_BOOT_ADDR_L(cpu) (MCUCFG_REG(0x2290) + ((cpu) * 8))
#define MP2_MISC_CONFIG_BOOT_ADDR_H(cpu) (MCUCFG_REG(0x2294) + ((cpu) * 8))

#define MP2_CPUCFG			MCUCFG_REG(0x2208)

#define MP2_CPU0_STANDBYWFE		BIT(4)
#define MP2_CPU1_STANDBYWFE		BIT(5)

#define MP0_CPUTOP_SPMC_CTL		MCUCFG_REG(0x788)
#define MP1_CPUTOP_SPMC_CTL		MCUCFG_REG(0x78C)
#define MP1_CPUTOP_SPMC_SRAM_CTL	MCUCFG_REG(0x790)

#define sw_spark_en			BIT(0)
#define sw_no_wait_for_q_channel	BIT(1)
#define sw_fsm_override			BIT(2)
#define sw_logic_pre1_pdb		BIT(3)
#define sw_logic_pre2_pdb		BIT(4)
#define sw_logic_pdb			BIT(5)
#define sw_iso				BIT(6)
#define sw_sram_sleepb			(U(0x3F) << 7)
#define sw_sram_isointb			BIT(13)
#define sw_clk_dis			BIT(14)
#define sw_ckiso			BIT(15)
#define sw_pd				(U(0x3F) << 16)
#define sw_hot_plug_reset		BIT(22)
#define sw_pwr_on_override_en		BIT(23)
#define sw_pwr_on			BIT(24)
#define sw_coq_dis			BIT(25)
#define logic_pdbo_all_off_ack		BIT(26)
#define logic_pdbo_all_on_ack		BIT(27)
#define logic_pre2_pdbo_all_on_ack	BIT(28)
#define logic_pre1_pdbo_all_on_ack	BIT(29)


#define CPUSYSx_CPUx_SPMC_CTL(cluster, cpu) \
	(MCUCFG_REG(0x1c30) + cluster * 0x2000 + cpu * 4)

#define CPUSYS0_CPU0_SPMC_CTL		MCUCFG_REG(0x1c30)
#define CPUSYS0_CPU1_SPMC_CTL		MCUCFG_REG(0x1c34)
#define CPUSYS0_CPU2_SPMC_CTL		MCUCFG_REG(0x1c38)
#define CPUSYS0_CPU3_SPMC_CTL		MCUCFG_REG(0x1c3C)

#define CPUSYS1_CPU0_SPMC_CTL		MCUCFG_REG(0x3c30)
#define CPUSYS1_CPU1_SPMC_CTL		MCUCFG_REG(0x3c34)
#define CPUSYS1_CPU2_SPMC_CTL		MCUCFG_REG(0x3c38)
#define CPUSYS1_CPU3_SPMC_CTL		MCUCFG_REG(0x3c3C)

#define cpu_sw_spark_en			BIT(0)
#define cpu_sw_no_wait_for_q_channel	BIT(1)
#define cpu_sw_fsm_override		BIT(2)
#define cpu_sw_logic_pre1_pdb		BIT(3)
#define cpu_sw_logic_pre2_pdb		BIT(4)
#define cpu_sw_logic_pdb		BIT(5)
#define cpu_sw_iso			BIT(6)
#define cpu_sw_sram_sleepb		BIT(7)
#define cpu_sw_sram_isointb		BIT(8)
#define cpu_sw_clk_dis			BIT(9)
#define cpu_sw_ckiso			BIT(10)
#define cpu_sw_pd			(U(0x1F) << 11)
#define cpu_sw_hot_plug_reset		BIT(16)
#define cpu_sw_powr_on_override_en	BIT(17)
#define cpu_sw_pwr_on			BIT(18)
#define cpu_spark2ldo_allswoff		BIT(19)
#define cpu_pdbo_all_on_ack		BIT(20)
#define cpu_pre2_pdbo_allon_ack		BIT(21)
#define cpu_pre1_pdbo_allon_ack		BIT(22)

/* CPC related registers */
#define CPC_MCUSYS_CPC_OFF_THRES	MCUCFG_REG(0xa714)
#define CPC_MCUSYS_PWR_CTRL		MCUCFG_REG(0xa804)
#define CPC_MCUSYS_CPC_FLOW_CTRL_CFG	MCUCFG_REG(0xa814)
#define CPC_MCUSYS_LAST_CORE_REQ	MCUCFG_REG(0xa818)
#define CPC_MCUSYS_MP_LAST_CORE_RESP	MCUCFG_REG(0xa81c)
#define CPC_MCUSYS_LAST_CORE_RESP	MCUCFG_REG(0xa824)
#define CPC_MCUSYS_PWR_ON_MASK		MCUCFG_REG(0xa828)
#define CPC_MCUSYS_CPU_ON_SW_HINT_SET	MCUCFG_REG(0xa8a8)
#define CPC_MCUSYS_CPU_ON_SW_HINT_CLR	MCUCFG_REG(0xa8ac)
#define CPC_MCUSYS_CPC_DBG_SETTING	MCUCFG_REG(0xab00)
#define CPC_MCUSYS_CPC_KERNEL_TIME_L_BASE	MCUCFG_REG(0xab04)
#define CPC_MCUSYS_CPC_KERNEL_TIME_H_BASE	MCUCFG_REG(0xab08)
#define CPC_MCUSYS_CPC_SYSTEM_TIME_L_BASE	MCUCFG_REG(0xab0c)
#define CPC_MCUSYS_CPC_SYSTEM_TIME_H_BASE	MCUCFG_REG(0xab10)
#define CPC_MCUSYS_TRACE_SEL		MCUCFG_REG(0xab14)
#define CPC_MCUSYS_TRACE_DATA		MCUCFG_REG(0xab20)
#define CPC_MCUSYS_CLUSTER_COUNTER	MCUCFG_REG(0xab70)
#define CPC_MCUSYS_CLUSTER_COUNTER_CLR	MCUCFG_REG(0xab74)

#define SPARK2LDO			MCUCFG_REG(0x2700)
/* APB Module mcucfg */
#define MP0_CA7_CACHE_CONFIG		MCUCFG_REG(0x000)
#define MP0_AXI_CONFIG			MCUCFG_REG(0x02C)
#define MP0_MISC_CONFIG0		MCUCFG_REG(0x030)
#define MP0_MISC_CONFIG1		MCUCFG_REG(0x034)
#define MP0_MISC_CONFIG2		MCUCFG_REG(0x038)
#define MP0_MISC_CONFIG_BOOT_ADDR(cpu)	(MP0_MISC_CONFIG2 + ((cpu) * 8))
#define MP0_MISC_CONFIG3		MCUCFG_REG(0x03C)
#define MP0_MISC_CONFIG9		MCUCFG_REG(0x054)
#define MP0_CA7_MISC_CONFIG		MCUCFG_REG(0x064)

#define MP0_RW_RSVD0			MCUCFG_REG(0x06C)


#define MP1_CA7_CACHE_CONFIG		MCUCFG_REG(0x200)
#define MP1_AXI_CONFIG			MCUCFG_REG(0x22C)
#define MP1_MISC_CONFIG0		MCUCFG_REG(0x230)
#define MP1_MISC_CONFIG1		MCUCFG_REG(0x234)
#define MP1_MISC_CONFIG2		MCUCFG_REG(0x238)
#define MP1_MISC_CONFIG_BOOT_ADDR(cpu)	(MP1_MISC_CONFIG2 + ((cpu) * 8))
#define MP1_MISC_CONFIG3		MCUCFG_REG(0x23C)
#define MP1_MISC_CONFIG9		MCUCFG_REG(0x254)
#define MP1_CA7_MISC_CONFIG		MCUCFG_REG(0x264)

#define CCI_ADB400_DCM_CONFIG		MCUCFG_REG(0x740)
#define SYNC_DCM_CONFIG			MCUCFG_REG(0x744)

#define MP0_CLUSTER_CFG0		MCUCFG_REG(0xC8D0)

#define MP0_SPMC			MCUCFG_REG(0x788)
#define MP1_SPMC			MCUCFG_REG(0x78C)
#define MP2_AXI_CONFIG			MCUCFG_REG(0x220C)
#define MP2_AXI_CONFIG_ACINACTM		BIT(0)
#define MP2_AXI_CONFIG_AINACTS		BIT(4)

#define MPx_AXI_CONFIG_ACINACTM		BIT(4)
#define MPx_AXI_CONFIG_AINACTS		BIT(5)

#define MPx_CA7_MISC_CONFIG_standbywfil2	BIT(28)

#define MP0_CPU0_STANDBYWFE		BIT(20)
#define MP0_CPU1_STANDBYWFE		BIT(21)
#define MP0_CPU2_STANDBYWFE		BIT(22)
#define MP0_CPU3_STANDBYWFE		BIT(23)

#define MP1_CPU0_STANDBYWFE		BIT(20)
#define MP1_CPU1_STANDBYWFE		BIT(21)
#define MP1_CPU2_STANDBYWFE		BIT(22)
#define MP1_CPU3_STANDBYWFE		BIT(23)

#define CPUSYS0_SPARKVRETCNTRL		MCUCFG_REG(0x1c00)
#define CPUSYS0_SPARKEN			MCUCFG_REG(0x1c04)
#define CPUSYS0_AMUXSEL			MCUCFG_REG(0x1c08)
#define CPUSYS1_SPARKVRETCNTRL		MCUCFG_REG(0x3c00)
#define CPUSYS1_SPARKEN			MCUCFG_REG(0x3c04)
#define CPUSYS1_AMUXSEL			MCUCFG_REG(0x3c08)

#define MP2_PWR_RST_CTL			MCUCFG_REG(0x2008)
#define MP2_PTP3_CPUTOP_SPMC0		MCUCFG_REG(0x22A0)
#define MP2_PTP3_CPUTOP_SPMC1		MCUCFG_REG(0x22A4)

#define MP2_COQ				MCUCFG_REG(0x22BC)
#define MP2_COQ_SW_DIS			BIT(0)

#define MP2_CA15M_MON_SEL		MCUCFG_REG(0x2400)
#define MP2_CA15M_MON_L			MCUCFG_REG(0x2404)

#define CPUSYS2_CPU0_SPMC_CTL		MCUCFG_REG(0x2430)
#define CPUSYS2_CPU1_SPMC_CTL		MCUCFG_REG(0x2438)
#define CPUSYS2_CPU0_SPMC_STA		MCUCFG_REG(0x2434)
#define CPUSYS2_CPU1_SPMC_STA		MCUCFG_REG(0x243C)

#define MP0_CA7L_DBG_PWR_CTRL		MCUCFG_REG(0x068)
#define MP1_CA7L_DBG_PWR_CTRL		MCUCFG_REG(0x268)
#define BIG_DBG_PWR_CTRL		MCUCFG_REG(0x75C)

#define MP2_SW_RST_B			BIT(0)
#define MP2_TOPAON_APB_MASK		BIT(1)

#define B_SW_HOT_PLUG_RESET		BIT(30)

#define B_SW_PD_OFFSET			18U
#define B_SW_PD				(U(0x3f) << B_SW_PD_OFFSET)

#define B_SW_SRAM_SLEEPB_OFFSET		12U
#define B_SW_SRAM_SLEEPB		(U(0x3f) << B_SW_SRAM_SLEEPB_OFFSET)

#define B_SW_SRAM_ISOINTB		BIT(9)
#define B_SW_ISO			BIT(8)
#define B_SW_LOGIC_PDB			BIT(7)
#define B_SW_LOGIC_PRE2_PDB		BIT(6)
#define B_SW_LOGIC_PRE1_PDB		BIT(5)
#define B_SW_FSM_OVERRIDE		BIT(4)
#define B_SW_PWR_ON			BIT(3)
#define B_SW_PWR_ON_OVERRIDE_EN		BIT(2)

#define B_FSM_STATE_OUT_OFFSET		(6U)
#define B_FSM_STATE_OUT_MASK		(U(0x1f) << B_FSM_STATE_OUT_OFFSET)
#define B_SW_LOGIC_PDBO_ALL_OFF_ACK	BIT(5)
#define B_SW_LOGIC_PDBO_ALL_ON_ACK	BIT(4)
#define B_SW_LOGIC_PRE2_PDBO_ALL_ON_ACK	BIT(3)
#define B_SW_LOGIC_PRE1_PDBO_ALL_ON_ACK	BIT(2)

#define B_FSM_OFF			(0U << B_FSM_STATE_OUT_OFFSET)
#define B_FSM_ON			(1U << B_FSM_STATE_OUT_OFFSET)
#define B_FSM_RET			(2U << B_FSM_STATE_OUT_OFFSET)

#ifndef __ASSEMBLER__
/* cpu boot mode */
enum {
	MP0_CPUCFG_64BIT_SHIFT = 12U,
	MP1_CPUCFG_64BIT_SHIFT = 28U,
	MP0_CPUCFG_64BIT = U(0xf) << MP0_CPUCFG_64BIT_SHIFT,
	MP1_CPUCFG_64BIT = U(0xf) << MP1_CPUCFG_64BIT_SHIFT
};

enum {
	MP1_DIS_RGU0_WAIT_PD_CPUS_L1_ACK_SHIFT = 0U,
	MP1_DIS_RGU1_WAIT_PD_CPUS_L1_ACK_SHIFT = 4U,
	MP1_DIS_RGU2_WAIT_PD_CPUS_L1_ACK_SHIFT = 8U,
	MP1_DIS_RGU3_WAIT_PD_CPUS_L1_ACK_SHIFT = 12U,
	MP1_DIS_RGU_NOCPU_WAIT_PD_CPUS_L1_ACK_SHIFT = 16U,

	MP1_DIS_RGU0_WAIT_PD_CPUS_L1_ACK =
		U(0xf) << MP1_DIS_RGU0_WAIT_PD_CPUS_L1_ACK_SHIFT,
	MP1_DIS_RGU1_WAIT_PD_CPUS_L1_ACK =
		U(0xf) << MP1_DIS_RGU1_WAIT_PD_CPUS_L1_ACK_SHIFT,
	MP1_DIS_RGU2_WAIT_PD_CPUS_L1_ACK =
		U(0xf) << MP1_DIS_RGU2_WAIT_PD_CPUS_L1_ACK_SHIFT,
	MP1_DIS_RGU3_WAIT_PD_CPUS_L1_ACK =
		U(0xf) << MP1_DIS_RGU3_WAIT_PD_CPUS_L1_ACK_SHIFT,
	MP1_DIS_RGU_NOCPU_WAIT_PD_CPUS_L1_ACK =
		U(0xf) << MP1_DIS_RGU_NOCPU_WAIT_PD_CPUS_L1_ACK_SHIFT
};

enum {
	MP1_AINACTS_SHIFT = 4U,
	MP1_AINACTS = 1U << MP1_AINACTS_SHIFT
};

enum {
	MP1_SW_CG_GEN_SHIFT = 12U,
	MP1_SW_CG_GEN = 1U << MP1_SW_CG_GEN_SHIFT
};

enum {
	MP1_L2RSTDISABLE_SHIFT = 14U,
	MP1_L2RSTDISABLE = 1U << MP1_L2RSTDISABLE_SHIFT
};
#endif /* __ASSEMBLER__ */

#endif  /* MCUCFG_H */