1 | /* SPDX-License-Identifier: GPL-2.0 */ |
2 | /* Copyright 2010-2017 ARM Limited. All rights reserved. |
3 | * Copyright 2017-2019 Qiang Yu <yuq825@gmail.com> |
4 | */ |
5 | |
6 | #ifndef __LIMA_REGS_H__ |
7 | #define __LIMA_REGS_H__ |
8 | |
9 | /* This file's register definition is collected from the |
10 | * official ARM Mali Utgard GPU kernel driver source code |
11 | */ |
12 | |
13 | /* PMU regs */ |
14 | #define LIMA_PMU_POWER_UP 0x00 |
15 | #define LIMA_PMU_POWER_DOWN 0x04 |
16 | #define LIMA_PMU_POWER_GP0_MASK BIT(0) |
17 | #define LIMA_PMU_POWER_L2_MASK BIT(1) |
18 | #define LIMA_PMU_POWER_PP_MASK(i) BIT(2 + i) |
19 | |
20 | /* |
21 | * On Mali450 each block automatically starts up its corresponding L2 |
22 | * and the PPs are not fully independent controllable. |
23 | * Instead PP0, PP1-3 and PP4-7 can be turned on or off. |
24 | */ |
25 | #define LIMA450_PMU_POWER_PP0_MASK BIT(1) |
26 | #define LIMA450_PMU_POWER_PP13_MASK BIT(2) |
27 | #define LIMA450_PMU_POWER_PP47_MASK BIT(3) |
28 | |
29 | #define LIMA_PMU_STATUS 0x08 |
30 | #define LIMA_PMU_INT_MASK 0x0C |
31 | #define LIMA_PMU_INT_RAWSTAT 0x10 |
32 | #define LIMA_PMU_INT_CLEAR 0x18 |
33 | #define LIMA_PMU_INT_CMD_MASK BIT(0) |
34 | #define LIMA_PMU_SW_DELAY 0x1C |
35 | |
36 | /* L2 cache regs */ |
37 | #define LIMA_L2_CACHE_SIZE 0x0004 |
38 | #define LIMA_L2_CACHE_STATUS 0x0008 |
39 | #define LIMA_L2_CACHE_STATUS_COMMAND_BUSY BIT(0) |
40 | #define LIMA_L2_CACHE_STATUS_DATA_BUSY BIT(1) |
41 | #define LIMA_L2_CACHE_COMMAND 0x0010 |
42 | #define LIMA_L2_CACHE_COMMAND_CLEAR_ALL BIT(0) |
43 | #define LIMA_L2_CACHE_CLEAR_PAGE 0x0014 |
44 | #define LIMA_L2_CACHE_MAX_READS 0x0018 |
45 | #define LIMA_L2_CACHE_ENABLE 0x001C |
46 | #define LIMA_L2_CACHE_ENABLE_ACCESS BIT(0) |
47 | #define LIMA_L2_CACHE_ENABLE_READ_ALLOCATE BIT(1) |
48 | #define LIMA_L2_CACHE_PERFCNT_SRC0 0x0020 |
49 | #define LIMA_L2_CACHE_PERFCNT_VAL0 0x0024 |
50 | #define LIMA_L2_CACHE_PERFCNT_SRC1 0x0028 |
51 | #define LIMA_L2_CACHE_ERFCNT_VAL1 0x002C |
52 | |
53 | /* GP regs */ |
54 | #define LIMA_GP_VSCL_START_ADDR 0x00 |
55 | #define LIMA_GP_VSCL_END_ADDR 0x04 |
56 | #define LIMA_GP_PLBUCL_START_ADDR 0x08 |
57 | #define LIMA_GP_PLBUCL_END_ADDR 0x0c |
58 | #define LIMA_GP_PLBU_ALLOC_START_ADDR 0x10 |
59 | #define LIMA_GP_PLBU_ALLOC_END_ADDR 0x14 |
60 | #define LIMA_GP_CMD 0x20 |
61 | #define LIMA_GP_CMD_START_VS BIT(0) |
62 | #define LIMA_GP_CMD_START_PLBU BIT(1) |
63 | #define LIMA_GP_CMD_UPDATE_PLBU_ALLOC BIT(4) |
64 | #define LIMA_GP_CMD_RESET BIT(5) |
65 | #define LIMA_GP_CMD_FORCE_HANG BIT(6) |
66 | #define LIMA_GP_CMD_STOP_BUS BIT(9) |
67 | #define LIMA_GP_CMD_SOFT_RESET BIT(10) |
68 | #define LIMA_GP_INT_RAWSTAT 0x24 |
69 | #define LIMA_GP_INT_CLEAR 0x28 |
70 | #define LIMA_GP_INT_MASK 0x2C |
71 | #define LIMA_GP_INT_STAT 0x30 |
72 | #define LIMA_GP_IRQ_VS_END_CMD_LST BIT(0) |
73 | #define LIMA_GP_IRQ_PLBU_END_CMD_LST BIT(1) |
74 | #define LIMA_GP_IRQ_PLBU_OUT_OF_MEM BIT(2) |
75 | #define LIMA_GP_IRQ_VS_SEM_IRQ BIT(3) |
76 | #define LIMA_GP_IRQ_PLBU_SEM_IRQ BIT(4) |
77 | #define LIMA_GP_IRQ_HANG BIT(5) |
78 | #define LIMA_GP_IRQ_FORCE_HANG BIT(6) |
79 | #define LIMA_GP_IRQ_PERF_CNT_0_LIMIT BIT(7) |
80 | #define LIMA_GP_IRQ_PERF_CNT_1_LIMIT BIT(8) |
81 | #define LIMA_GP_IRQ_WRITE_BOUND_ERR BIT(9) |
82 | #define LIMA_GP_IRQ_SYNC_ERROR BIT(10) |
83 | #define LIMA_GP_IRQ_AXI_BUS_ERROR BIT(11) |
84 | #define LIMA_GP_IRQ_AXI_BUS_STOPPED BIT(12) |
85 | #define LIMA_GP_IRQ_VS_INVALID_CMD BIT(13) |
86 | #define LIMA_GP_IRQ_PLB_INVALID_CMD BIT(14) |
87 | #define LIMA_GP_IRQ_RESET_COMPLETED BIT(19) |
88 | #define LIMA_GP_IRQ_SEMAPHORE_UNDERFLOW BIT(20) |
89 | #define LIMA_GP_IRQ_SEMAPHORE_OVERFLOW BIT(21) |
90 | #define LIMA_GP_IRQ_PTR_ARRAY_OUT_OF_BOUNDS BIT(22) |
91 | #define LIMA_GP_WRITE_BOUND_LOW 0x34 |
92 | #define LIMA_GP_PERF_CNT_0_ENABLE 0x3C |
93 | #define LIMA_GP_PERF_CNT_1_ENABLE 0x40 |
94 | #define LIMA_GP_PERF_CNT_0_SRC 0x44 |
95 | #define LIMA_GP_PERF_CNT_1_SRC 0x48 |
96 | #define LIMA_GP_PERF_CNT_0_VALUE 0x4C |
97 | #define LIMA_GP_PERF_CNT_1_VALUE 0x50 |
98 | #define LIMA_GP_PERF_CNT_0_LIMIT 0x54 |
99 | #define LIMA_GP_STATUS 0x68 |
100 | #define LIMA_GP_STATUS_VS_ACTIVE BIT(1) |
101 | #define LIMA_GP_STATUS_BUS_STOPPED BIT(2) |
102 | #define LIMA_GP_STATUS_PLBU_ACTIVE BIT(3) |
103 | #define LIMA_GP_STATUS_BUS_ERROR BIT(6) |
104 | #define LIMA_GP_STATUS_WRITE_BOUND_ERR BIT(8) |
105 | #define LIMA_GP_VERSION 0x6C |
106 | #define LIMA_GP_VSCL_START_ADDR_READ 0x80 |
107 | #define LIMA_GP_PLBCL_START_ADDR_READ 0x84 |
108 | #define LIMA_GP_CONTR_AXI_BUS_ERROR_STAT 0x94 |
109 | |
110 | #define LIMA_GP_IRQ_MASK_ALL \ |
111 | ( \ |
112 | LIMA_GP_IRQ_VS_END_CMD_LST | \ |
113 | LIMA_GP_IRQ_PLBU_END_CMD_LST | \ |
114 | LIMA_GP_IRQ_PLBU_OUT_OF_MEM | \ |
115 | LIMA_GP_IRQ_VS_SEM_IRQ | \ |
116 | LIMA_GP_IRQ_PLBU_SEM_IRQ | \ |
117 | LIMA_GP_IRQ_HANG | \ |
118 | LIMA_GP_IRQ_FORCE_HANG | \ |
119 | LIMA_GP_IRQ_PERF_CNT_0_LIMIT | \ |
120 | LIMA_GP_IRQ_PERF_CNT_1_LIMIT | \ |
121 | LIMA_GP_IRQ_WRITE_BOUND_ERR | \ |
122 | LIMA_GP_IRQ_SYNC_ERROR | \ |
123 | LIMA_GP_IRQ_AXI_BUS_ERROR | \ |
124 | LIMA_GP_IRQ_AXI_BUS_STOPPED | \ |
125 | LIMA_GP_IRQ_VS_INVALID_CMD | \ |
126 | LIMA_GP_IRQ_PLB_INVALID_CMD | \ |
127 | LIMA_GP_IRQ_RESET_COMPLETED | \ |
128 | LIMA_GP_IRQ_SEMAPHORE_UNDERFLOW | \ |
129 | LIMA_GP_IRQ_SEMAPHORE_OVERFLOW | \ |
130 | LIMA_GP_IRQ_PTR_ARRAY_OUT_OF_BOUNDS) |
131 | |
132 | #define LIMA_GP_IRQ_MASK_ERROR \ |
133 | ( \ |
134 | LIMA_GP_IRQ_PLBU_OUT_OF_MEM | \ |
135 | LIMA_GP_IRQ_FORCE_HANG | \ |
136 | LIMA_GP_IRQ_WRITE_BOUND_ERR | \ |
137 | LIMA_GP_IRQ_SYNC_ERROR | \ |
138 | LIMA_GP_IRQ_AXI_BUS_ERROR | \ |
139 | LIMA_GP_IRQ_VS_INVALID_CMD | \ |
140 | LIMA_GP_IRQ_PLB_INVALID_CMD | \ |
141 | LIMA_GP_IRQ_SEMAPHORE_UNDERFLOW | \ |
142 | LIMA_GP_IRQ_SEMAPHORE_OVERFLOW | \ |
143 | LIMA_GP_IRQ_PTR_ARRAY_OUT_OF_BOUNDS) |
144 | |
145 | #define LIMA_GP_IRQ_MASK_USED \ |
146 | ( \ |
147 | LIMA_GP_IRQ_VS_END_CMD_LST | \ |
148 | LIMA_GP_IRQ_PLBU_END_CMD_LST | \ |
149 | LIMA_GP_IRQ_MASK_ERROR) |
150 | |
151 | /* PP regs */ |
152 | #define LIMA_PP_FRAME 0x0000 |
153 | #define LIMA_PP_RSW 0x0004 |
154 | #define LIMA_PP_STACK 0x0030 |
155 | #define LIMA_PP_STACK_SIZE 0x0034 |
156 | #define LIMA_PP_ORIGIN_OFFSET_X 0x0040 |
157 | #define LIMA_PP_WB(i) (0x0100 * (i + 1)) |
158 | #define LIMA_PP_WB_SOURCE_SELECT 0x0000 |
159 | #define LIMA_PP_WB_SOURCE_ADDR 0x0004 |
160 | |
161 | #define LIMA_PP_VERSION 0x1000 |
162 | #define LIMA_PP_CURRENT_REND_LIST_ADDR 0x1004 |
163 | #define LIMA_PP_STATUS 0x1008 |
164 | #define LIMA_PP_STATUS_RENDERING_ACTIVE BIT(0) |
165 | #define LIMA_PP_STATUS_BUS_STOPPED BIT(4) |
166 | #define LIMA_PP_CTRL 0x100c |
167 | #define LIMA_PP_CTRL_STOP_BUS BIT(0) |
168 | #define LIMA_PP_CTRL_FLUSH_CACHES BIT(3) |
169 | #define LIMA_PP_CTRL_FORCE_RESET BIT(5) |
170 | #define LIMA_PP_CTRL_START_RENDERING BIT(6) |
171 | #define LIMA_PP_CTRL_SOFT_RESET BIT(7) |
172 | #define LIMA_PP_INT_RAWSTAT 0x1020 |
173 | #define LIMA_PP_INT_CLEAR 0x1024 |
174 | #define LIMA_PP_INT_MASK 0x1028 |
175 | #define LIMA_PP_INT_STATUS 0x102c |
176 | #define LIMA_PP_IRQ_END_OF_FRAME BIT(0) |
177 | #define LIMA_PP_IRQ_END_OF_TILE BIT(1) |
178 | #define LIMA_PP_IRQ_HANG BIT(2) |
179 | #define LIMA_PP_IRQ_FORCE_HANG BIT(3) |
180 | #define LIMA_PP_IRQ_BUS_ERROR BIT(4) |
181 | #define LIMA_PP_IRQ_BUS_STOP BIT(5) |
182 | #define LIMA_PP_IRQ_CNT_0_LIMIT BIT(6) |
183 | #define LIMA_PP_IRQ_CNT_1_LIMIT BIT(7) |
184 | #define LIMA_PP_IRQ_WRITE_BOUNDARY_ERROR BIT(8) |
185 | #define LIMA_PP_IRQ_INVALID_PLIST_COMMAND BIT(9) |
186 | #define LIMA_PP_IRQ_CALL_STACK_UNDERFLOW BIT(10) |
187 | #define LIMA_PP_IRQ_CALL_STACK_OVERFLOW BIT(11) |
188 | #define LIMA_PP_IRQ_RESET_COMPLETED BIT(12) |
189 | #define LIMA_PP_WRITE_BOUNDARY_LOW 0x1044 |
190 | #define LIMA_PP_BUS_ERROR_STATUS 0x1050 |
191 | #define LIMA_PP_PERF_CNT_0_ENABLE 0x1080 |
192 | #define LIMA_PP_PERF_CNT_0_SRC 0x1084 |
193 | #define LIMA_PP_PERF_CNT_0_LIMIT 0x1088 |
194 | #define LIMA_PP_PERF_CNT_0_VALUE 0x108c |
195 | #define LIMA_PP_PERF_CNT_1_ENABLE 0x10a0 |
196 | #define LIMA_PP_PERF_CNT_1_SRC 0x10a4 |
197 | #define LIMA_PP_PERF_CNT_1_LIMIT 0x10a8 |
198 | #define LIMA_PP_PERF_CNT_1_VALUE 0x10ac |
199 | #define LIMA_PP_PERFMON_CONTR 0x10b0 |
200 | #define LIMA_PP_PERFMON_BASE 0x10b4 |
201 | |
202 | #define LIMA_PP_IRQ_MASK_ALL \ |
203 | ( \ |
204 | LIMA_PP_IRQ_END_OF_FRAME | \ |
205 | LIMA_PP_IRQ_END_OF_TILE | \ |
206 | LIMA_PP_IRQ_HANG | \ |
207 | LIMA_PP_IRQ_FORCE_HANG | \ |
208 | LIMA_PP_IRQ_BUS_ERROR | \ |
209 | LIMA_PP_IRQ_BUS_STOP | \ |
210 | LIMA_PP_IRQ_CNT_0_LIMIT | \ |
211 | LIMA_PP_IRQ_CNT_1_LIMIT | \ |
212 | LIMA_PP_IRQ_WRITE_BOUNDARY_ERROR | \ |
213 | LIMA_PP_IRQ_INVALID_PLIST_COMMAND | \ |
214 | LIMA_PP_IRQ_CALL_STACK_UNDERFLOW | \ |
215 | LIMA_PP_IRQ_CALL_STACK_OVERFLOW | \ |
216 | LIMA_PP_IRQ_RESET_COMPLETED) |
217 | |
218 | #define LIMA_PP_IRQ_MASK_ERROR \ |
219 | ( \ |
220 | LIMA_PP_IRQ_FORCE_HANG | \ |
221 | LIMA_PP_IRQ_BUS_ERROR | \ |
222 | LIMA_PP_IRQ_WRITE_BOUNDARY_ERROR | \ |
223 | LIMA_PP_IRQ_INVALID_PLIST_COMMAND | \ |
224 | LIMA_PP_IRQ_CALL_STACK_UNDERFLOW | \ |
225 | LIMA_PP_IRQ_CALL_STACK_OVERFLOW) |
226 | |
227 | #define LIMA_PP_IRQ_MASK_USED \ |
228 | ( \ |
229 | LIMA_PP_IRQ_END_OF_FRAME | \ |
230 | LIMA_PP_IRQ_MASK_ERROR) |
231 | |
232 | /* MMU regs */ |
233 | #define LIMA_MMU_DTE_ADDR 0x0000 |
234 | #define LIMA_MMU_STATUS 0x0004 |
235 | #define LIMA_MMU_STATUS_PAGING_ENABLED BIT(0) |
236 | #define LIMA_MMU_STATUS_PAGE_FAULT_ACTIVE BIT(1) |
237 | #define LIMA_MMU_STATUS_STALL_ACTIVE BIT(2) |
238 | #define LIMA_MMU_STATUS_IDLE BIT(3) |
239 | #define LIMA_MMU_STATUS_REPLAY_BUFFER_EMPTY BIT(4) |
240 | #define LIMA_MMU_STATUS_PAGE_FAULT_IS_WRITE BIT(5) |
241 | #define LIMA_MMU_STATUS_BUS_ID(x) ((x >> 6) & 0x1F) |
242 | #define LIMA_MMU_STATUS_STALL_NOT_ACTIVE BIT(31) |
243 | #define LIMA_MMU_COMMAND 0x0008 |
244 | #define LIMA_MMU_COMMAND_ENABLE_PAGING 0x00 |
245 | #define LIMA_MMU_COMMAND_DISABLE_PAGING 0x01 |
246 | #define LIMA_MMU_COMMAND_ENABLE_STALL 0x02 |
247 | #define LIMA_MMU_COMMAND_DISABLE_STALL 0x03 |
248 | #define LIMA_MMU_COMMAND_ZAP_CACHE 0x04 |
249 | #define LIMA_MMU_COMMAND_PAGE_FAULT_DONE 0x05 |
250 | #define LIMA_MMU_COMMAND_HARD_RESET 0x06 |
251 | #define LIMA_MMU_PAGE_FAULT_ADDR 0x000C |
252 | #define LIMA_MMU_ZAP_ONE_LINE 0x0010 |
253 | #define LIMA_MMU_INT_RAWSTAT 0x0014 |
254 | #define LIMA_MMU_INT_CLEAR 0x0018 |
255 | #define LIMA_MMU_INT_MASK 0x001C |
256 | #define LIMA_MMU_INT_PAGE_FAULT BIT(0) |
257 | #define LIMA_MMU_INT_READ_BUS_ERROR BIT(1) |
258 | #define LIMA_MMU_INT_STATUS 0x0020 |
259 | |
260 | #define LIMA_VM_FLAG_PRESENT BIT(0) |
261 | #define LIMA_VM_FLAG_READ_PERMISSION BIT(1) |
262 | #define LIMA_VM_FLAG_WRITE_PERMISSION BIT(2) |
263 | #define LIMA_VM_FLAG_OVERRIDE_CACHE BIT(3) |
264 | #define LIMA_VM_FLAG_WRITE_CACHEABLE BIT(4) |
265 | #define LIMA_VM_FLAG_WRITE_ALLOCATE BIT(5) |
266 | #define LIMA_VM_FLAG_WRITE_BUFFERABLE BIT(6) |
267 | #define LIMA_VM_FLAG_READ_CACHEABLE BIT(7) |
268 | #define LIMA_VM_FLAG_READ_ALLOCATE BIT(8) |
269 | #define LIMA_VM_FLAG_MASK 0x1FF |
270 | |
271 | #define LIMA_VM_FLAGS_CACHE ( \ |
272 | LIMA_VM_FLAG_PRESENT | \ |
273 | LIMA_VM_FLAG_READ_PERMISSION | \ |
274 | LIMA_VM_FLAG_WRITE_PERMISSION | \ |
275 | LIMA_VM_FLAG_OVERRIDE_CACHE | \ |
276 | LIMA_VM_FLAG_WRITE_CACHEABLE | \ |
277 | LIMA_VM_FLAG_WRITE_BUFFERABLE | \ |
278 | LIMA_VM_FLAG_READ_CACHEABLE | \ |
279 | LIMA_VM_FLAG_READ_ALLOCATE) |
280 | |
281 | #define LIMA_VM_FLAGS_UNCACHE ( \ |
282 | LIMA_VM_FLAG_PRESENT | \ |
283 | LIMA_VM_FLAG_READ_PERMISSION | \ |
284 | LIMA_VM_FLAG_WRITE_PERMISSION) |
285 | |
286 | /* DLBU regs */ |
287 | #define LIMA_DLBU_MASTER_TLLIST_PHYS_ADDR 0x0000 |
288 | #define LIMA_DLBU_MASTER_TLLIST_VADDR 0x0004 |
289 | #define LIMA_DLBU_TLLIST_VBASEADDR 0x0008 |
290 | #define LIMA_DLBU_FB_DIM 0x000C |
291 | #define LIMA_DLBU_TLLIST_CONF 0x0010 |
292 | #define LIMA_DLBU_START_TILE_POS 0x0014 |
293 | #define LIMA_DLBU_PP_ENABLE_MASK 0x0018 |
294 | |
295 | /* BCAST regs */ |
296 | #define LIMA_BCAST_BROADCAST_MASK 0x0 |
297 | #define LIMA_BCAST_INTERRUPT_MASK 0x4 |
298 | |
299 | #endif |
300 | |