diff options
author | Alex Deucher <alexdeucher@gmail.com> | 2010-05-28 19:01:35 -0400 |
---|---|---|
committer | Dave Airlie <airlied@redhat.com> | 2010-05-31 21:46:04 -0400 |
commit | cb5fcbd540b438a5d311bd15dc910841d01ed140 (patch) | |
tree | e4d481c8e47eaa377551dc3d7735915cbc6a3c8e /drivers/gpu | |
parent | 36d1701c502d4f46386e1000ad58d9497a11688d (diff) |
drm/radeon/kms/evergreen: add initial CS parser
Advanced validation is not implemented yet.
The mesa code that uses this will be released soon.
Signed-off-by: Alex Deucher <alexdeucher@gmail.com>
Signed-off-by: Dave Airlie <airlied@redhat.com>
Diffstat (limited to 'drivers/gpu')
-rw-r--r-- | drivers/gpu/drm/radeon/Makefile | 7 | ||||
-rw-r--r-- | drivers/gpu/drm/radeon/evergreen_cs.c | 1356 | ||||
-rw-r--r-- | drivers/gpu/drm/radeon/evergreen_reg.h | 3 | ||||
-rw-r--r-- | drivers/gpu/drm/radeon/evergreend.h | 464 | ||||
-rw-r--r-- | drivers/gpu/drm/radeon/radeon_asic.c | 4 | ||||
-rw-r--r-- | drivers/gpu/drm/radeon/radeon_asic.h | 1 | ||||
-rw-r--r-- | drivers/gpu/drm/radeon/reg_srcs/evergreen | 611 |
7 files changed, 2443 insertions, 3 deletions
diff --git a/drivers/gpu/drm/radeon/Makefile b/drivers/gpu/drm/radeon/Makefile index 3c91312dea9a..84b1f2729d43 100644 --- a/drivers/gpu/drm/radeon/Makefile +++ b/drivers/gpu/drm/radeon/Makefile | |||
@@ -33,6 +33,9 @@ $(obj)/rs600_reg_safe.h: $(src)/reg_srcs/rs600 $(obj)/mkregtable | |||
33 | $(obj)/r600_reg_safe.h: $(src)/reg_srcs/r600 $(obj)/mkregtable | 33 | $(obj)/r600_reg_safe.h: $(src)/reg_srcs/r600 $(obj)/mkregtable |
34 | $(call if_changed,mkregtable) | 34 | $(call if_changed,mkregtable) |
35 | 35 | ||
36 | $(obj)/evergreen_reg_safe.h: $(src)/reg_srcs/evergreen $(obj)/mkregtable | ||
37 | $(call if_changed,mkregtable) | ||
38 | |||
36 | $(obj)/r100.o: $(obj)/r100_reg_safe.h $(obj)/rn50_reg_safe.h | 39 | $(obj)/r100.o: $(obj)/r100_reg_safe.h $(obj)/rn50_reg_safe.h |
37 | 40 | ||
38 | $(obj)/r200.o: $(obj)/r200_reg_safe.h | 41 | $(obj)/r200.o: $(obj)/r200_reg_safe.h |
@@ -47,6 +50,8 @@ $(obj)/rs600.o: $(obj)/rs600_reg_safe.h | |||
47 | 50 | ||
48 | $(obj)/r600_cs.o: $(obj)/r600_reg_safe.h | 51 | $(obj)/r600_cs.o: $(obj)/r600_reg_safe.h |
49 | 52 | ||
53 | $(obj)/evergreen_cs.o: $(obj)/evergreen_reg_safe.h | ||
54 | |||
50 | radeon-y := radeon_drv.o radeon_cp.o radeon_state.o radeon_mem.o \ | 55 | radeon-y := radeon_drv.o radeon_cp.o radeon_state.o radeon_mem.o \ |
51 | radeon_irq.o r300_cmdbuf.o r600_cp.o | 56 | radeon_irq.o r300_cmdbuf.o r600_cp.o |
52 | # add KMS driver | 57 | # add KMS driver |
@@ -60,7 +65,7 @@ radeon-y += radeon_device.o radeon_asic.o radeon_kms.o \ | |||
60 | rs400.o rs600.o rs690.o rv515.o r520.o r600.o rv770.o radeon_test.o \ | 65 | rs400.o rs600.o rs690.o rv515.o r520.o r600.o rv770.o radeon_test.o \ |
61 | r200.o radeon_legacy_tv.o r600_cs.o r600_blit.o r600_blit_shaders.o \ | 66 | r200.o radeon_legacy_tv.o r600_cs.o r600_blit.o r600_blit_shaders.o \ |
62 | r600_blit_kms.o radeon_pm.o atombios_dp.o r600_audio.o r600_hdmi.o \ | 67 | r600_blit_kms.o radeon_pm.o atombios_dp.o r600_audio.o r600_hdmi.o \ |
63 | evergreen.o | 68 | evergreen.o evergreen_cs.o |
64 | 69 | ||
65 | radeon-$(CONFIG_COMPAT) += radeon_ioc32.o | 70 | radeon-$(CONFIG_COMPAT) += radeon_ioc32.o |
66 | radeon-$(CONFIG_VGA_SWITCHEROO) += radeon_atpx_handler.o | 71 | radeon-$(CONFIG_VGA_SWITCHEROO) += radeon_atpx_handler.o |
diff --git a/drivers/gpu/drm/radeon/evergreen_cs.c b/drivers/gpu/drm/radeon/evergreen_cs.c new file mode 100644 index 000000000000..64516b950891 --- /dev/null +++ b/drivers/gpu/drm/radeon/evergreen_cs.c | |||
@@ -0,0 +1,1356 @@ | |||
1 | /* | ||
2 | * Copyright 2010 Advanced Micro Devices, Inc. | ||
3 | * Copyright 2008 Red Hat Inc. | ||
4 | * Copyright 2009 Jerome Glisse. | ||
5 | * | ||
6 | * Permission is hereby granted, free of charge, to any person obtaining a | ||
7 | * copy of this software and associated documentation files (the "Software"), | ||
8 | * to deal in the Software without restriction, including without limitation | ||
9 | * the rights to use, copy, modify, merge, publish, distribute, sublicense, | ||
10 | * and/or sell copies of the Software, and to permit persons to whom the | ||
11 | * Software is furnished to do so, subject to the following conditions: | ||
12 | * | ||
13 | * The above copyright notice and this permission notice shall be included in | ||
14 | * all copies or substantial portions of the Software. | ||
15 | * | ||
16 | * THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR | ||
17 | * IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY, | ||
18 | * FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL | ||
19 | * THE COPYRIGHT HOLDER(S) OR AUTHOR(S) BE LIABLE FOR ANY CLAIM, DAMAGES OR | ||
20 | * OTHER LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, | ||
21 | * ARISING FROM, OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR | ||
22 | * OTHER DEALINGS IN THE SOFTWARE. | ||
23 | * | ||
24 | * Authors: Dave Airlie | ||
25 | * Alex Deucher | ||
26 | * Jerome Glisse | ||
27 | */ | ||
28 | #include "drmP.h" | ||
29 | #include "radeon.h" | ||
30 | #include "evergreend.h" | ||
31 | #include "evergreen_reg_safe.h" | ||
32 | |||
33 | static int evergreen_cs_packet_next_reloc(struct radeon_cs_parser *p, | ||
34 | struct radeon_cs_reloc **cs_reloc); | ||
35 | |||
36 | struct evergreen_cs_track { | ||
37 | u32 group_size; | ||
38 | u32 nbanks; | ||
39 | u32 npipes; | ||
40 | /* value we track */ | ||
41 | u32 nsamples; | ||
42 | u32 cb_color_base_last[12]; | ||
43 | struct radeon_bo *cb_color_bo[12]; | ||
44 | u32 cb_color_bo_offset[12]; | ||
45 | struct radeon_bo *cb_color_fmask_bo[8]; | ||
46 | struct radeon_bo *cb_color_cmask_bo[8]; | ||
47 | u32 cb_color_info[12]; | ||
48 | u32 cb_color_view[12]; | ||
49 | u32 cb_color_pitch_idx[12]; | ||
50 | u32 cb_color_slice_idx[12]; | ||
51 | u32 cb_color_dim_idx[12]; | ||
52 | u32 cb_color_dim[12]; | ||
53 | u32 cb_color_pitch[12]; | ||
54 | u32 cb_color_slice[12]; | ||
55 | u32 cb_color_cmask_slice[8]; | ||
56 | u32 cb_color_fmask_slice[8]; | ||
57 | u32 cb_target_mask; | ||
58 | u32 cb_shader_mask; | ||
59 | u32 vgt_strmout_config; | ||
60 | u32 vgt_strmout_buffer_config; | ||
61 | u32 db_depth_control; | ||
62 | u32 db_depth_view; | ||
63 | u32 db_depth_size; | ||
64 | u32 db_depth_size_idx; | ||
65 | u32 db_z_info; | ||
66 | u32 db_z_idx; | ||
67 | u32 db_z_read_offset; | ||
68 | u32 db_z_write_offset; | ||
69 | struct radeon_bo *db_z_read_bo; | ||
70 | struct radeon_bo *db_z_write_bo; | ||
71 | u32 db_s_info; | ||
72 | u32 db_s_idx; | ||
73 | u32 db_s_read_offset; | ||
74 | u32 db_s_write_offset; | ||
75 | struct radeon_bo *db_s_read_bo; | ||
76 | struct radeon_bo *db_s_write_bo; | ||
77 | }; | ||
78 | |||
79 | static void evergreen_cs_track_init(struct evergreen_cs_track *track) | ||
80 | { | ||
81 | int i; | ||
82 | |||
83 | for (i = 0; i < 8; i++) { | ||
84 | track->cb_color_fmask_bo[i] = NULL; | ||
85 | track->cb_color_cmask_bo[i] = NULL; | ||
86 | track->cb_color_cmask_slice[i] = 0; | ||
87 | track->cb_color_fmask_slice[i] = 0; | ||
88 | } | ||
89 | |||
90 | for (i = 0; i < 12; i++) { | ||
91 | track->cb_color_base_last[i] = 0; | ||
92 | track->cb_color_bo[i] = NULL; | ||
93 | track->cb_color_bo_offset[i] = 0xFFFFFFFF; | ||
94 | track->cb_color_info[i] = 0; | ||
95 | track->cb_color_view[i] = 0; | ||
96 | track->cb_color_pitch_idx[i] = 0; | ||
97 | track->cb_color_slice_idx[i] = 0; | ||
98 | track->cb_color_dim[i] = 0; | ||
99 | track->cb_color_pitch[i] = 0; | ||
100 | track->cb_color_slice[i] = 0; | ||
101 | track->cb_color_dim[i] = 0; | ||
102 | } | ||
103 | track->cb_target_mask = 0xFFFFFFFF; | ||
104 | track->cb_shader_mask = 0xFFFFFFFF; | ||
105 | |||
106 | track->db_depth_view = 0xFFFFC000; | ||
107 | track->db_depth_size = 0xFFFFFFFF; | ||
108 | track->db_depth_size_idx = 0; | ||
109 | track->db_depth_control = 0xFFFFFFFF; | ||
110 | track->db_z_info = 0xFFFFFFFF; | ||
111 | track->db_z_idx = 0xFFFFFFFF; | ||
112 | track->db_z_read_offset = 0xFFFFFFFF; | ||
113 | track->db_z_write_offset = 0xFFFFFFFF; | ||
114 | track->db_z_read_bo = NULL; | ||
115 | track->db_z_write_bo = NULL; | ||
116 | track->db_s_info = 0xFFFFFFFF; | ||
117 | track->db_s_idx = 0xFFFFFFFF; | ||
118 | track->db_s_read_offset = 0xFFFFFFFF; | ||
119 | track->db_s_write_offset = 0xFFFFFFFF; | ||
120 | track->db_s_read_bo = NULL; | ||
121 | track->db_s_write_bo = NULL; | ||
122 | } | ||
123 | |||
124 | static inline int evergreen_cs_track_validate_cb(struct radeon_cs_parser *p, int i) | ||
125 | { | ||
126 | /* XXX fill in */ | ||
127 | return 0; | ||
128 | } | ||
129 | |||
130 | static int evergreen_cs_track_check(struct radeon_cs_parser *p) | ||
131 | { | ||
132 | struct evergreen_cs_track *track = p->track; | ||
133 | |||
134 | /* we don't support stream out buffer yet */ | ||
135 | if (track->vgt_strmout_config || track->vgt_strmout_buffer_config) { | ||
136 | dev_warn(p->dev, "this kernel doesn't support SMX output buffer\n"); | ||
137 | return -EINVAL; | ||
138 | } | ||
139 | |||
140 | /* XXX fill in */ | ||
141 | return 0; | ||
142 | } | ||
143 | |||
144 | /** | ||
145 | * evergreen_cs_packet_parse() - parse cp packet and point ib index to next packet | ||
146 | * @parser: parser structure holding parsing context. | ||
147 | * @pkt: where to store packet informations | ||
148 | * | ||
149 | * Assume that chunk_ib_index is properly set. Will return -EINVAL | ||
150 | * if packet is bigger than remaining ib size. or if packets is unknown. | ||
151 | **/ | ||
152 | int evergreen_cs_packet_parse(struct radeon_cs_parser *p, | ||
153 | struct radeon_cs_packet *pkt, | ||
154 | unsigned idx) | ||
155 | { | ||
156 | struct radeon_cs_chunk *ib_chunk = &p->chunks[p->chunk_ib_idx]; | ||
157 | uint32_t header; | ||
158 | |||
159 | if (idx >= ib_chunk->length_dw) { | ||
160 | DRM_ERROR("Can not parse packet at %d after CS end %d !\n", | ||
161 | idx, ib_chunk->length_dw); | ||
162 | return -EINVAL; | ||
163 | } | ||
164 | header = radeon_get_ib_value(p, idx); | ||
165 | pkt->idx = idx; | ||
166 | pkt->type = CP_PACKET_GET_TYPE(header); | ||
167 | pkt->count = CP_PACKET_GET_COUNT(header); | ||
168 | pkt->one_reg_wr = 0; | ||
169 | switch (pkt->type) { | ||
170 | case PACKET_TYPE0: | ||
171 | pkt->reg = CP_PACKET0_GET_REG(header); | ||
172 | break; | ||
173 | case PACKET_TYPE3: | ||
174 | pkt->opcode = CP_PACKET3_GET_OPCODE(header); | ||
175 | break; | ||
176 | case PACKET_TYPE2: | ||
177 | pkt->count = -1; | ||
178 | break; | ||
179 | default: | ||
180 | DRM_ERROR("Unknown packet type %d at %d !\n", pkt->type, idx); | ||
181 | return -EINVAL; | ||
182 | } | ||
183 | if ((pkt->count + 1 + pkt->idx) >= ib_chunk->length_dw) { | ||
184 | DRM_ERROR("Packet (%d:%d:%d) end after CS buffer (%d) !\n", | ||
185 | pkt->idx, pkt->type, pkt->count, ib_chunk->length_dw); | ||
186 | return -EINVAL; | ||
187 | } | ||
188 | return 0; | ||
189 | } | ||
190 | |||
191 | /** | ||
192 | * evergreen_cs_packet_next_reloc() - parse next packet which should be reloc packet3 | ||
193 | * @parser: parser structure holding parsing context. | ||
194 | * @data: pointer to relocation data | ||
195 | * @offset_start: starting offset | ||
196 | * @offset_mask: offset mask (to align start offset on) | ||
197 | * @reloc: reloc informations | ||
198 | * | ||
199 | * Check next packet is relocation packet3, do bo validation and compute | ||
200 | * GPU offset using the provided start. | ||
201 | **/ | ||
202 | static int evergreen_cs_packet_next_reloc(struct radeon_cs_parser *p, | ||
203 | struct radeon_cs_reloc **cs_reloc) | ||
204 | { | ||
205 | struct radeon_cs_chunk *relocs_chunk; | ||
206 | struct radeon_cs_packet p3reloc; | ||
207 | unsigned idx; | ||
208 | int r; | ||
209 | |||
210 | if (p->chunk_relocs_idx == -1) { | ||
211 | DRM_ERROR("No relocation chunk !\n"); | ||
212 | return -EINVAL; | ||
213 | } | ||
214 | *cs_reloc = NULL; | ||
215 | relocs_chunk = &p->chunks[p->chunk_relocs_idx]; | ||
216 | r = evergreen_cs_packet_parse(p, &p3reloc, p->idx); | ||
217 | if (r) { | ||
218 | return r; | ||
219 | } | ||
220 | p->idx += p3reloc.count + 2; | ||
221 | if (p3reloc.type != PACKET_TYPE3 || p3reloc.opcode != PACKET3_NOP) { | ||
222 | DRM_ERROR("No packet3 for relocation for packet at %d.\n", | ||
223 | p3reloc.idx); | ||
224 | return -EINVAL; | ||
225 | } | ||
226 | idx = radeon_get_ib_value(p, p3reloc.idx + 1); | ||
227 | if (idx >= relocs_chunk->length_dw) { | ||
228 | DRM_ERROR("Relocs at %d after relocations chunk end %d !\n", | ||
229 | idx, relocs_chunk->length_dw); | ||
230 | return -EINVAL; | ||
231 | } | ||
232 | /* FIXME: we assume reloc size is 4 dwords */ | ||
233 | *cs_reloc = p->relocs_ptr[(idx / 4)]; | ||
234 | return 0; | ||
235 | } | ||
236 | |||
237 | /** | ||
238 | * evergreen_cs_packet_next_is_pkt3_nop() - test if next packet is packet3 nop for reloc | ||
239 | * @parser: parser structure holding parsing context. | ||
240 | * | ||
241 | * Check next packet is relocation packet3, do bo validation and compute | ||
242 | * GPU offset using the provided start. | ||
243 | **/ | ||
244 | static inline int evergreen_cs_packet_next_is_pkt3_nop(struct radeon_cs_parser *p) | ||
245 | { | ||
246 | struct radeon_cs_packet p3reloc; | ||
247 | int r; | ||
248 | |||
249 | r = evergreen_cs_packet_parse(p, &p3reloc, p->idx); | ||
250 | if (r) { | ||
251 | return 0; | ||
252 | } | ||
253 | if (p3reloc.type != PACKET_TYPE3 || p3reloc.opcode != PACKET3_NOP) { | ||
254 | return 0; | ||
255 | } | ||
256 | return 1; | ||
257 | } | ||
258 | |||
259 | /** | ||
260 | * evergreen_cs_packet_next_vline() - parse userspace VLINE packet | ||
261 | * @parser: parser structure holding parsing context. | ||
262 | * | ||
263 | * Userspace sends a special sequence for VLINE waits. | ||
264 | * PACKET0 - VLINE_START_END + value | ||
265 | * PACKET3 - WAIT_REG_MEM poll vline status reg | ||
266 | * RELOC (P3) - crtc_id in reloc. | ||
267 | * | ||
268 | * This function parses this and relocates the VLINE START END | ||
269 | * and WAIT_REG_MEM packets to the correct crtc. | ||
270 | * It also detects a switched off crtc and nulls out the | ||
271 | * wait in that case. | ||
272 | */ | ||
273 | static int evergreen_cs_packet_parse_vline(struct radeon_cs_parser *p) | ||
274 | { | ||
275 | struct drm_mode_object *obj; | ||
276 | struct drm_crtc *crtc; | ||
277 | struct radeon_crtc *radeon_crtc; | ||
278 | struct radeon_cs_packet p3reloc, wait_reg_mem; | ||
279 | int crtc_id; | ||
280 | int r; | ||
281 | uint32_t header, h_idx, reg, wait_reg_mem_info; | ||
282 | volatile uint32_t *ib; | ||
283 | |||
284 | ib = p->ib->ptr; | ||
285 | |||
286 | /* parse the WAIT_REG_MEM */ | ||
287 | r = evergreen_cs_packet_parse(p, &wait_reg_mem, p->idx); | ||
288 | if (r) | ||
289 | return r; | ||
290 | |||
291 | /* check its a WAIT_REG_MEM */ | ||
292 | if (wait_reg_mem.type != PACKET_TYPE3 || | ||
293 | wait_reg_mem.opcode != PACKET3_WAIT_REG_MEM) { | ||
294 | DRM_ERROR("vline wait missing WAIT_REG_MEM segment\n"); | ||
295 | r = -EINVAL; | ||
296 | return r; | ||
297 | } | ||
298 | |||
299 | wait_reg_mem_info = radeon_get_ib_value(p, wait_reg_mem.idx + 1); | ||
300 | /* bit 4 is reg (0) or mem (1) */ | ||
301 | if (wait_reg_mem_info & 0x10) { | ||
302 | DRM_ERROR("vline WAIT_REG_MEM waiting on MEM rather than REG\n"); | ||
303 | r = -EINVAL; | ||
304 | return r; | ||
305 | } | ||
306 | /* waiting for value to be equal */ | ||
307 | if ((wait_reg_mem_info & 0x7) != 0x3) { | ||
308 | DRM_ERROR("vline WAIT_REG_MEM function not equal\n"); | ||
309 | r = -EINVAL; | ||
310 | return r; | ||
311 | } | ||
312 | if ((radeon_get_ib_value(p, wait_reg_mem.idx + 2) << 2) != EVERGREEN_VLINE_STATUS) { | ||
313 | DRM_ERROR("vline WAIT_REG_MEM bad reg\n"); | ||
314 | r = -EINVAL; | ||
315 | return r; | ||
316 | } | ||
317 | |||
318 | if (radeon_get_ib_value(p, wait_reg_mem.idx + 5) != EVERGREEN_VLINE_STAT) { | ||
319 | DRM_ERROR("vline WAIT_REG_MEM bad bit mask\n"); | ||
320 | r = -EINVAL; | ||
321 | return r; | ||
322 | } | ||
323 | |||
324 | /* jump over the NOP */ | ||
325 | r = evergreen_cs_packet_parse(p, &p3reloc, p->idx + wait_reg_mem.count + 2); | ||
326 | if (r) | ||
327 | return r; | ||
328 | |||
329 | h_idx = p->idx - 2; | ||
330 | p->idx += wait_reg_mem.count + 2; | ||
331 | p->idx += p3reloc.count + 2; | ||
332 | |||
333 | header = radeon_get_ib_value(p, h_idx); | ||
334 | crtc_id = radeon_get_ib_value(p, h_idx + 2 + 7 + 1); | ||
335 | reg = CP_PACKET0_GET_REG(header); | ||
336 | mutex_lock(&p->rdev->ddev->mode_config.mutex); | ||
337 | obj = drm_mode_object_find(p->rdev->ddev, crtc_id, DRM_MODE_OBJECT_CRTC); | ||
338 | if (!obj) { | ||
339 | DRM_ERROR("cannot find crtc %d\n", crtc_id); | ||
340 | r = -EINVAL; | ||
341 | goto out; | ||
342 | } | ||
343 | crtc = obj_to_crtc(obj); | ||
344 | radeon_crtc = to_radeon_crtc(crtc); | ||
345 | crtc_id = radeon_crtc->crtc_id; | ||
346 | |||
347 | if (!crtc->enabled) { | ||
348 | /* if the CRTC isn't enabled - we need to nop out the WAIT_REG_MEM */ | ||
349 | ib[h_idx + 2] = PACKET2(0); | ||
350 | ib[h_idx + 3] = PACKET2(0); | ||
351 | ib[h_idx + 4] = PACKET2(0); | ||
352 | ib[h_idx + 5] = PACKET2(0); | ||
353 | ib[h_idx + 6] = PACKET2(0); | ||
354 | ib[h_idx + 7] = PACKET2(0); | ||
355 | ib[h_idx + 8] = PACKET2(0); | ||
356 | } else { | ||
357 | switch (reg) { | ||
358 | case EVERGREEN_VLINE_START_END: | ||
359 | header &= ~R600_CP_PACKET0_REG_MASK; | ||
360 | header |= (EVERGREEN_VLINE_START_END + radeon_crtc->crtc_offset) >> 2; | ||
361 | ib[h_idx] = header; | ||
362 | ib[h_idx + 4] = (EVERGREEN_VLINE_STATUS + radeon_crtc->crtc_offset) >> 2; | ||
363 | break; | ||
364 | default: | ||
365 | DRM_ERROR("unknown crtc reloc\n"); | ||
366 | r = -EINVAL; | ||
367 | goto out; | ||
368 | } | ||
369 | } | ||
370 | out: | ||
371 | mutex_unlock(&p->rdev->ddev->mode_config.mutex); | ||
372 | return r; | ||
373 | } | ||
374 | |||
375 | static int evergreen_packet0_check(struct radeon_cs_parser *p, | ||
376 | struct radeon_cs_packet *pkt, | ||
377 | unsigned idx, unsigned reg) | ||
378 | { | ||
379 | int r; | ||
380 | |||
381 | switch (reg) { | ||
382 | case EVERGREEN_VLINE_START_END: | ||
383 | r = evergreen_cs_packet_parse_vline(p); | ||
384 | if (r) { | ||
385 | DRM_ERROR("No reloc for ib[%d]=0x%04X\n", | ||
386 | idx, reg); | ||
387 | return r; | ||
388 | } | ||
389 | break; | ||
390 | default: | ||
391 | printk(KERN_ERR "Forbidden register 0x%04X in cs at %d\n", | ||
392 | reg, idx); | ||
393 | return -EINVAL; | ||
394 | } | ||
395 | return 0; | ||
396 | } | ||
397 | |||
398 | static int evergreen_cs_parse_packet0(struct radeon_cs_parser *p, | ||
399 | struct radeon_cs_packet *pkt) | ||
400 | { | ||
401 | unsigned reg, i; | ||
402 | unsigned idx; | ||
403 | int r; | ||
404 | |||
405 | idx = pkt->idx + 1; | ||
406 | reg = pkt->reg; | ||
407 | for (i = 0; i <= pkt->count; i++, idx++, reg += 4) { | ||
408 | r = evergreen_packet0_check(p, pkt, idx, reg); | ||
409 | if (r) { | ||
410 | return r; | ||
411 | } | ||
412 | } | ||
413 | return 0; | ||
414 | } | ||
415 | |||
416 | /** | ||
417 | * evergreen_cs_check_reg() - check if register is authorized or not | ||
418 | * @parser: parser structure holding parsing context | ||
419 | * @reg: register we are testing | ||
420 | * @idx: index into the cs buffer | ||
421 | * | ||
422 | * This function will test against evergreen_reg_safe_bm and return 0 | ||
423 | * if register is safe. If register is not flag as safe this function | ||
424 | * will test it against a list of register needind special handling. | ||
425 | */ | ||
426 | static inline int evergreen_cs_check_reg(struct radeon_cs_parser *p, u32 reg, u32 idx) | ||
427 | { | ||
428 | struct evergreen_cs_track *track = (struct evergreen_cs_track *)p->track; | ||
429 | struct radeon_cs_reloc *reloc; | ||
430 | u32 last_reg = ARRAY_SIZE(evergreen_reg_safe_bm); | ||
431 | u32 m, i, tmp, *ib; | ||
432 | int r; | ||
433 | |||
434 | i = (reg >> 7); | ||
435 | if (i > last_reg) { | ||
436 | dev_warn(p->dev, "forbidden register 0x%08x at %d\n", reg, idx); | ||
437 | return -EINVAL; | ||
438 | } | ||
439 | m = 1 << ((reg >> 2) & 31); | ||
440 | if (!(evergreen_reg_safe_bm[i] & m)) | ||
441 | return 0; | ||
442 | ib = p->ib->ptr; | ||
443 | switch (reg) { | ||
444 | /* force following reg to 0 in an attemp to disable out buffer | ||
445 | * which will need us to better understand how it works to perform | ||
446 | * security check on it (Jerome) | ||
447 | */ | ||
448 | case SQ_ESGS_RING_SIZE: | ||
449 | case SQ_GSVS_RING_SIZE: | ||
450 | case SQ_ESTMP_RING_SIZE: | ||
451 | case SQ_GSTMP_RING_SIZE: | ||
452 | case SQ_HSTMP_RING_SIZE: | ||
453 | case SQ_LSTMP_RING_SIZE: | ||
454 | case SQ_PSTMP_RING_SIZE: | ||
455 | case SQ_VSTMP_RING_SIZE: | ||
456 | case SQ_ESGS_RING_ITEMSIZE: | ||
457 | case SQ_ESTMP_RING_ITEMSIZE: | ||
458 | case SQ_GSTMP_RING_ITEMSIZE: | ||
459 | case SQ_GSVS_RING_ITEMSIZE: | ||
460 | case SQ_GS_VERT_ITEMSIZE: | ||
461 | case SQ_GS_VERT_ITEMSIZE_1: | ||
462 | case SQ_GS_VERT_ITEMSIZE_2: | ||
463 | case SQ_GS_VERT_ITEMSIZE_3: | ||
464 | case SQ_GSVS_RING_OFFSET_1: | ||
465 | case SQ_GSVS_RING_OFFSET_2: | ||
466 | case SQ_GSVS_RING_OFFSET_3: | ||
467 | case SQ_HSTMP_RING_ITEMSIZE: | ||
468 | case SQ_LSTMP_RING_ITEMSIZE: | ||
469 | case SQ_PSTMP_RING_ITEMSIZE: | ||
470 | case SQ_VSTMP_RING_ITEMSIZE: | ||
471 | case VGT_TF_RING_SIZE: | ||
472 | /* get value to populate the IB don't remove */ | ||
473 | tmp =radeon_get_ib_value(p, idx); | ||
474 | ib[idx] = 0; | ||
475 | break; | ||
476 | case DB_DEPTH_CONTROL: | ||
477 | track->db_depth_control = radeon_get_ib_value(p, idx); | ||
478 | break; | ||
479 | case DB_Z_INFO: | ||
480 | r = evergreen_cs_packet_next_reloc(p, &reloc); | ||
481 | if (r) { | ||
482 | dev_warn(p->dev, "bad SET_CONTEXT_REG " | ||
483 | "0x%04X\n", reg); | ||
484 | return -EINVAL; | ||
485 | } | ||
486 | track->db_z_info = radeon_get_ib_value(p, idx); | ||
487 | ib[idx] &= ~Z_ARRAY_MODE(0xf); | ||
488 | track->db_z_info &= ~Z_ARRAY_MODE(0xf); | ||
489 | if (reloc->lobj.tiling_flags & RADEON_TILING_MACRO) { | ||
490 | ib[idx] |= Z_ARRAY_MODE(ARRAY_2D_TILED_THIN1); | ||
491 | track->db_z_info |= Z_ARRAY_MODE(ARRAY_2D_TILED_THIN1); | ||
492 | } else { | ||
493 | ib[idx] |= Z_ARRAY_MODE(ARRAY_1D_TILED_THIN1); | ||
494 | track->db_z_info |= Z_ARRAY_MODE(ARRAY_1D_TILED_THIN1); | ||
495 | } | ||
496 | break; | ||
497 | case DB_STENCIL_INFO: | ||
498 | track->db_s_info = radeon_get_ib_value(p, idx); | ||
499 | break; | ||
500 | case DB_DEPTH_VIEW: | ||
501 | track->db_depth_view = radeon_get_ib_value(p, idx); | ||
502 | break; | ||
503 | case DB_DEPTH_SIZE: | ||
504 | track->db_depth_size = radeon_get_ib_value(p, idx); | ||
505 | track->db_depth_size_idx = idx; | ||
506 | break; | ||
507 | case DB_Z_READ_BASE: | ||
508 | r = evergreen_cs_packet_next_reloc(p, &reloc); | ||
509 | if (r) { | ||
510 | dev_warn(p->dev, "bad SET_CONTEXT_REG " | ||
511 | "0x%04X\n", reg); | ||
512 | return -EINVAL; | ||
513 | } | ||
514 | track->db_z_read_offset = radeon_get_ib_value(p, idx); | ||
515 | ib[idx] += (u32)((reloc->lobj.gpu_offset >> 8) & 0xffffffff); | ||
516 | track->db_z_read_bo = reloc->robj; | ||
517 | break; | ||
518 | case DB_Z_WRITE_BASE: | ||
519 | r = evergreen_cs_packet_next_reloc(p, &reloc); | ||
520 | if (r) { | ||
521 | dev_warn(p->dev, "bad SET_CONTEXT_REG " | ||
522 | "0x%04X\n", reg); | ||
523 | return -EINVAL; | ||
524 | } | ||
525 | track->db_z_write_offset = radeon_get_ib_value(p, idx); | ||
526 | ib[idx] += (u32)((reloc->lobj.gpu_offset >> 8) & 0xffffffff); | ||
527 | track->db_z_write_bo = reloc->robj; | ||
528 | break; | ||
529 | case DB_STENCIL_READ_BASE: | ||
530 | r = evergreen_cs_packet_next_reloc(p, &reloc); | ||
531 | if (r) { | ||
532 | dev_warn(p->dev, "bad SET_CONTEXT_REG " | ||
533 | "0x%04X\n", reg); | ||
534 | return -EINVAL; | ||
535 | } | ||
536 | track->db_s_read_offset = radeon_get_ib_value(p, idx); | ||
537 | ib[idx] += (u32)((reloc->lobj.gpu_offset >> 8) & 0xffffffff); | ||
538 | track->db_s_read_bo = reloc->robj; | ||
539 | break; | ||
540 | case DB_STENCIL_WRITE_BASE: | ||
541 | r = evergreen_cs_packet_next_reloc(p, &reloc); | ||
542 | if (r) { | ||
543 | dev_warn(p->dev, "bad SET_CONTEXT_REG " | ||
544 | "0x%04X\n", reg); | ||
545 | return -EINVAL; | ||
546 | } | ||
547 | track->db_s_write_offset = radeon_get_ib_value(p, idx); | ||
548 | ib[idx] += (u32)((reloc->lobj.gpu_offset >> 8) & 0xffffffff); | ||
549 | track->db_s_write_bo = reloc->robj; | ||
550 | break; | ||
551 | case VGT_STRMOUT_CONFIG: | ||
552 | track->vgt_strmout_config = radeon_get_ib_value(p, idx); | ||
553 | break; | ||
554 | case VGT_STRMOUT_BUFFER_CONFIG: | ||
555 | track->vgt_strmout_buffer_config = radeon_get_ib_value(p, idx); | ||
556 | break; | ||
557 | case CB_TARGET_MASK: | ||
558 | track->cb_target_mask = radeon_get_ib_value(p, idx); | ||
559 | break; | ||
560 | case CB_SHADER_MASK: | ||
561 | track->cb_shader_mask = radeon_get_ib_value(p, idx); | ||
562 | break; | ||
563 | case PA_SC_AA_CONFIG: | ||
564 | tmp = radeon_get_ib_value(p, idx) & MSAA_NUM_SAMPLES_MASK; | ||
565 | track->nsamples = 1 << tmp; | ||
566 | break; | ||
567 | case CB_COLOR0_VIEW: | ||
568 | case CB_COLOR1_VIEW: | ||
569 | case CB_COLOR2_VIEW: | ||
570 | case CB_COLOR3_VIEW: | ||
571 | case CB_COLOR4_VIEW: | ||
572 | case CB_COLOR5_VIEW: | ||
573 | case CB_COLOR6_VIEW: | ||
574 | case CB_COLOR7_VIEW: | ||
575 | tmp = (reg - CB_COLOR0_VIEW) / 0x3c; | ||
576 | track->cb_color_view[tmp] = radeon_get_ib_value(p, idx); | ||
577 | break; | ||
578 | case CB_COLOR8_VIEW: | ||
579 | case CB_COLOR9_VIEW: | ||
580 | case CB_COLOR10_VIEW: | ||
581 | case CB_COLOR11_VIEW: | ||
582 | tmp = ((reg - CB_COLOR8_VIEW) / 0x1c) + 8; | ||
583 | track->cb_color_view[tmp] = radeon_get_ib_value(p, idx); | ||
584 | break; | ||
585 | case CB_COLOR0_INFO: | ||
586 | case CB_COLOR1_INFO: | ||
587 | case CB_COLOR2_INFO: | ||
588 | case CB_COLOR3_INFO: | ||
589 | case CB_COLOR4_INFO: | ||
590 | case CB_COLOR5_INFO: | ||
591 | case CB_COLOR6_INFO: | ||
592 | case CB_COLOR7_INFO: | ||
593 | r = evergreen_cs_packet_next_reloc(p, &reloc); | ||
594 | if (r) { | ||
595 | dev_warn(p->dev, "bad SET_CONTEXT_REG " | ||
596 | "0x%04X\n", reg); | ||
597 | return -EINVAL; | ||
598 | } | ||
599 | tmp = (reg - CB_COLOR0_INFO) / 0x3c; | ||
600 | track->cb_color_info[tmp] = radeon_get_ib_value(p, idx); | ||
601 | if (reloc->lobj.tiling_flags & RADEON_TILING_MACRO) { | ||
602 | ib[idx] |= CB_ARRAY_MODE(ARRAY_2D_TILED_THIN1); | ||
603 | track->cb_color_info[tmp] |= CB_ARRAY_MODE(ARRAY_2D_TILED_THIN1); | ||
604 | } else if (reloc->lobj.tiling_flags & RADEON_TILING_MICRO) { | ||
605 | ib[idx] |= CB_ARRAY_MODE(ARRAY_1D_TILED_THIN1); | ||
606 | track->cb_color_info[tmp] |= CB_ARRAY_MODE(ARRAY_1D_TILED_THIN1); | ||
607 | } | ||
608 | break; | ||
609 | case CB_COLOR8_INFO: | ||
610 | case CB_COLOR9_INFO: | ||
611 | case CB_COLOR10_INFO: | ||
612 | case CB_COLOR11_INFO: | ||
613 | r = evergreen_cs_packet_next_reloc(p, &reloc); | ||
614 | if (r) { | ||
615 | dev_warn(p->dev, "bad SET_CONTEXT_REG " | ||
616 | "0x%04X\n", reg); | ||
617 | return -EINVAL; | ||
618 | } | ||
619 | tmp = ((reg - CB_COLOR8_INFO) / 0x1c) + 8; | ||
620 | track->cb_color_info[tmp] = radeon_get_ib_value(p, idx); | ||
621 | if (reloc->lobj.tiling_flags & RADEON_TILING_MACRO) { | ||
622 | ib[idx] |= CB_ARRAY_MODE(ARRAY_2D_TILED_THIN1); | ||
623 | track->cb_color_info[tmp] |= CB_ARRAY_MODE(ARRAY_2D_TILED_THIN1); | ||
624 | } else if (reloc->lobj.tiling_flags & RADEON_TILING_MICRO) { | ||
625 | ib[idx] |= CB_ARRAY_MODE(ARRAY_1D_TILED_THIN1); | ||
626 | track->cb_color_info[tmp] |= CB_ARRAY_MODE(ARRAY_1D_TILED_THIN1); | ||
627 | } | ||
628 | break; | ||
629 | case CB_COLOR0_PITCH: | ||
630 | case CB_COLOR1_PITCH: | ||
631 | case CB_COLOR2_PITCH: | ||
632 | case CB_COLOR3_PITCH: | ||
633 | case CB_COLOR4_PITCH: | ||
634 | case CB_COLOR5_PITCH: | ||
635 | case CB_COLOR6_PITCH: | ||
636 | case CB_COLOR7_PITCH: | ||
637 | tmp = (reg - CB_COLOR0_PITCH) / 0x3c; | ||
638 | track->cb_color_pitch[tmp] = radeon_get_ib_value(p, idx); | ||
639 | track->cb_color_pitch_idx[tmp] = idx; | ||
640 | break; | ||
641 | case CB_COLOR8_PITCH: | ||
642 | case CB_COLOR9_PITCH: | ||
643 | case CB_COLOR10_PITCH: | ||
644 | case CB_COLOR11_PITCH: | ||
645 | tmp = ((reg - CB_COLOR8_PITCH) / 0x1c) + 8; | ||
646 | track->cb_color_pitch[tmp] = radeon_get_ib_value(p, idx); | ||
647 | track->cb_color_pitch_idx[tmp] = idx; | ||
648 | break; | ||
649 | case CB_COLOR0_SLICE: | ||
650 | case CB_COLOR1_SLICE: | ||
651 | case CB_COLOR2_SLICE: | ||
652 | case CB_COLOR3_SLICE: | ||
653 | case CB_COLOR4_SLICE: | ||
654 | case CB_COLOR5_SLICE: | ||
655 | case CB_COLOR6_SLICE: | ||
656 | case CB_COLOR7_SLICE: | ||
657 | tmp = (reg - CB_COLOR0_SLICE) / 0x3c; | ||
658 | track->cb_color_slice[tmp] = radeon_get_ib_value(p, idx); | ||
659 | track->cb_color_slice_idx[tmp] = idx; | ||
660 | break; | ||
661 | case CB_COLOR8_SLICE: | ||
662 | case CB_COLOR9_SLICE: | ||
663 | case CB_COLOR10_SLICE: | ||
664 | case CB_COLOR11_SLICE: | ||
665 | tmp = ((reg - CB_COLOR8_SLICE) / 0x1c) + 8; | ||
666 | track->cb_color_slice[tmp] = radeon_get_ib_value(p, idx); | ||
667 | track->cb_color_slice_idx[tmp] = idx; | ||
668 | break; | ||
669 | case CB_COLOR0_ATTRIB: | ||
670 | case CB_COLOR1_ATTRIB: | ||
671 | case CB_COLOR2_ATTRIB: | ||
672 | case CB_COLOR3_ATTRIB: | ||
673 | case CB_COLOR4_ATTRIB: | ||
674 | case CB_COLOR5_ATTRIB: | ||
675 | case CB_COLOR6_ATTRIB: | ||
676 | case CB_COLOR7_ATTRIB: | ||
677 | case CB_COLOR8_ATTRIB: | ||
678 | case CB_COLOR9_ATTRIB: | ||
679 | case CB_COLOR10_ATTRIB: | ||
680 | case CB_COLOR11_ATTRIB: | ||
681 | break; | ||
682 | case CB_COLOR0_DIM: | ||
683 | case CB_COLOR1_DIM: | ||
684 | case CB_COLOR2_DIM: | ||
685 | case CB_COLOR3_DIM: | ||
686 | case CB_COLOR4_DIM: | ||
687 | case CB_COLOR5_DIM: | ||
688 | case CB_COLOR6_DIM: | ||
689 | case CB_COLOR7_DIM: | ||
690 | tmp = (reg - CB_COLOR0_DIM) / 0x3c; | ||
691 | track->cb_color_dim[tmp] = radeon_get_ib_value(p, idx); | ||
692 | track->cb_color_dim_idx[tmp] = idx; | ||
693 | break; | ||
694 | case CB_COLOR8_DIM: | ||
695 | case CB_COLOR9_DIM: | ||
696 | case CB_COLOR10_DIM: | ||
697 | case CB_COLOR11_DIM: | ||
698 | tmp = ((reg - CB_COLOR8_DIM) / 0x1c) + 8; | ||
699 | track->cb_color_dim[tmp] = radeon_get_ib_value(p, idx); | ||
700 | track->cb_color_dim_idx[tmp] = idx; | ||
701 | break; | ||
702 | case CB_COLOR0_FMASK: | ||
703 | case CB_COLOR1_FMASK: | ||
704 | case CB_COLOR2_FMASK: | ||
705 | case CB_COLOR3_FMASK: | ||
706 | case CB_COLOR4_FMASK: | ||
707 | case CB_COLOR5_FMASK: | ||
708 | case CB_COLOR6_FMASK: | ||
709 | case CB_COLOR7_FMASK: | ||
710 | tmp = (reg - CB_COLOR0_FMASK) / 0x3c; | ||
711 | r = evergreen_cs_packet_next_reloc(p, &reloc); | ||
712 | if (r) { | ||
713 | dev_err(p->dev, "bad SET_CONTEXT_REG 0x%04X\n", reg); | ||
714 | return -EINVAL; | ||
715 | } | ||
716 | ib[idx] += (u32)((reloc->lobj.gpu_offset >> 8) & 0xffffffff); | ||
717 | track->cb_color_fmask_bo[tmp] = reloc->robj; | ||
718 | break; | ||
719 | case CB_COLOR0_CMASK: | ||
720 | case CB_COLOR1_CMASK: | ||
721 | case CB_COLOR2_CMASK: | ||
722 | case CB_COLOR3_CMASK: | ||
723 | case CB_COLOR4_CMASK: | ||
724 | case CB_COLOR5_CMASK: | ||
725 | case CB_COLOR6_CMASK: | ||
726 | case CB_COLOR7_CMASK: | ||
727 | tmp = (reg - CB_COLOR0_CMASK) / 0x3c; | ||
728 | r = evergreen_cs_packet_next_reloc(p, &reloc); | ||
729 | if (r) { | ||
730 | dev_err(p->dev, "bad SET_CONTEXT_REG 0x%04X\n", reg); | ||
731 | return -EINVAL; | ||
732 | } | ||
733 | ib[idx] += (u32)((reloc->lobj.gpu_offset >> 8) & 0xffffffff); | ||
734 | track->cb_color_cmask_bo[tmp] = reloc->robj; | ||
735 | break; | ||
736 | case CB_COLOR0_FMASK_SLICE: | ||
737 | case CB_COLOR1_FMASK_SLICE: | ||
738 | case CB_COLOR2_FMASK_SLICE: | ||
739 | case CB_COLOR3_FMASK_SLICE: | ||
740 | case CB_COLOR4_FMASK_SLICE: | ||
741 | case CB_COLOR5_FMASK_SLICE: | ||
742 | case CB_COLOR6_FMASK_SLICE: | ||
743 | case CB_COLOR7_FMASK_SLICE: | ||
744 | tmp = (reg - CB_COLOR0_FMASK_SLICE) / 0x3c; | ||
745 | track->cb_color_fmask_slice[tmp] = radeon_get_ib_value(p, idx); | ||
746 | break; | ||
747 | case CB_COLOR0_CMASK_SLICE: | ||
748 | case CB_COLOR1_CMASK_SLICE: | ||
749 | case CB_COLOR2_CMASK_SLICE: | ||
750 | case CB_COLOR3_CMASK_SLICE: | ||
751 | case CB_COLOR4_CMASK_SLICE: | ||
752 | case CB_COLOR5_CMASK_SLICE: | ||
753 | case CB_COLOR6_CMASK_SLICE: | ||
754 | case CB_COLOR7_CMASK_SLICE: | ||
755 | tmp = (reg - CB_COLOR0_CMASK_SLICE) / 0x3c; | ||
756 | track->cb_color_cmask_slice[tmp] = radeon_get_ib_value(p, idx); | ||
757 | break; | ||
758 | case CB_COLOR0_BASE: | ||
759 | case CB_COLOR1_BASE: | ||
760 | case CB_COLOR2_BASE: | ||
761 | case CB_COLOR3_BASE: | ||
762 | case CB_COLOR4_BASE: | ||
763 | case CB_COLOR5_BASE: | ||
764 | case CB_COLOR6_BASE: | ||
765 | case CB_COLOR7_BASE: | ||
766 | r = evergreen_cs_packet_next_reloc(p, &reloc); | ||
767 | if (r) { | ||
768 | dev_warn(p->dev, "bad SET_CONTEXT_REG " | ||
769 | "0x%04X\n", reg); | ||
770 | return -EINVAL; | ||
771 | } | ||
772 | tmp = (reg - CB_COLOR0_BASE) / 0x3c; | ||
773 | track->cb_color_bo_offset[tmp] = radeon_get_ib_value(p, idx); | ||
774 | ib[idx] += (u32)((reloc->lobj.gpu_offset >> 8) & 0xffffffff); | ||
775 | track->cb_color_base_last[tmp] = ib[idx]; | ||
776 | track->cb_color_bo[tmp] = reloc->robj; | ||
777 | break; | ||
778 | case CB_COLOR8_BASE: | ||
779 | case CB_COLOR9_BASE: | ||
780 | case CB_COLOR10_BASE: | ||
781 | case CB_COLOR11_BASE: | ||
782 | r = evergreen_cs_packet_next_reloc(p, &reloc); | ||
783 | if (r) { | ||
784 | dev_warn(p->dev, "bad SET_CONTEXT_REG " | ||
785 | "0x%04X\n", reg); | ||
786 | return -EINVAL; | ||
787 | } | ||
788 | tmp = ((reg - CB_COLOR8_BASE) / 0x1c) + 8; | ||
789 | track->cb_color_bo_offset[tmp] = radeon_get_ib_value(p, idx); | ||
790 | ib[idx] += (u32)((reloc->lobj.gpu_offset >> 8) & 0xffffffff); | ||
791 | track->cb_color_base_last[tmp] = ib[idx]; | ||
792 | track->cb_color_bo[tmp] = reloc->robj; | ||
793 | break; | ||
794 | case CB_IMMED0_BASE: | ||
795 | case CB_IMMED1_BASE: | ||
796 | case CB_IMMED2_BASE: | ||
797 | case CB_IMMED3_BASE: | ||
798 | case CB_IMMED4_BASE: | ||
799 | case CB_IMMED5_BASE: | ||
800 | case CB_IMMED6_BASE: | ||
801 | case CB_IMMED7_BASE: | ||
802 | case CB_IMMED8_BASE: | ||
803 | case CB_IMMED9_BASE: | ||
804 | case CB_IMMED10_BASE: | ||
805 | case CB_IMMED11_BASE: | ||
806 | case DB_HTILE_DATA_BASE: | ||
807 | case SQ_PGM_START_FS: | ||
808 | case SQ_PGM_START_ES: | ||
809 | case SQ_PGM_START_VS: | ||
810 | case SQ_PGM_START_GS: | ||
811 | case SQ_PGM_START_PS: | ||
812 | case SQ_PGM_START_HS: | ||
813 | case SQ_PGM_START_LS: | ||
814 | case GDS_ADDR_BASE: | ||
815 | case SQ_CONST_MEM_BASE: | ||
816 | case SQ_ALU_CONST_CACHE_GS_0: | ||
817 | case SQ_ALU_CONST_CACHE_GS_1: | ||
818 | case SQ_ALU_CONST_CACHE_GS_2: | ||
819 | case SQ_ALU_CONST_CACHE_GS_3: | ||
820 | case SQ_ALU_CONST_CACHE_GS_4: | ||
821 | case SQ_ALU_CONST_CACHE_GS_5: | ||
822 | case SQ_ALU_CONST_CACHE_GS_6: | ||
823 | case SQ_ALU_CONST_CACHE_GS_7: | ||
824 | case SQ_ALU_CONST_CACHE_GS_8: | ||
825 | case SQ_ALU_CONST_CACHE_GS_9: | ||
826 | case SQ_ALU_CONST_CACHE_GS_10: | ||
827 | case SQ_ALU_CONST_CACHE_GS_11: | ||
828 | case SQ_ALU_CONST_CACHE_GS_12: | ||
829 | case SQ_ALU_CONST_CACHE_GS_13: | ||
830 | case SQ_ALU_CONST_CACHE_GS_14: | ||
831 | case SQ_ALU_CONST_CACHE_GS_15: | ||
832 | case SQ_ALU_CONST_CACHE_PS_0: | ||
833 | case SQ_ALU_CONST_CACHE_PS_1: | ||
834 | case SQ_ALU_CONST_CACHE_PS_2: | ||
835 | case SQ_ALU_CONST_CACHE_PS_3: | ||
836 | case SQ_ALU_CONST_CACHE_PS_4: | ||
837 | case SQ_ALU_CONST_CACHE_PS_5: | ||
838 | case SQ_ALU_CONST_CACHE_PS_6: | ||
839 | case SQ_ALU_CONST_CACHE_PS_7: | ||
840 | case SQ_ALU_CONST_CACHE_PS_8: | ||
841 | case SQ_ALU_CONST_CACHE_PS_9: | ||
842 | case SQ_ALU_CONST_CACHE_PS_10: | ||
843 | case SQ_ALU_CONST_CACHE_PS_11: | ||
844 | case SQ_ALU_CONST_CACHE_PS_12: | ||
845 | case SQ_ALU_CONST_CACHE_PS_13: | ||
846 | case SQ_ALU_CONST_CACHE_PS_14: | ||
847 | case SQ_ALU_CONST_CACHE_PS_15: | ||
848 | case SQ_ALU_CONST_CACHE_VS_0: | ||
849 | case SQ_ALU_CONST_CACHE_VS_1: | ||
850 | case SQ_ALU_CONST_CACHE_VS_2: | ||
851 | case SQ_ALU_CONST_CACHE_VS_3: | ||
852 | case SQ_ALU_CONST_CACHE_VS_4: | ||
853 | case SQ_ALU_CONST_CACHE_VS_5: | ||
854 | case SQ_ALU_CONST_CACHE_VS_6: | ||
855 | case SQ_ALU_CONST_CACHE_VS_7: | ||
856 | case SQ_ALU_CONST_CACHE_VS_8: | ||
857 | case SQ_ALU_CONST_CACHE_VS_9: | ||
858 | case SQ_ALU_CONST_CACHE_VS_10: | ||
859 | case SQ_ALU_CONST_CACHE_VS_11: | ||
860 | case SQ_ALU_CONST_CACHE_VS_12: | ||
861 | case SQ_ALU_CONST_CACHE_VS_13: | ||
862 | case SQ_ALU_CONST_CACHE_VS_14: | ||
863 | case SQ_ALU_CONST_CACHE_VS_15: | ||
864 | case SQ_ALU_CONST_CACHE_HS_0: | ||
865 | case SQ_ALU_CONST_CACHE_HS_1: | ||
866 | case SQ_ALU_CONST_CACHE_HS_2: | ||
867 | case SQ_ALU_CONST_CACHE_HS_3: | ||
868 | case SQ_ALU_CONST_CACHE_HS_4: | ||
869 | case SQ_ALU_CONST_CACHE_HS_5: | ||
870 | case SQ_ALU_CONST_CACHE_HS_6: | ||
871 | case SQ_ALU_CONST_CACHE_HS_7: | ||
872 | case SQ_ALU_CONST_CACHE_HS_8: | ||
873 | case SQ_ALU_CONST_CACHE_HS_9: | ||
874 | case SQ_ALU_CONST_CACHE_HS_10: | ||
875 | case SQ_ALU_CONST_CACHE_HS_11: | ||
876 | case SQ_ALU_CONST_CACHE_HS_12: | ||
877 | case SQ_ALU_CONST_CACHE_HS_13: | ||
878 | case SQ_ALU_CONST_CACHE_HS_14: | ||
879 | case SQ_ALU_CONST_CACHE_HS_15: | ||
880 | case SQ_ALU_CONST_CACHE_LS_0: | ||
881 | case SQ_ALU_CONST_CACHE_LS_1: | ||
882 | case SQ_ALU_CONST_CACHE_LS_2: | ||
883 | case SQ_ALU_CONST_CACHE_LS_3: | ||
884 | case SQ_ALU_CONST_CACHE_LS_4: | ||
885 | case SQ_ALU_CONST_CACHE_LS_5: | ||
886 | case SQ_ALU_CONST_CACHE_LS_6: | ||
887 | case SQ_ALU_CONST_CACHE_LS_7: | ||
888 | case SQ_ALU_CONST_CACHE_LS_8: | ||
889 | case SQ_ALU_CONST_CACHE_LS_9: | ||
890 | case SQ_ALU_CONST_CACHE_LS_10: | ||
891 | case SQ_ALU_CONST_CACHE_LS_11: | ||
892 | case SQ_ALU_CONST_CACHE_LS_12: | ||
893 | case SQ_ALU_CONST_CACHE_LS_13: | ||
894 | case SQ_ALU_CONST_CACHE_LS_14: | ||
895 | case SQ_ALU_CONST_CACHE_LS_15: | ||
896 | r = evergreen_cs_packet_next_reloc(p, &reloc); | ||
897 | if (r) { | ||
898 | dev_warn(p->dev, "bad SET_CONTEXT_REG " | ||
899 | "0x%04X\n", reg); | ||
900 | return -EINVAL; | ||
901 | } | ||
902 | ib[idx] += (u32)((reloc->lobj.gpu_offset >> 8) & 0xffffffff); | ||
903 | break; | ||
904 | default: | ||
905 | dev_warn(p->dev, "forbidden register 0x%08x at %d\n", reg, idx); | ||
906 | return -EINVAL; | ||
907 | } | ||
908 | return 0; | ||
909 | } | ||
910 | |||
911 | /** | ||
912 | * evergreen_check_texture_resource() - check if register is authorized or not | ||
913 | * @p: parser structure holding parsing context | ||
914 | * @idx: index into the cs buffer | ||
915 | * @texture: texture's bo structure | ||
916 | * @mipmap: mipmap's bo structure | ||
917 | * | ||
918 | * This function will check that the resource has valid field and that | ||
919 | * the texture and mipmap bo object are big enough to cover this resource. | ||
920 | */ | ||
921 | static inline int evergreen_check_texture_resource(struct radeon_cs_parser *p, u32 idx, | ||
922 | struct radeon_bo *texture, | ||
923 | struct radeon_bo *mipmap) | ||
924 | { | ||
925 | /* XXX fill in */ | ||
926 | return 0; | ||
927 | } | ||
928 | |||
929 | static int evergreen_packet3_check(struct radeon_cs_parser *p, | ||
930 | struct radeon_cs_packet *pkt) | ||
931 | { | ||
932 | struct radeon_cs_reloc *reloc; | ||
933 | struct evergreen_cs_track *track; | ||
934 | volatile u32 *ib; | ||
935 | unsigned idx; | ||
936 | unsigned i; | ||
937 | unsigned start_reg, end_reg, reg; | ||
938 | int r; | ||
939 | u32 idx_value; | ||
940 | |||
941 | track = (struct evergreen_cs_track *)p->track; | ||
942 | ib = p->ib->ptr; | ||
943 | idx = pkt->idx + 1; | ||
944 | idx_value = radeon_get_ib_value(p, idx); | ||
945 | |||
946 | switch (pkt->opcode) { | ||
947 | case PACKET3_CONTEXT_CONTROL: | ||
948 | if (pkt->count != 1) { | ||
949 | DRM_ERROR("bad CONTEXT_CONTROL\n"); | ||
950 | return -EINVAL; | ||
951 | } | ||
952 | break; | ||
953 | case PACKET3_INDEX_TYPE: | ||
954 | case PACKET3_NUM_INSTANCES: | ||
955 | case PACKET3_CLEAR_STATE: | ||
956 | if (pkt->count) { | ||
957 | DRM_ERROR("bad INDEX_TYPE/NUM_INSTANCES/CLEAR_STATE\n"); | ||
958 | return -EINVAL; | ||
959 | } | ||
960 | break; | ||
961 | case PACKET3_INDEX_BASE: | ||
962 | if (pkt->count != 1) { | ||
963 | DRM_ERROR("bad INDEX_BASE\n"); | ||
964 | return -EINVAL; | ||
965 | } | ||
966 | r = evergreen_cs_packet_next_reloc(p, &reloc); | ||
967 | if (r) { | ||
968 | DRM_ERROR("bad INDEX_BASE\n"); | ||
969 | return -EINVAL; | ||
970 | } | ||
971 | ib[idx+0] = idx_value + (u32)(reloc->lobj.gpu_offset & 0xffffffff); | ||
972 | ib[idx+1] += upper_32_bits(reloc->lobj.gpu_offset) & 0xff; | ||
973 | r = evergreen_cs_track_check(p); | ||
974 | if (r) { | ||
975 | dev_warn(p->dev, "%s:%d invalid cmd stream\n", __func__, __LINE__); | ||
976 | return r; | ||
977 | } | ||
978 | break; | ||
979 | case PACKET3_DRAW_INDEX: | ||
980 | if (pkt->count != 3) { | ||
981 | DRM_ERROR("bad DRAW_INDEX\n"); | ||
982 | return -EINVAL; | ||
983 | } | ||
984 | r = evergreen_cs_packet_next_reloc(p, &reloc); | ||
985 | if (r) { | ||
986 | DRM_ERROR("bad DRAW_INDEX\n"); | ||
987 | return -EINVAL; | ||
988 | } | ||
989 | ib[idx+0] = idx_value + (u32)(reloc->lobj.gpu_offset & 0xffffffff); | ||
990 | ib[idx+1] += upper_32_bits(reloc->lobj.gpu_offset) & 0xff; | ||
991 | r = evergreen_cs_track_check(p); | ||
992 | if (r) { | ||
993 | dev_warn(p->dev, "%s:%d invalid cmd stream\n", __func__, __LINE__); | ||
994 | return r; | ||
995 | } | ||
996 | break; | ||
997 | case PACKET3_DRAW_INDEX_2: | ||
998 | if (pkt->count != 4) { | ||
999 | DRM_ERROR("bad DRAW_INDEX_2\n"); | ||
1000 | return -EINVAL; | ||
1001 | } | ||
1002 | r = evergreen_cs_packet_next_reloc(p, &reloc); | ||
1003 | if (r) { | ||
1004 | DRM_ERROR("bad DRAW_INDEX_2\n"); | ||
1005 | return -EINVAL; | ||
1006 | } | ||
1007 | ib[idx+1] = idx_value + (u32)(reloc->lobj.gpu_offset & 0xffffffff); | ||
1008 | ib[idx+2] += upper_32_bits(reloc->lobj.gpu_offset) & 0xff; | ||
1009 | r = evergreen_cs_track_check(p); | ||
1010 | if (r) { | ||
1011 | dev_warn(p->dev, "%s:%d invalid cmd stream\n", __func__, __LINE__); | ||
1012 | return r; | ||
1013 | } | ||
1014 | break; | ||
1015 | case PACKET3_DRAW_INDEX_AUTO: | ||
1016 | if (pkt->count != 1) { | ||
1017 | DRM_ERROR("bad DRAW_INDEX_AUTO\n"); | ||
1018 | return -EINVAL; | ||
1019 | } | ||
1020 | r = evergreen_cs_track_check(p); | ||
1021 | if (r) { | ||
1022 | dev_warn(p->dev, "%s:%d invalid cmd stream %d\n", __func__, __LINE__, idx); | ||
1023 | return r; | ||
1024 | } | ||
1025 | break; | ||
1026 | case PACKET3_DRAW_INDEX_MULTI_AUTO: | ||
1027 | if (pkt->count != 2) { | ||
1028 | DRM_ERROR("bad DRAW_INDEX_MULTI_AUTO\n"); | ||
1029 | return -EINVAL; | ||
1030 | } | ||
1031 | r = evergreen_cs_track_check(p); | ||
1032 | if (r) { | ||
1033 | dev_warn(p->dev, "%s:%d invalid cmd stream %d\n", __func__, __LINE__, idx); | ||
1034 | return r; | ||
1035 | } | ||
1036 | break; | ||
1037 | case PACKET3_DRAW_INDEX_IMMD: | ||
1038 | if (pkt->count < 2) { | ||
1039 | DRM_ERROR("bad DRAW_INDEX_IMMD\n"); | ||
1040 | return -EINVAL; | ||
1041 | } | ||
1042 | r = evergreen_cs_track_check(p); | ||
1043 | if (r) { | ||
1044 | dev_warn(p->dev, "%s:%d invalid cmd stream\n", __func__, __LINE__); | ||
1045 | return r; | ||
1046 | } | ||
1047 | break; | ||
1048 | case PACKET3_DRAW_INDEX_OFFSET: | ||
1049 | if (pkt->count != 2) { | ||
1050 | DRM_ERROR("bad DRAW_INDEX_OFFSET\n"); | ||
1051 | return -EINVAL; | ||
1052 | } | ||
1053 | r = evergreen_cs_track_check(p); | ||
1054 | if (r) { | ||
1055 | dev_warn(p->dev, "%s:%d invalid cmd stream\n", __func__, __LINE__); | ||
1056 | return r; | ||
1057 | } | ||
1058 | break; | ||
1059 | case PACKET3_DRAW_INDEX_OFFSET_2: | ||
1060 | if (pkt->count != 3) { | ||
1061 | DRM_ERROR("bad DRAW_INDEX_OFFSET_2\n"); | ||
1062 | return -EINVAL; | ||
1063 | } | ||
1064 | r = evergreen_cs_track_check(p); | ||
1065 | if (r) { | ||
1066 | dev_warn(p->dev, "%s:%d invalid cmd stream\n", __func__, __LINE__); | ||
1067 | return r; | ||
1068 | } | ||
1069 | break; | ||
1070 | case PACKET3_WAIT_REG_MEM: | ||
1071 | if (pkt->count != 5) { | ||
1072 | DRM_ERROR("bad WAIT_REG_MEM\n"); | ||
1073 | return -EINVAL; | ||
1074 | } | ||
1075 | /* bit 4 is reg (0) or mem (1) */ | ||
1076 | if (idx_value & 0x10) { | ||
1077 | r = evergreen_cs_packet_next_reloc(p, &reloc); | ||
1078 | if (r) { | ||
1079 | DRM_ERROR("bad WAIT_REG_MEM\n"); | ||
1080 | return -EINVAL; | ||
1081 | } | ||
1082 | ib[idx+1] += (u32)(reloc->lobj.gpu_offset & 0xffffffff); | ||
1083 | ib[idx+2] += upper_32_bits(reloc->lobj.gpu_offset) & 0xff; | ||
1084 | } | ||
1085 | break; | ||
1086 | case PACKET3_SURFACE_SYNC: | ||
1087 | if (pkt->count != 3) { | ||
1088 | DRM_ERROR("bad SURFACE_SYNC\n"); | ||
1089 | return -EINVAL; | ||
1090 | } | ||
1091 | /* 0xffffffff/0x0 is flush all cache flag */ | ||
1092 | if (radeon_get_ib_value(p, idx + 1) != 0xffffffff || | ||
1093 | radeon_get_ib_value(p, idx + 2) != 0) { | ||
1094 | r = evergreen_cs_packet_next_reloc(p, &reloc); | ||
1095 | if (r) { | ||
1096 | DRM_ERROR("bad SURFACE_SYNC\n"); | ||
1097 | return -EINVAL; | ||
1098 | } | ||
1099 | ib[idx+2] += (u32)((reloc->lobj.gpu_offset >> 8) & 0xffffffff); | ||
1100 | } | ||
1101 | break; | ||
1102 | case PACKET3_EVENT_WRITE: | ||
1103 | if (pkt->count != 2 && pkt->count != 0) { | ||
1104 | DRM_ERROR("bad EVENT_WRITE\n"); | ||
1105 | return -EINVAL; | ||
1106 | } | ||
1107 | if (pkt->count) { | ||
1108 | r = evergreen_cs_packet_next_reloc(p, &reloc); | ||
1109 | if (r) { | ||
1110 | DRM_ERROR("bad EVENT_WRITE\n"); | ||
1111 | return -EINVAL; | ||
1112 | } | ||
1113 | ib[idx+1] += (u32)(reloc->lobj.gpu_offset & 0xffffffff); | ||
1114 | ib[idx+2] += upper_32_bits(reloc->lobj.gpu_offset) & 0xff; | ||
1115 | } | ||
1116 | break; | ||
1117 | case PACKET3_EVENT_WRITE_EOP: | ||
1118 | if (pkt->count != 4) { | ||
1119 | DRM_ERROR("bad EVENT_WRITE_EOP\n"); | ||
1120 | return -EINVAL; | ||
1121 | } | ||
1122 | r = evergreen_cs_packet_next_reloc(p, &reloc); | ||
1123 | if (r) { | ||
1124 | DRM_ERROR("bad EVENT_WRITE_EOP\n"); | ||
1125 | return -EINVAL; | ||
1126 | } | ||
1127 | ib[idx+1] += (u32)(reloc->lobj.gpu_offset & 0xffffffff); | ||
1128 | ib[idx+2] += upper_32_bits(reloc->lobj.gpu_offset) & 0xff; | ||
1129 | break; | ||
1130 | case PACKET3_EVENT_WRITE_EOS: | ||
1131 | if (pkt->count != 3) { | ||
1132 | DRM_ERROR("bad EVENT_WRITE_EOS\n"); | ||
1133 | return -EINVAL; | ||
1134 | } | ||
1135 | r = evergreen_cs_packet_next_reloc(p, &reloc); | ||
1136 | if (r) { | ||
1137 | DRM_ERROR("bad EVENT_WRITE_EOS\n"); | ||
1138 | return -EINVAL; | ||
1139 | } | ||
1140 | ib[idx+1] += (u32)(reloc->lobj.gpu_offset & 0xffffffff); | ||
1141 | ib[idx+2] += upper_32_bits(reloc->lobj.gpu_offset) & 0xff; | ||
1142 | break; | ||
1143 | case PACKET3_SET_CONFIG_REG: | ||
1144 | start_reg = (idx_value << 2) + PACKET3_SET_CONFIG_REG_START; | ||
1145 | end_reg = 4 * pkt->count + start_reg - 4; | ||
1146 | if ((start_reg < PACKET3_SET_CONFIG_REG_START) || | ||
1147 | (start_reg >= PACKET3_SET_CONFIG_REG_END) || | ||
1148 | (end_reg >= PACKET3_SET_CONFIG_REG_END)) { | ||
1149 | DRM_ERROR("bad PACKET3_SET_CONFIG_REG\n"); | ||
1150 | return -EINVAL; | ||
1151 | } | ||
1152 | for (i = 0; i < pkt->count; i++) { | ||
1153 | reg = start_reg + (4 * i); | ||
1154 | r = evergreen_cs_check_reg(p, reg, idx+1+i); | ||
1155 | if (r) | ||
1156 | return r; | ||
1157 | } | ||
1158 | break; | ||
1159 | case PACKET3_SET_CONTEXT_REG: | ||
1160 | start_reg = (idx_value << 2) + PACKET3_SET_CONTEXT_REG_START; | ||
1161 | end_reg = 4 * pkt->count + start_reg - 4; | ||
1162 | if ((start_reg < PACKET3_SET_CONTEXT_REG_START) || | ||
1163 | (start_reg >= PACKET3_SET_CONTEXT_REG_END) || | ||
1164 | (end_reg >= PACKET3_SET_CONTEXT_REG_END)) { | ||
1165 | DRM_ERROR("bad PACKET3_SET_CONTEXT_REG\n"); | ||
1166 | return -EINVAL; | ||
1167 | } | ||
1168 | for (i = 0; i < pkt->count; i++) { | ||
1169 | reg = start_reg + (4 * i); | ||
1170 | r = evergreen_cs_check_reg(p, reg, idx+1+i); | ||
1171 | if (r) | ||
1172 | return r; | ||
1173 | } | ||
1174 | break; | ||
1175 | case PACKET3_SET_RESOURCE: | ||
1176 | if (pkt->count % 8) { | ||
1177 | DRM_ERROR("bad SET_RESOURCE\n"); | ||
1178 | return -EINVAL; | ||
1179 | } | ||
1180 | start_reg = (idx_value << 2) + PACKET3_SET_RESOURCE_START; | ||
1181 | end_reg = 4 * pkt->count + start_reg - 4; | ||
1182 | if ((start_reg < PACKET3_SET_RESOURCE_START) || | ||
1183 | (start_reg >= PACKET3_SET_RESOURCE_END) || | ||
1184 | (end_reg >= PACKET3_SET_RESOURCE_END)) { | ||
1185 | DRM_ERROR("bad SET_RESOURCE\n"); | ||
1186 | return -EINVAL; | ||
1187 | } | ||
1188 | for (i = 0; i < (pkt->count / 8); i++) { | ||
1189 | struct radeon_bo *texture, *mipmap; | ||
1190 | u32 size, offset; | ||
1191 | |||
1192 | switch (G__SQ_CONSTANT_TYPE(radeon_get_ib_value(p, idx+1+(i*8)+7))) { | ||
1193 | case SQ_TEX_VTX_VALID_TEXTURE: | ||
1194 | /* tex base */ | ||
1195 | r = evergreen_cs_packet_next_reloc(p, &reloc); | ||
1196 | if (r) { | ||
1197 | DRM_ERROR("bad SET_RESOURCE (tex)\n"); | ||
1198 | return -EINVAL; | ||
1199 | } | ||
1200 | ib[idx+1+(i*8)+3] += (u32)((reloc->lobj.gpu_offset >> 8) & 0xffffffff); | ||
1201 | if (reloc->lobj.tiling_flags & RADEON_TILING_MACRO) | ||
1202 | ib[idx+1+(i*8)+1] |= TEX_ARRAY_MODE(ARRAY_2D_TILED_THIN1); | ||
1203 | else if (reloc->lobj.tiling_flags & RADEON_TILING_MICRO) | ||
1204 | ib[idx+1+(i*8)+1] |= TEX_ARRAY_MODE(ARRAY_1D_TILED_THIN1); | ||
1205 | texture = reloc->robj; | ||
1206 | /* tex mip base */ | ||
1207 | r = evergreen_cs_packet_next_reloc(p, &reloc); | ||
1208 | if (r) { | ||
1209 | DRM_ERROR("bad SET_RESOURCE (tex)\n"); | ||
1210 | return -EINVAL; | ||
1211 | } | ||
1212 | ib[idx+1+(i*8)+4] += (u32)((reloc->lobj.gpu_offset >> 8) & 0xffffffff); | ||
1213 | mipmap = reloc->robj; | ||
1214 | r = evergreen_check_texture_resource(p, idx+1+(i*8), | ||
1215 | texture, mipmap); | ||
1216 | if (r) | ||
1217 | return r; | ||
1218 | break; | ||
1219 | case SQ_TEX_VTX_VALID_BUFFER: | ||
1220 | /* vtx base */ | ||
1221 | r = evergreen_cs_packet_next_reloc(p, &reloc); | ||
1222 | if (r) { | ||
1223 | DRM_ERROR("bad SET_RESOURCE (vtx)\n"); | ||
1224 | return -EINVAL; | ||
1225 | } | ||
1226 | offset = radeon_get_ib_value(p, idx+1+(i*8)+0); | ||
1227 | size = radeon_get_ib_value(p, idx+1+(i*8)+1); | ||
1228 | if (p->rdev && (size + offset) > radeon_bo_size(reloc->robj)) { | ||
1229 | /* force size to size of the buffer */ | ||
1230 | dev_warn(p->dev, "vbo resource seems too big for the bo\n"); | ||
1231 | ib[idx+1+(i*8)+1] = radeon_bo_size(reloc->robj); | ||
1232 | } | ||
1233 | ib[idx+1+(i*8)+0] += (u32)((reloc->lobj.gpu_offset) & 0xffffffff); | ||
1234 | ib[idx+1+(i*8)+2] += upper_32_bits(reloc->lobj.gpu_offset) & 0xff; | ||
1235 | break; | ||
1236 | case SQ_TEX_VTX_INVALID_TEXTURE: | ||
1237 | case SQ_TEX_VTX_INVALID_BUFFER: | ||
1238 | default: | ||
1239 | DRM_ERROR("bad SET_RESOURCE\n"); | ||
1240 | return -EINVAL; | ||
1241 | } | ||
1242 | } | ||
1243 | break; | ||
1244 | case PACKET3_SET_ALU_CONST: | ||
1245 | /* XXX fix me ALU const buffers only */ | ||
1246 | break; | ||
1247 | case PACKET3_SET_BOOL_CONST: | ||
1248 | start_reg = (idx_value << 2) + PACKET3_SET_BOOL_CONST_START; | ||
1249 | end_reg = 4 * pkt->count + start_reg - 4; | ||
1250 | if ((start_reg < PACKET3_SET_BOOL_CONST_START) || | ||
1251 | (start_reg >= PACKET3_SET_BOOL_CONST_END) || | ||
1252 | (end_reg >= PACKET3_SET_BOOL_CONST_END)) { | ||
1253 | DRM_ERROR("bad SET_BOOL_CONST\n"); | ||
1254 | return -EINVAL; | ||
1255 | } | ||
1256 | break; | ||
1257 | case PACKET3_SET_LOOP_CONST: | ||
1258 | start_reg = (idx_value << 2) + PACKET3_SET_LOOP_CONST_START; | ||
1259 | end_reg = 4 * pkt->count + start_reg - 4; | ||
1260 | if ((start_reg < PACKET3_SET_LOOP_CONST_START) || | ||
1261 | (start_reg >= PACKET3_SET_LOOP_CONST_END) || | ||
1262 | (end_reg >= PACKET3_SET_LOOP_CONST_END)) { | ||
1263 | DRM_ERROR("bad SET_LOOP_CONST\n"); | ||
1264 | return -EINVAL; | ||
1265 | } | ||
1266 | break; | ||
1267 | case PACKET3_SET_CTL_CONST: | ||
1268 | start_reg = (idx_value << 2) + PACKET3_SET_CTL_CONST_START; | ||
1269 | end_reg = 4 * pkt->count + start_reg - 4; | ||
1270 | if ((start_reg < PACKET3_SET_CTL_CONST_START) || | ||
1271 | (start_reg >= PACKET3_SET_CTL_CONST_END) || | ||
1272 | (end_reg >= PACKET3_SET_CTL_CONST_END)) { | ||
1273 | DRM_ERROR("bad SET_CTL_CONST\n"); | ||
1274 | return -EINVAL; | ||
1275 | } | ||
1276 | break; | ||
1277 | case PACKET3_SET_SAMPLER: | ||
1278 | if (pkt->count % 3) { | ||
1279 | DRM_ERROR("bad SET_SAMPLER\n"); | ||
1280 | return -EINVAL; | ||
1281 | } | ||
1282 | start_reg = (idx_value << 2) + PACKET3_SET_SAMPLER_START; | ||
1283 | end_reg = 4 * pkt->count + start_reg - 4; | ||
1284 | if ((start_reg < PACKET3_SET_SAMPLER_START) || | ||
1285 | (start_reg >= PACKET3_SET_SAMPLER_END) || | ||
1286 | (end_reg >= PACKET3_SET_SAMPLER_END)) { | ||
1287 | DRM_ERROR("bad SET_SAMPLER\n"); | ||
1288 | return -EINVAL; | ||
1289 | } | ||
1290 | break; | ||
1291 | case PACKET3_NOP: | ||
1292 | break; | ||
1293 | default: | ||
1294 | DRM_ERROR("Packet3 opcode %x not supported\n", pkt->opcode); | ||
1295 | return -EINVAL; | ||
1296 | } | ||
1297 | return 0; | ||
1298 | } | ||
1299 | |||
1300 | int evergreen_cs_parse(struct radeon_cs_parser *p) | ||
1301 | { | ||
1302 | struct radeon_cs_packet pkt; | ||
1303 | struct evergreen_cs_track *track; | ||
1304 | int r; | ||
1305 | |||
1306 | if (p->track == NULL) { | ||
1307 | /* initialize tracker, we are in kms */ | ||
1308 | track = kzalloc(sizeof(*track), GFP_KERNEL); | ||
1309 | if (track == NULL) | ||
1310 | return -ENOMEM; | ||
1311 | evergreen_cs_track_init(track); | ||
1312 | track->npipes = p->rdev->config.evergreen.tiling_npipes; | ||
1313 | track->nbanks = p->rdev->config.evergreen.tiling_nbanks; | ||
1314 | track->group_size = p->rdev->config.evergreen.tiling_group_size; | ||
1315 | p->track = track; | ||
1316 | } | ||
1317 | do { | ||
1318 | r = evergreen_cs_packet_parse(p, &pkt, p->idx); | ||
1319 | if (r) { | ||
1320 | kfree(p->track); | ||
1321 | p->track = NULL; | ||
1322 | return r; | ||
1323 | } | ||
1324 | p->idx += pkt.count + 2; | ||
1325 | switch (pkt.type) { | ||
1326 | case PACKET_TYPE0: | ||
1327 | r = evergreen_cs_parse_packet0(p, &pkt); | ||
1328 | break; | ||
1329 | case PACKET_TYPE2: | ||
1330 | break; | ||
1331 | case PACKET_TYPE3: | ||
1332 | r = evergreen_packet3_check(p, &pkt); | ||
1333 | break; | ||
1334 | default: | ||
1335 | DRM_ERROR("Unknown packet type %d !\n", pkt.type); | ||
1336 | kfree(p->track); | ||
1337 | p->track = NULL; | ||
1338 | return -EINVAL; | ||
1339 | } | ||
1340 | if (r) { | ||
1341 | kfree(p->track); | ||
1342 | p->track = NULL; | ||
1343 | return r; | ||
1344 | } | ||
1345 | } while (p->idx < p->chunks[p->chunk_ib_idx].length_dw); | ||
1346 | #if 0 | ||
1347 | for (r = 0; r < p->ib->length_dw; r++) { | ||
1348 | printk(KERN_INFO "%05d 0x%08X\n", r, p->ib->ptr[r]); | ||
1349 | mdelay(1); | ||
1350 | } | ||
1351 | #endif | ||
1352 | kfree(p->track); | ||
1353 | p->track = NULL; | ||
1354 | return 0; | ||
1355 | } | ||
1356 | |||
diff --git a/drivers/gpu/drm/radeon/evergreen_reg.h b/drivers/gpu/drm/radeon/evergreen_reg.h index af86af836f13..e028c1cd9d9b 100644 --- a/drivers/gpu/drm/radeon/evergreen_reg.h +++ b/drivers/gpu/drm/radeon/evergreen_reg.h | |||
@@ -151,6 +151,9 @@ | |||
151 | #define EVERGREEN_DATA_FORMAT 0x6b00 | 151 | #define EVERGREEN_DATA_FORMAT 0x6b00 |
152 | # define EVERGREEN_INTERLEAVE_EN (1 << 0) | 152 | # define EVERGREEN_INTERLEAVE_EN (1 << 0) |
153 | #define EVERGREEN_DESKTOP_HEIGHT 0x6b04 | 153 | #define EVERGREEN_DESKTOP_HEIGHT 0x6b04 |
154 | #define EVERGREEN_VLINE_START_END 0x6b08 | ||
155 | #define EVERGREEN_VLINE_STATUS 0x6bb8 | ||
156 | # define EVERGREEN_VLINE_STAT (1 << 12) | ||
154 | 157 | ||
155 | #define EVERGREEN_VIEWPORT_START 0x6d70 | 158 | #define EVERGREEN_VIEWPORT_START 0x6d70 |
156 | #define EVERGREEN_VIEWPORT_SIZE 0x6d74 | 159 | #define EVERGREEN_VIEWPORT_SIZE 0x6d74 |
diff --git a/drivers/gpu/drm/radeon/evergreend.h b/drivers/gpu/drm/radeon/evergreend.h index 93e9e17ad54a..79683f6b4452 100644 --- a/drivers/gpu/drm/radeon/evergreend.h +++ b/drivers/gpu/drm/radeon/evergreend.h | |||
@@ -218,6 +218,8 @@ | |||
218 | #define CLIP_VTX_REORDER_ENA (1 << 0) | 218 | #define CLIP_VTX_REORDER_ENA (1 << 0) |
219 | #define NUM_CLIP_SEQ(x) ((x) << 1) | 219 | #define NUM_CLIP_SEQ(x) ((x) << 1) |
220 | #define PA_SC_AA_CONFIG 0x28C04 | 220 | #define PA_SC_AA_CONFIG 0x28C04 |
221 | #define MSAA_NUM_SAMPLES_SHIFT 0 | ||
222 | #define MSAA_NUM_SAMPLES_MASK 0x3 | ||
221 | #define PA_SC_CLIPRECT_RULE 0x2820C | 223 | #define PA_SC_CLIPRECT_RULE 0x2820C |
222 | #define PA_SC_EDGERULE 0x28230 | 224 | #define PA_SC_EDGERULE 0x28230 |
223 | #define PA_SC_FIFO_SIZE 0x8BCC | 225 | #define PA_SC_FIFO_SIZE 0x8BCC |
@@ -553,4 +555,466 @@ | |||
553 | # define DC_HPDx_RX_INT_TIMER(x) ((x) << 16) | 555 | # define DC_HPDx_RX_INT_TIMER(x) ((x) << 16) |
554 | # define DC_HPDx_EN (1 << 28) | 556 | # define DC_HPDx_EN (1 << 28) |
555 | 557 | ||
558 | /* | ||
559 | * PM4 | ||
560 | */ | ||
561 | #define PACKET_TYPE0 0 | ||
562 | #define PACKET_TYPE1 1 | ||
563 | #define PACKET_TYPE2 2 | ||
564 | #define PACKET_TYPE3 3 | ||
565 | |||
566 | #define CP_PACKET_GET_TYPE(h) (((h) >> 30) & 3) | ||
567 | #define CP_PACKET_GET_COUNT(h) (((h) >> 16) & 0x3FFF) | ||
568 | #define CP_PACKET0_GET_REG(h) (((h) & 0xFFFF) << 2) | ||
569 | #define CP_PACKET3_GET_OPCODE(h) (((h) >> 8) & 0xFF) | ||
570 | #define PACKET0(reg, n) ((PACKET_TYPE0 << 30) | \ | ||
571 | (((reg) >> 2) & 0xFFFF) | \ | ||
572 | ((n) & 0x3FFF) << 16) | ||
573 | #define CP_PACKET2 0x80000000 | ||
574 | #define PACKET2_PAD_SHIFT 0 | ||
575 | #define PACKET2_PAD_MASK (0x3fffffff << 0) | ||
576 | |||
577 | #define PACKET2(v) (CP_PACKET2 | REG_SET(PACKET2_PAD, (v))) | ||
578 | |||
579 | #define PACKET3(op, n) ((PACKET_TYPE3 << 30) | \ | ||
580 | (((op) & 0xFF) << 8) | \ | ||
581 | ((n) & 0x3FFF) << 16) | ||
582 | |||
583 | /* Packet 3 types */ | ||
584 | #define PACKET3_NOP 0x10 | ||
585 | #define PACKET3_SET_BASE 0x11 | ||
586 | #define PACKET3_CLEAR_STATE 0x12 | ||
587 | #define PACKET3_INDIRECT_BUFFER_SIZE 0x13 | ||
588 | #define PACKET3_DISPATCH_DIRECT 0x15 | ||
589 | #define PACKET3_DISPATCH_INDIRECT 0x16 | ||
590 | #define PACKET3_INDIRECT_BUFFER_END 0x17 | ||
591 | #define PACKET3_SET_PREDICATION 0x20 | ||
592 | #define PACKET3_REG_RMW 0x21 | ||
593 | #define PACKET3_COND_EXEC 0x22 | ||
594 | #define PACKET3_PRED_EXEC 0x23 | ||
595 | #define PACKET3_DRAW_INDIRECT 0x24 | ||
596 | #define PACKET3_DRAW_INDEX_INDIRECT 0x25 | ||
597 | #define PACKET3_INDEX_BASE 0x26 | ||
598 | #define PACKET3_DRAW_INDEX_2 0x27 | ||
599 | #define PACKET3_CONTEXT_CONTROL 0x28 | ||
600 | #define PACKET3_DRAW_INDEX_OFFSET 0x29 | ||
601 | #define PACKET3_INDEX_TYPE 0x2A | ||
602 | #define PACKET3_DRAW_INDEX 0x2B | ||
603 | #define PACKET3_DRAW_INDEX_AUTO 0x2D | ||
604 | #define PACKET3_DRAW_INDEX_IMMD 0x2E | ||
605 | #define PACKET3_NUM_INSTANCES 0x2F | ||
606 | #define PACKET3_DRAW_INDEX_MULTI_AUTO 0x30 | ||
607 | #define PACKET3_STRMOUT_BUFFER_UPDATE 0x34 | ||
608 | #define PACKET3_DRAW_INDEX_OFFSET_2 0x35 | ||
609 | #define PACKET3_DRAW_INDEX_MULTI_ELEMENT 0x36 | ||
610 | #define PACKET3_MEM_SEMAPHORE 0x39 | ||
611 | #define PACKET3_MPEG_INDEX 0x3A | ||
612 | #define PACKET3_WAIT_REG_MEM 0x3C | ||
613 | #define PACKET3_MEM_WRITE 0x3D | ||
614 | #define PACKET3_INDIRECT_BUFFER 0x32 | ||
615 | #define PACKET3_SURFACE_SYNC 0x43 | ||
616 | # define PACKET3_CB0_DEST_BASE_ENA (1 << 6) | ||
617 | # define PACKET3_CB1_DEST_BASE_ENA (1 << 7) | ||
618 | # define PACKET3_CB2_DEST_BASE_ENA (1 << 8) | ||
619 | # define PACKET3_CB3_DEST_BASE_ENA (1 << 9) | ||
620 | # define PACKET3_CB4_DEST_BASE_ENA (1 << 10) | ||
621 | # define PACKET3_CB5_DEST_BASE_ENA (1 << 11) | ||
622 | # define PACKET3_CB6_DEST_BASE_ENA (1 << 12) | ||
623 | # define PACKET3_CB7_DEST_BASE_ENA (1 << 13) | ||
624 | # define PACKET3_DB_DEST_BASE_ENA (1 << 14) | ||
625 | # define PACKET3_CB8_DEST_BASE_ENA (1 << 15) | ||
626 | # define PACKET3_CB9_DEST_BASE_ENA (1 << 16) | ||
627 | # define PACKET3_CB10_DEST_BASE_ENA (1 << 17) | ||
628 | # define PACKET3_CB11_DEST_BASE_ENA (1 << 17) | ||
629 | # define PACKET3_FULL_CACHE_ENA (1 << 20) | ||
630 | # define PACKET3_TC_ACTION_ENA (1 << 23) | ||
631 | # define PACKET3_VC_ACTION_ENA (1 << 24) | ||
632 | # define PACKET3_CB_ACTION_ENA (1 << 25) | ||
633 | # define PACKET3_DB_ACTION_ENA (1 << 26) | ||
634 | # define PACKET3_SH_ACTION_ENA (1 << 27) | ||
635 | # define PACKET3_SMX_ACTION_ENA (1 << 28) | ||
636 | #define PACKET3_ME_INITIALIZE 0x44 | ||
637 | #define PACKET3_ME_INITIALIZE_DEVICE_ID(x) ((x) << 16) | ||
638 | #define PACKET3_COND_WRITE 0x45 | ||
639 | #define PACKET3_EVENT_WRITE 0x46 | ||
640 | #define PACKET3_EVENT_WRITE_EOP 0x47 | ||
641 | #define PACKET3_EVENT_WRITE_EOS 0x48 | ||
642 | #define PACKET3_PREAMBLE_CNTL 0x4A | ||
643 | #define PACKET3_RB_OFFSET 0x4B | ||
644 | #define PACKET3_ALU_PS_CONST_BUFFER_COPY 0x4C | ||
645 | #define PACKET3_ALU_VS_CONST_BUFFER_COPY 0x4D | ||
646 | #define PACKET3_ALU_PS_CONST_UPDATE 0x4E | ||
647 | #define PACKET3_ALU_VS_CONST_UPDATE 0x4F | ||
648 | #define PACKET3_ONE_REG_WRITE 0x57 | ||
649 | #define PACKET3_SET_CONFIG_REG 0x68 | ||
650 | #define PACKET3_SET_CONFIG_REG_START 0x00008000 | ||
651 | #define PACKET3_SET_CONFIG_REG_END 0x0000ac00 | ||
652 | #define PACKET3_SET_CONTEXT_REG 0x69 | ||
653 | #define PACKET3_SET_CONTEXT_REG_START 0x00028000 | ||
654 | #define PACKET3_SET_CONTEXT_REG_END 0x00029000 | ||
655 | #define PACKET3_SET_ALU_CONST 0x6A | ||
656 | /* alu const buffers only; no reg file */ | ||
657 | #define PACKET3_SET_BOOL_CONST 0x6B | ||
658 | #define PACKET3_SET_BOOL_CONST_START 0x0003a500 | ||
659 | #define PACKET3_SET_BOOL_CONST_END 0x0003a518 | ||
660 | #define PACKET3_SET_LOOP_CONST 0x6C | ||
661 | #define PACKET3_SET_LOOP_CONST_START 0x0003a200 | ||
662 | #define PACKET3_SET_LOOP_CONST_END 0x0003a500 | ||
663 | #define PACKET3_SET_RESOURCE 0x6D | ||
664 | #define PACKET3_SET_RESOURCE_START 0x00030000 | ||
665 | #define PACKET3_SET_RESOURCE_END 0x00038000 | ||
666 | #define PACKET3_SET_SAMPLER 0x6E | ||
667 | #define PACKET3_SET_SAMPLER_START 0x0003c000 | ||
668 | #define PACKET3_SET_SAMPLER_END 0x0003c600 | ||
669 | #define PACKET3_SET_CTL_CONST 0x6F | ||
670 | #define PACKET3_SET_CTL_CONST_START 0x0003cff0 | ||
671 | #define PACKET3_SET_CTL_CONST_END 0x0003ff0c | ||
672 | #define PACKET3_SET_RESOURCE_OFFSET 0x70 | ||
673 | #define PACKET3_SET_ALU_CONST_VS 0x71 | ||
674 | #define PACKET3_SET_ALU_CONST_DI 0x72 | ||
675 | #define PACKET3_SET_CONTEXT_REG_INDIRECT 0x73 | ||
676 | #define PACKET3_SET_RESOURCE_INDIRECT 0x74 | ||
677 | #define PACKET3_SET_APPEND_CNT 0x75 | ||
678 | |||
679 | #define SQ_RESOURCE_CONSTANT_WORD7_0 0x3001c | ||
680 | #define S__SQ_CONSTANT_TYPE(x) (((x) & 3) << 30) | ||
681 | #define G__SQ_CONSTANT_TYPE(x) (((x) >> 30) & 3) | ||
682 | #define SQ_TEX_VTX_INVALID_TEXTURE 0x0 | ||
683 | #define SQ_TEX_VTX_INVALID_BUFFER 0x1 | ||
684 | #define SQ_TEX_VTX_VALID_TEXTURE 0x2 | ||
685 | #define SQ_TEX_VTX_VALID_BUFFER 0x3 | ||
686 | |||
687 | #define SQ_CONST_MEM_BASE 0x8df8 | ||
688 | |||
689 | #define SQ_ESGS_RING_SIZE 0x8c44 | ||
690 | #define SQ_GSVS_RING_SIZE 0x8c4c | ||
691 | #define SQ_ESTMP_RING_SIZE 0x8c54 | ||
692 | #define SQ_GSTMP_RING_SIZE 0x8c5c | ||
693 | #define SQ_VSTMP_RING_SIZE 0x8c64 | ||
694 | #define SQ_PSTMP_RING_SIZE 0x8c6c | ||
695 | #define SQ_LSTMP_RING_SIZE 0x8e14 | ||
696 | #define SQ_HSTMP_RING_SIZE 0x8e1c | ||
697 | #define VGT_TF_RING_SIZE 0x8988 | ||
698 | |||
699 | #define SQ_ESGS_RING_ITEMSIZE 0x28900 | ||
700 | #define SQ_GSVS_RING_ITEMSIZE 0x28904 | ||
701 | #define SQ_ESTMP_RING_ITEMSIZE 0x28908 | ||
702 | #define SQ_GSTMP_RING_ITEMSIZE 0x2890c | ||
703 | #define SQ_VSTMP_RING_ITEMSIZE 0x28910 | ||
704 | #define SQ_PSTMP_RING_ITEMSIZE 0x28914 | ||
705 | #define SQ_LSTMP_RING_ITEMSIZE 0x28830 | ||
706 | #define SQ_HSTMP_RING_ITEMSIZE 0x28834 | ||
707 | |||
708 | #define SQ_GS_VERT_ITEMSIZE 0x2891c | ||
709 | #define SQ_GS_VERT_ITEMSIZE_1 0x28920 | ||
710 | #define SQ_GS_VERT_ITEMSIZE_2 0x28924 | ||
711 | #define SQ_GS_VERT_ITEMSIZE_3 0x28928 | ||
712 | #define SQ_GSVS_RING_OFFSET_1 0x2892c | ||
713 | #define SQ_GSVS_RING_OFFSET_2 0x28930 | ||
714 | #define SQ_GSVS_RING_OFFSET_3 0x28934 | ||
715 | |||
716 | #define SQ_ALU_CONST_CACHE_PS_0 0x28940 | ||
717 | #define SQ_ALU_CONST_CACHE_PS_1 0x28944 | ||
718 | #define SQ_ALU_CONST_CACHE_PS_2 0x28948 | ||
719 | #define SQ_ALU_CONST_CACHE_PS_3 0x2894c | ||
720 | #define SQ_ALU_CONST_CACHE_PS_4 0x28950 | ||
721 | #define SQ_ALU_CONST_CACHE_PS_5 0x28954 | ||
722 | #define SQ_ALU_CONST_CACHE_PS_6 0x28958 | ||
723 | #define SQ_ALU_CONST_CACHE_PS_7 0x2895c | ||
724 | #define SQ_ALU_CONST_CACHE_PS_8 0x28960 | ||
725 | #define SQ_ALU_CONST_CACHE_PS_9 0x28964 | ||
726 | #define SQ_ALU_CONST_CACHE_PS_10 0x28968 | ||
727 | #define SQ_ALU_CONST_CACHE_PS_11 0x2896c | ||
728 | #define SQ_ALU_CONST_CACHE_PS_12 0x28970 | ||
729 | #define SQ_ALU_CONST_CACHE_PS_13 0x28974 | ||
730 | #define SQ_ALU_CONST_CACHE_PS_14 0x28978 | ||
731 | #define SQ_ALU_CONST_CACHE_PS_15 0x2897c | ||
732 | #define SQ_ALU_CONST_CACHE_VS_0 0x28980 | ||
733 | #define SQ_ALU_CONST_CACHE_VS_1 0x28984 | ||
734 | #define SQ_ALU_CONST_CACHE_VS_2 0x28988 | ||
735 | #define SQ_ALU_CONST_CACHE_VS_3 0x2898c | ||
736 | #define SQ_ALU_CONST_CACHE_VS_4 0x28990 | ||
737 | #define SQ_ALU_CONST_CACHE_VS_5 0x28994 | ||
738 | #define SQ_ALU_CONST_CACHE_VS_6 0x28998 | ||
739 | #define SQ_ALU_CONST_CACHE_VS_7 0x2899c | ||
740 | #define SQ_ALU_CONST_CACHE_VS_8 0x289a0 | ||
741 | #define SQ_ALU_CONST_CACHE_VS_9 0x289a4 | ||
742 | #define SQ_ALU_CONST_CACHE_VS_10 0x289a8 | ||
743 | #define SQ_ALU_CONST_CACHE_VS_11 0x289ac | ||
744 | #define SQ_ALU_CONST_CACHE_VS_12 0x289b0 | ||
745 | #define SQ_ALU_CONST_CACHE_VS_13 0x289b4 | ||
746 | #define SQ_ALU_CONST_CACHE_VS_14 0x289b8 | ||
747 | #define SQ_ALU_CONST_CACHE_VS_15 0x289bc | ||
748 | #define SQ_ALU_CONST_CACHE_GS_0 0x289c0 | ||
749 | #define SQ_ALU_CONST_CACHE_GS_1 0x289c4 | ||
750 | #define SQ_ALU_CONST_CACHE_GS_2 0x289c8 | ||
751 | #define SQ_ALU_CONST_CACHE_GS_3 0x289cc | ||
752 | #define SQ_ALU_CONST_CACHE_GS_4 0x289d0 | ||
753 | #define SQ_ALU_CONST_CACHE_GS_5 0x289d4 | ||
754 | #define SQ_ALU_CONST_CACHE_GS_6 0x289d8 | ||
755 | #define SQ_ALU_CONST_CACHE_GS_7 0x289dc | ||
756 | #define SQ_ALU_CONST_CACHE_GS_8 0x289e0 | ||
757 | #define SQ_ALU_CONST_CACHE_GS_9 0x289e4 | ||
758 | #define SQ_ALU_CONST_CACHE_GS_10 0x289e8 | ||
759 | #define SQ_ALU_CONST_CACHE_GS_11 0x289ec | ||
760 | #define SQ_ALU_CONST_CACHE_GS_12 0x289f0 | ||
761 | #define SQ_ALU_CONST_CACHE_GS_13 0x289f4 | ||
762 | #define SQ_ALU_CONST_CACHE_GS_14 0x289f8 | ||
763 | #define SQ_ALU_CONST_CACHE_GS_15 0x289fc | ||
764 | #define SQ_ALU_CONST_CACHE_HS_0 0x28f00 | ||
765 | #define SQ_ALU_CONST_CACHE_HS_1 0x28f04 | ||
766 | #define SQ_ALU_CONST_CACHE_HS_2 0x28f08 | ||
767 | #define SQ_ALU_CONST_CACHE_HS_3 0x28f0c | ||
768 | #define SQ_ALU_CONST_CACHE_HS_4 0x28f10 | ||
769 | #define SQ_ALU_CONST_CACHE_HS_5 0x28f14 | ||
770 | #define SQ_ALU_CONST_CACHE_HS_6 0x28f18 | ||
771 | #define SQ_ALU_CONST_CACHE_HS_7 0x28f1c | ||
772 | #define SQ_ALU_CONST_CACHE_HS_8 0x28f20 | ||
773 | #define SQ_ALU_CONST_CACHE_HS_9 0x28f24 | ||
774 | #define SQ_ALU_CONST_CACHE_HS_10 0x28f28 | ||
775 | #define SQ_ALU_CONST_CACHE_HS_11 0x28f2c | ||
776 | #define SQ_ALU_CONST_CACHE_HS_12 0x28f30 | ||
777 | #define SQ_ALU_CONST_CACHE_HS_13 0x28f34 | ||
778 | #define SQ_ALU_CONST_CACHE_HS_14 0x28f38 | ||
779 | #define SQ_ALU_CONST_CACHE_HS_15 0x28f3c | ||
780 | #define SQ_ALU_CONST_CACHE_LS_0 0x28f40 | ||
781 | #define SQ_ALU_CONST_CACHE_LS_1 0x28f44 | ||
782 | #define SQ_ALU_CONST_CACHE_LS_2 0x28f48 | ||
783 | #define SQ_ALU_CONST_CACHE_LS_3 0x28f4c | ||
784 | #define SQ_ALU_CONST_CACHE_LS_4 0x28f50 | ||
785 | #define SQ_ALU_CONST_CACHE_LS_5 0x28f54 | ||
786 | #define SQ_ALU_CONST_CACHE_LS_6 0x28f58 | ||
787 | #define SQ_ALU_CONST_CACHE_LS_7 0x28f5c | ||
788 | #define SQ_ALU_CONST_CACHE_LS_8 0x28f60 | ||
789 | #define SQ_ALU_CONST_CACHE_LS_9 0x28f64 | ||
790 | #define SQ_ALU_CONST_CACHE_LS_10 0x28f68 | ||
791 | #define SQ_ALU_CONST_CACHE_LS_11 0x28f6c | ||
792 | #define SQ_ALU_CONST_CACHE_LS_12 0x28f70 | ||
793 | #define SQ_ALU_CONST_CACHE_LS_13 0x28f74 | ||
794 | #define SQ_ALU_CONST_CACHE_LS_14 0x28f78 | ||
795 | #define SQ_ALU_CONST_CACHE_LS_15 0x28f7c | ||
796 | |||
797 | #define DB_DEPTH_CONTROL 0x28800 | ||
798 | #define DB_DEPTH_VIEW 0x28008 | ||
799 | #define DB_HTILE_DATA_BASE 0x28014 | ||
800 | #define DB_Z_INFO 0x28040 | ||
801 | # define Z_ARRAY_MODE(x) ((x) << 4) | ||
802 | #define DB_STENCIL_INFO 0x28044 | ||
803 | #define DB_Z_READ_BASE 0x28048 | ||
804 | #define DB_STENCIL_READ_BASE 0x2804c | ||
805 | #define DB_Z_WRITE_BASE 0x28050 | ||
806 | #define DB_STENCIL_WRITE_BASE 0x28054 | ||
807 | #define DB_DEPTH_SIZE 0x28058 | ||
808 | |||
809 | #define SQ_PGM_START_PS 0x28840 | ||
810 | #define SQ_PGM_START_VS 0x2885c | ||
811 | #define SQ_PGM_START_GS 0x28874 | ||
812 | #define SQ_PGM_START_ES 0x2888c | ||
813 | #define SQ_PGM_START_FS 0x288a4 | ||
814 | #define SQ_PGM_START_HS 0x288b8 | ||
815 | #define SQ_PGM_START_LS 0x288d0 | ||
816 | |||
817 | #define VGT_STRMOUT_CONFIG 0x28b94 | ||
818 | #define VGT_STRMOUT_BUFFER_CONFIG 0x28b98 | ||
819 | |||
820 | #define CB_TARGET_MASK 0x28238 | ||
821 | #define CB_SHADER_MASK 0x2823c | ||
822 | |||
823 | #define GDS_ADDR_BASE 0x28720 | ||
824 | |||
825 | #define CB_IMMED0_BASE 0x28b9c | ||
826 | #define CB_IMMED1_BASE 0x28ba0 | ||
827 | #define CB_IMMED2_BASE 0x28ba4 | ||
828 | #define CB_IMMED3_BASE 0x28ba8 | ||
829 | #define CB_IMMED4_BASE 0x28bac | ||
830 | #define CB_IMMED5_BASE 0x28bb0 | ||
831 | #define CB_IMMED6_BASE 0x28bb4 | ||
832 | #define CB_IMMED7_BASE 0x28bb8 | ||
833 | #define CB_IMMED8_BASE 0x28bbc | ||
834 | #define CB_IMMED9_BASE 0x28bc0 | ||
835 | #define CB_IMMED10_BASE 0x28bc4 | ||
836 | #define CB_IMMED11_BASE 0x28bc8 | ||
837 | |||
838 | /* all 12 CB blocks have these regs */ | ||
839 | #define CB_COLOR0_BASE 0x28c60 | ||
840 | #define CB_COLOR0_PITCH 0x28c64 | ||
841 | #define CB_COLOR0_SLICE 0x28c68 | ||
842 | #define CB_COLOR0_VIEW 0x28c6c | ||
843 | #define CB_COLOR0_INFO 0x28c70 | ||
844 | # define CB_ARRAY_MODE(x) ((x) << 8) | ||
845 | # define ARRAY_LINEAR_GENERAL 0 | ||
846 | # define ARRAY_LINEAR_ALIGNED 1 | ||
847 | # define ARRAY_1D_TILED_THIN1 2 | ||
848 | # define ARRAY_2D_TILED_THIN1 4 | ||
849 | #define CB_COLOR0_ATTRIB 0x28c74 | ||
850 | #define CB_COLOR0_DIM 0x28c78 | ||
851 | /* only CB0-7 blocks have these regs */ | ||
852 | #define CB_COLOR0_CMASK 0x28c7c | ||
853 | #define CB_COLOR0_CMASK_SLICE 0x28c80 | ||
854 | #define CB_COLOR0_FMASK 0x28c84 | ||
855 | #define CB_COLOR0_FMASK_SLICE 0x28c88 | ||
856 | #define CB_COLOR0_CLEAR_WORD0 0x28c8c | ||
857 | #define CB_COLOR0_CLEAR_WORD1 0x28c90 | ||
858 | #define CB_COLOR0_CLEAR_WORD2 0x28c94 | ||
859 | #define CB_COLOR0_CLEAR_WORD3 0x28c98 | ||
860 | |||
861 | #define CB_COLOR1_BASE 0x28c9c | ||
862 | #define CB_COLOR2_BASE 0x28cd8 | ||
863 | #define CB_COLOR3_BASE 0x28d14 | ||
864 | #define CB_COLOR4_BASE 0x28d50 | ||
865 | #define CB_COLOR5_BASE 0x28d8c | ||
866 | #define CB_COLOR6_BASE 0x28dc8 | ||
867 | #define CB_COLOR7_BASE 0x28e04 | ||
868 | #define CB_COLOR8_BASE 0x28e40 | ||
869 | #define CB_COLOR9_BASE 0x28e5c | ||
870 | #define CB_COLOR10_BASE 0x28e78 | ||
871 | #define CB_COLOR11_BASE 0x28e94 | ||
872 | |||
873 | #define CB_COLOR1_PITCH 0x28ca0 | ||
874 | #define CB_COLOR2_PITCH 0x28cdc | ||
875 | #define CB_COLOR3_PITCH 0x28d18 | ||
876 | #define CB_COLOR4_PITCH 0x28d54 | ||
877 | #define CB_COLOR5_PITCH 0x28d90 | ||
878 | #define CB_COLOR6_PITCH 0x28dcc | ||
879 | #define CB_COLOR7_PITCH 0x28e08 | ||
880 | #define CB_COLOR8_PITCH 0x28e44 | ||
881 | #define CB_COLOR9_PITCH 0x28e60 | ||
882 | #define CB_COLOR10_PITCH 0x28e7c | ||
883 | #define CB_COLOR11_PITCH 0x28e98 | ||
884 | |||
885 | #define CB_COLOR1_SLICE 0x28ca4 | ||
886 | #define CB_COLOR2_SLICE 0x28ce0 | ||
887 | #define CB_COLOR3_SLICE 0x28d1c | ||
888 | #define CB_COLOR4_SLICE 0x28d58 | ||
889 | #define CB_COLOR5_SLICE 0x28d94 | ||
890 | #define CB_COLOR6_SLICE 0x28dd0 | ||
891 | #define CB_COLOR7_SLICE 0x28e0c | ||
892 | #define CB_COLOR8_SLICE 0x28e48 | ||
893 | #define CB_COLOR9_SLICE 0x28e64 | ||
894 | #define CB_COLOR10_SLICE 0x28e80 | ||
895 | #define CB_COLOR11_SLICE 0x28e9c | ||
896 | |||
897 | #define CB_COLOR1_VIEW 0x28ca8 | ||
898 | #define CB_COLOR2_VIEW 0x28ce4 | ||
899 | #define CB_COLOR3_VIEW 0x28d20 | ||
900 | #define CB_COLOR4_VIEW 0x28d5c | ||
901 | #define CB_COLOR5_VIEW 0x28d98 | ||
902 | #define CB_COLOR6_VIEW 0x28dd4 | ||
903 | #define CB_COLOR7_VIEW 0x28e10 | ||
904 | #define CB_COLOR8_VIEW 0x28e4c | ||
905 | #define CB_COLOR9_VIEW 0x28e68 | ||
906 | #define CB_COLOR10_VIEW 0x28e84 | ||
907 | #define CB_COLOR11_VIEW 0x28ea0 | ||
908 | |||
909 | #define CB_COLOR1_INFO 0x28cac | ||
910 | #define CB_COLOR2_INFO 0x28ce8 | ||
911 | #define CB_COLOR3_INFO 0x28d24 | ||
912 | #define CB_COLOR4_INFO 0x28d60 | ||
913 | #define CB_COLOR5_INFO 0x28d9c | ||
914 | #define CB_COLOR6_INFO 0x28dd8 | ||
915 | #define CB_COLOR7_INFO 0x28e14 | ||
916 | #define CB_COLOR8_INFO 0x28e50 | ||
917 | #define CB_COLOR9_INFO 0x28e6c | ||
918 | #define CB_COLOR10_INFO 0x28e88 | ||
919 | #define CB_COLOR11_INFO 0x28ea4 | ||
920 | |||
921 | #define CB_COLOR1_ATTRIB 0x28cb0 | ||
922 | #define CB_COLOR2_ATTRIB 0x28cec | ||
923 | #define CB_COLOR3_ATTRIB 0x28d28 | ||
924 | #define CB_COLOR4_ATTRIB 0x28d64 | ||
925 | #define CB_COLOR5_ATTRIB 0x28da0 | ||
926 | #define CB_COLOR6_ATTRIB 0x28ddc | ||
927 | #define CB_COLOR7_ATTRIB 0x28e18 | ||
928 | #define CB_COLOR8_ATTRIB 0x28e54 | ||
929 | #define CB_COLOR9_ATTRIB 0x28e70 | ||
930 | #define CB_COLOR10_ATTRIB 0x28e8c | ||
931 | #define CB_COLOR11_ATTRIB 0x28ea8 | ||
932 | |||
933 | #define CB_COLOR1_DIM 0x28cb4 | ||
934 | #define CB_COLOR2_DIM 0x28cf0 | ||
935 | #define CB_COLOR3_DIM 0x28d2c | ||
936 | #define CB_COLOR4_DIM 0x28d68 | ||
937 | #define CB_COLOR5_DIM 0x28da4 | ||
938 | #define CB_COLOR6_DIM 0x28de0 | ||
939 | #define CB_COLOR7_DIM 0x28e1c | ||
940 | #define CB_COLOR8_DIM 0x28e58 | ||
941 | #define CB_COLOR9_DIM 0x28e74 | ||
942 | #define CB_COLOR10_DIM 0x28e90 | ||
943 | #define CB_COLOR11_DIM 0x28eac | ||
944 | |||
945 | #define CB_COLOR1_CMASK 0x28cb8 | ||
946 | #define CB_COLOR2_CMASK 0x28cf4 | ||
947 | #define CB_COLOR3_CMASK 0x28d30 | ||
948 | #define CB_COLOR4_CMASK 0x28d6c | ||
949 | #define CB_COLOR5_CMASK 0x28da8 | ||
950 | #define CB_COLOR6_CMASK 0x28de4 | ||
951 | #define CB_COLOR7_CMASK 0x28e20 | ||
952 | |||
953 | #define CB_COLOR1_CMASK_SLICE 0x28cbc | ||
954 | #define CB_COLOR2_CMASK_SLICE 0x28cf8 | ||
955 | #define CB_COLOR3_CMASK_SLICE 0x28d34 | ||
956 | #define CB_COLOR4_CMASK_SLICE 0x28d70 | ||
957 | #define CB_COLOR5_CMASK_SLICE 0x28dac | ||
958 | #define CB_COLOR6_CMASK_SLICE 0x28de8 | ||
959 | #define CB_COLOR7_CMASK_SLICE 0x28e24 | ||
960 | |||
961 | #define CB_COLOR1_FMASK 0x28cc0 | ||
962 | #define CB_COLOR2_FMASK 0x28cfc | ||
963 | #define CB_COLOR3_FMASK 0x28d38 | ||
964 | #define CB_COLOR4_FMASK 0x28d74 | ||
965 | #define CB_COLOR5_FMASK 0x28db0 | ||
966 | #define CB_COLOR6_FMASK 0x28dec | ||
967 | #define CB_COLOR7_FMASK 0x28e28 | ||
968 | |||
969 | #define CB_COLOR1_FMASK_SLICE 0x28cc4 | ||
970 | #define CB_COLOR2_FMASK_SLICE 0x28d00 | ||
971 | #define CB_COLOR3_FMASK_SLICE 0x28d3c | ||
972 | #define CB_COLOR4_FMASK_SLICE 0x28d78 | ||
973 | #define CB_COLOR5_FMASK_SLICE 0x28db4 | ||
974 | #define CB_COLOR6_FMASK_SLICE 0x28df0 | ||
975 | #define CB_COLOR7_FMASK_SLICE 0x28e2c | ||
976 | |||
977 | #define CB_COLOR1_CLEAR_WORD0 0x28cc8 | ||
978 | #define CB_COLOR2_CLEAR_WORD0 0x28d04 | ||
979 | #define CB_COLOR3_CLEAR_WORD0 0x28d40 | ||
980 | #define CB_COLOR4_CLEAR_WORD0 0x28d7c | ||
981 | #define CB_COLOR5_CLEAR_WORD0 0x28db8 | ||
982 | #define CB_COLOR6_CLEAR_WORD0 0x28df4 | ||
983 | #define CB_COLOR7_CLEAR_WORD0 0x28e30 | ||
984 | |||
985 | #define CB_COLOR1_CLEAR_WORD1 0x28ccc | ||
986 | #define CB_COLOR2_CLEAR_WORD1 0x28d08 | ||
987 | #define CB_COLOR3_CLEAR_WORD1 0x28d44 | ||
988 | #define CB_COLOR4_CLEAR_WORD1 0x28d80 | ||
989 | #define CB_COLOR5_CLEAR_WORD1 0x28dbc | ||
990 | #define CB_COLOR6_CLEAR_WORD1 0x28df8 | ||
991 | #define CB_COLOR7_CLEAR_WORD1 0x28e34 | ||
992 | |||
993 | #define CB_COLOR1_CLEAR_WORD2 0x28cd0 | ||
994 | #define CB_COLOR2_CLEAR_WORD2 0x28d0c | ||
995 | #define CB_COLOR3_CLEAR_WORD2 0x28d48 | ||
996 | #define CB_COLOR4_CLEAR_WORD2 0x28d84 | ||
997 | #define CB_COLOR5_CLEAR_WORD2 0x28dc0 | ||
998 | #define CB_COLOR6_CLEAR_WORD2 0x28dfc | ||
999 | #define CB_COLOR7_CLEAR_WORD2 0x28e38 | ||
1000 | |||
1001 | #define CB_COLOR1_CLEAR_WORD3 0x28cd4 | ||
1002 | #define CB_COLOR2_CLEAR_WORD3 0x28d10 | ||
1003 | #define CB_COLOR3_CLEAR_WORD3 0x28d4c | ||
1004 | #define CB_COLOR4_CLEAR_WORD3 0x28d88 | ||
1005 | #define CB_COLOR5_CLEAR_WORD3 0x28dc4 | ||
1006 | #define CB_COLOR6_CLEAR_WORD3 0x28e00 | ||
1007 | #define CB_COLOR7_CLEAR_WORD3 0x28e3c | ||
1008 | |||
1009 | #define SQ_TEX_RESOURCE_WORD0_0 0x30000 | ||
1010 | #define SQ_TEX_RESOURCE_WORD1_0 0x30004 | ||
1011 | # define TEX_ARRAY_MODE(x) ((x) << 28) | ||
1012 | #define SQ_TEX_RESOURCE_WORD2_0 0x30008 | ||
1013 | #define SQ_TEX_RESOURCE_WORD3_0 0x3000C | ||
1014 | #define SQ_TEX_RESOURCE_WORD4_0 0x30010 | ||
1015 | #define SQ_TEX_RESOURCE_WORD5_0 0x30014 | ||
1016 | #define SQ_TEX_RESOURCE_WORD6_0 0x30018 | ||
1017 | #define SQ_TEX_RESOURCE_WORD7_0 0x3001c | ||
1018 | |||
1019 | |||
556 | #endif | 1020 | #endif |
diff --git a/drivers/gpu/drm/radeon/radeon_asic.c b/drivers/gpu/drm/radeon/radeon_asic.c index e57df08d4aeb..87f7e2cc52d4 100644 --- a/drivers/gpu/drm/radeon/radeon_asic.c +++ b/drivers/gpu/drm/radeon/radeon_asic.c | |||
@@ -724,8 +724,8 @@ static struct radeon_asic evergreen_asic = { | |||
724 | .irq_set = &evergreen_irq_set, | 724 | .irq_set = &evergreen_irq_set, |
725 | .irq_process = &evergreen_irq_process, | 725 | .irq_process = &evergreen_irq_process, |
726 | .get_vblank_counter = &evergreen_get_vblank_counter, | 726 | .get_vblank_counter = &evergreen_get_vblank_counter, |
727 | .fence_ring_emit = NULL, | 727 | .fence_ring_emit = &r600_fence_ring_emit, |
728 | .cs_parse = NULL, | 728 | .cs_parse = &evergreen_cs_parse, |
729 | .copy_blit = NULL, | 729 | .copy_blit = NULL, |
730 | .copy_dma = NULL, | 730 | .copy_dma = NULL, |
731 | .copy = NULL, | 731 | .copy = NULL, |
diff --git a/drivers/gpu/drm/radeon/radeon_asic.h b/drivers/gpu/drm/radeon/radeon_asic.h index 5c40a3dfaca2..c0bbaa64157a 100644 --- a/drivers/gpu/drm/radeon/radeon_asic.h +++ b/drivers/gpu/drm/radeon/radeon_asic.h | |||
@@ -314,6 +314,7 @@ void evergreen_hpd_set_polarity(struct radeon_device *rdev, | |||
314 | u32 evergreen_get_vblank_counter(struct radeon_device *rdev, int crtc); | 314 | u32 evergreen_get_vblank_counter(struct radeon_device *rdev, int crtc); |
315 | int evergreen_irq_set(struct radeon_device *rdev); | 315 | int evergreen_irq_set(struct radeon_device *rdev); |
316 | int evergreen_irq_process(struct radeon_device *rdev); | 316 | int evergreen_irq_process(struct radeon_device *rdev); |
317 | extern int evergreen_cs_parse(struct radeon_cs_parser *p); | ||
317 | extern void evergreen_pm_misc(struct radeon_device *rdev); | 318 | extern void evergreen_pm_misc(struct radeon_device *rdev); |
318 | extern void evergreen_pm_prepare(struct radeon_device *rdev); | 319 | extern void evergreen_pm_prepare(struct radeon_device *rdev); |
319 | extern void evergreen_pm_finish(struct radeon_device *rdev); | 320 | extern void evergreen_pm_finish(struct radeon_device *rdev); |
diff --git a/drivers/gpu/drm/radeon/reg_srcs/evergreen b/drivers/gpu/drm/radeon/reg_srcs/evergreen new file mode 100644 index 000000000000..b5c757f68d3c --- /dev/null +++ b/drivers/gpu/drm/radeon/reg_srcs/evergreen | |||
@@ -0,0 +1,611 @@ | |||
1 | evergreen 0x9400 | ||
2 | 0x00008040 WAIT_UNTIL | ||
3 | 0x00008044 WAIT_UNTIL_POLL_CNTL | ||
4 | 0x00008048 WAIT_UNTIL_POLL_MASK | ||
5 | 0x0000804c WAIT_UNTIL_POLL_REFDATA | ||
6 | 0x000088B0 VGT_VTX_VECT_EJECT_REG | ||
7 | 0x000088C4 VGT_CACHE_INVALIDATION | ||
8 | 0x000088D4 VGT_GS_VERTEX_REUSE | ||
9 | 0x00008958 VGT_PRIMITIVE_TYPE | ||
10 | 0x0000895C VGT_INDEX_TYPE | ||
11 | 0x00008970 VGT_NUM_INDICES | ||
12 | 0x00008974 VGT_NUM_INSTANCES | ||
13 | 0x00008990 VGT_COMPUTE_DIM_X | ||
14 | 0x00008994 VGT_COMPUTE_DIM_Y | ||
15 | 0x00008998 VGT_COMPUTE_DIM_Z | ||
16 | 0x0000899C VGT_COMPUTE_START_X | ||
17 | 0x000089A0 VGT_COMPUTE_START_Y | ||
18 | 0x000089A4 VGT_COMPUTE_START_Z | ||
19 | 0x000089AC VGT_COMPUTE_THREAD_GOURP_SIZE | ||
20 | 0x00008A14 PA_CL_ENHANCE | ||
21 | 0x00008A60 PA_SC_LINE_STIPPLE_VALUE | ||
22 | 0x00008B10 PA_SC_LINE_STIPPLE_STATE | ||
23 | 0x00008BF0 PA_SC_ENHANCE | ||
24 | 0x00008D8C SQ_DYN_GPR_CNTL_PS_FLUSH_REQ | ||
25 | 0x00008C00 SQ_CONFIG | ||
26 | 0x00008C04 SQ_GPR_RESOURCE_MGMT_1 | ||
27 | 0x00008C08 SQ_GPR_RESOURCE_MGMT_2 | ||
28 | 0x00008C0C SQ_GPR_RESOURCE_MGMT_3 | ||
29 | 0x00008C10 SQ_GLOBAL_GPR_RESOURCE_MGMT_1 | ||
30 | 0x00008C14 SQ_GLOBAL_GPR_RESOURCE_MGMT_2 | ||
31 | 0x00008C18 SQ_THREAD_RESOURCE_MGMT | ||
32 | 0x00008C1C SQ_THREAD_RESOURCE_MGMT_2 | ||
33 | 0x00008C20 SQ_STACK_RESOURCE_MGMT_1 | ||
34 | 0x00008C24 SQ_STACK_RESOURCE_MGMT_2 | ||
35 | 0x00008C28 SQ_STACK_RESOURCE_MGMT_3 | ||
36 | 0x00008DF8 SQ_CONST_MEM_BASE | ||
37 | 0x00008E48 SQ_EX_ALLOC_TABLE_SLOTS | ||
38 | 0x00009100 SPI_CONFIG_CNTL | ||
39 | 0x0000913C SPI_CONFIG_CNTL_1 | ||
40 | 0x00009700 VC_CNTL | ||
41 | 0x00009714 VC_ENHANCE | ||
42 | 0x00009830 DB_DEBUG | ||
43 | 0x00009834 DB_DEBUG2 | ||
44 | 0x00009838 DB_DEBUG3 | ||
45 | 0x0000983C DB_DEBUG4 | ||
46 | 0x00009854 DB_WATERMARKS | ||
47 | 0x0000A400 TD_PS_BORDER_COLOR_INDEX | ||
48 | 0x0000A404 TD_PS_BORDER_COLOR_RED | ||
49 | 0x0000A408 TD_PS_BORDER_COLOR_GREEN | ||
50 | 0x0000A40C TD_PS_BORDER_COLOR_BLUE | ||
51 | 0x0000A410 TD_PS_BORDER_COLOR_ALPHA | ||
52 | 0x0000A414 TD_VS_BORDER_COLOR_INDEX | ||
53 | 0x0000A418 TD_VS_BORDER_COLOR_RED | ||
54 | 0x0000A41C TD_VS_BORDER_COLOR_GREEN | ||
55 | 0x0000A420 TD_VS_BORDER_COLOR_BLUE | ||
56 | 0x0000A424 TD_VS_BORDER_COLOR_ALPHA | ||
57 | 0x0000A428 TD_GS_BORDER_COLOR_INDEX | ||
58 | 0x0000A42C TD_GS_BORDER_COLOR_RED | ||
59 | 0x0000A430 TD_GS_BORDER_COLOR_GREEN | ||
60 | 0x0000A434 TD_GS_BORDER_COLOR_BLUE | ||
61 | 0x0000A438 TD_GS_BORDER_COLOR_ALPHA | ||
62 | 0x0000A43C TD_HS_BORDER_COLOR_INDEX | ||
63 | 0x0000A440 TD_HS_BORDER_COLOR_RED | ||
64 | 0x0000A444 TD_HS_BORDER_COLOR_GREEN | ||
65 | 0x0000A448 TD_HS_BORDER_COLOR_BLUE | ||
66 | 0x0000A44C TD_HS_BORDER_COLOR_ALPHA | ||
67 | 0x0000A450 TD_LS_BORDER_COLOR_INDEX | ||
68 | 0x0000A454 TD_LS_BORDER_COLOR_RED | ||
69 | 0x0000A458 TD_LS_BORDER_COLOR_GREEN | ||
70 | 0x0000A45C TD_LS_BORDER_COLOR_BLUE | ||
71 | 0x0000A460 TD_LS_BORDER_COLOR_ALPHA | ||
72 | 0x0000A464 TD_CS_BORDER_COLOR_INDEX | ||
73 | 0x0000A468 TD_CS_BORDER_COLOR_RED | ||
74 | 0x0000A46C TD_CS_BORDER_COLOR_GREEN | ||
75 | 0x0000A470 TD_CS_BORDER_COLOR_BLUE | ||
76 | 0x0000A474 TD_CS_BORDER_COLOR_ALPHA | ||
77 | 0x00028000 DB_RENDER_CONTROL | ||
78 | 0x00028004 DB_COUNT_CONTROL | ||
79 | 0x0002800C DB_RENDER_OVERRIDE | ||
80 | 0x00028010 DB_RENDER_OVERRIDE2 | ||
81 | 0x00028028 DB_STENCIL_CLEAR | ||
82 | 0x0002802C DB_DEPTH_CLEAR | ||
83 | 0x00028034 PA_SC_SCREEN_SCISSOR_BR | ||
84 | 0x00028030 PA_SC_SCREEN_SCISSOR_TL | ||
85 | 0x0002805C DB_DEPTH_SLICE | ||
86 | 0x00028140 SQ_ALU_CONST_BUFFER_SIZE_PS_0 | ||
87 | 0x00028144 SQ_ALU_CONST_BUFFER_SIZE_PS_1 | ||
88 | 0x00028148 SQ_ALU_CONST_BUFFER_SIZE_PS_2 | ||
89 | 0x0002814C SQ_ALU_CONST_BUFFER_SIZE_PS_3 | ||
90 | 0x00028150 SQ_ALU_CONST_BUFFER_SIZE_PS_4 | ||
91 | 0x00028154 SQ_ALU_CONST_BUFFER_SIZE_PS_5 | ||
92 | 0x00028158 SQ_ALU_CONST_BUFFER_SIZE_PS_6 | ||
93 | 0x0002815C SQ_ALU_CONST_BUFFER_SIZE_PS_7 | ||
94 | 0x00028160 SQ_ALU_CONST_BUFFER_SIZE_PS_8 | ||
95 | 0x00028164 SQ_ALU_CONST_BUFFER_SIZE_PS_9 | ||
96 | 0x00028168 SQ_ALU_CONST_BUFFER_SIZE_PS_10 | ||
97 | 0x0002816C SQ_ALU_CONST_BUFFER_SIZE_PS_11 | ||
98 | 0x00028170 SQ_ALU_CONST_BUFFER_SIZE_PS_12 | ||
99 | 0x00028174 SQ_ALU_CONST_BUFFER_SIZE_PS_13 | ||
100 | 0x00028178 SQ_ALU_CONST_BUFFER_SIZE_PS_14 | ||
101 | 0x0002817C SQ_ALU_CONST_BUFFER_SIZE_PS_15 | ||
102 | 0x00028180 SQ_ALU_CONST_BUFFER_SIZE_VS_0 | ||
103 | 0x00028184 SQ_ALU_CONST_BUFFER_SIZE_VS_1 | ||
104 | 0x00028188 SQ_ALU_CONST_BUFFER_SIZE_VS_2 | ||
105 | 0x0002818C SQ_ALU_CONST_BUFFER_SIZE_VS_3 | ||
106 | 0x00028190 SQ_ALU_CONST_BUFFER_SIZE_VS_4 | ||
107 | 0x00028194 SQ_ALU_CONST_BUFFER_SIZE_VS_5 | ||
108 | 0x00028198 SQ_ALU_CONST_BUFFER_SIZE_VS_6 | ||
109 | 0x0002819C SQ_ALU_CONST_BUFFER_SIZE_VS_7 | ||
110 | 0x000281A0 SQ_ALU_CONST_BUFFER_SIZE_VS_8 | ||
111 | 0x000281A4 SQ_ALU_CONST_BUFFER_SIZE_VS_9 | ||
112 | 0x000281A8 SQ_ALU_CONST_BUFFER_SIZE_VS_10 | ||
113 | 0x000281AC SQ_ALU_CONST_BUFFER_SIZE_VS_11 | ||
114 | 0x000281B0 SQ_ALU_CONST_BUFFER_SIZE_VS_12 | ||
115 | 0x000281B4 SQ_ALU_CONST_BUFFER_SIZE_VS_13 | ||
116 | 0x000281B8 SQ_ALU_CONST_BUFFER_SIZE_VS_14 | ||
117 | 0x000281BC SQ_ALU_CONST_BUFFER_SIZE_VS_15 | ||
118 | 0x000281C0 SQ_ALU_CONST_BUFFER_SIZE_GS_0 | ||
119 | 0x000281C4 SQ_ALU_CONST_BUFFER_SIZE_GS_1 | ||
120 | 0x000281C8 SQ_ALU_CONST_BUFFER_SIZE_GS_2 | ||
121 | 0x000281CC SQ_ALU_CONST_BUFFER_SIZE_GS_3 | ||
122 | 0x000281D0 SQ_ALU_CONST_BUFFER_SIZE_GS_4 | ||
123 | 0x000281D4 SQ_ALU_CONST_BUFFER_SIZE_GS_5 | ||
124 | 0x000281D8 SQ_ALU_CONST_BUFFER_SIZE_GS_6 | ||
125 | 0x000281DC SQ_ALU_CONST_BUFFER_SIZE_GS_7 | ||
126 | 0x000281E0 SQ_ALU_CONST_BUFFER_SIZE_GS_8 | ||
127 | 0x000281E4 SQ_ALU_CONST_BUFFER_SIZE_GS_9 | ||
128 | 0x000281E8 SQ_ALU_CONST_BUFFER_SIZE_GS_10 | ||
129 | 0x000281EC SQ_ALU_CONST_BUFFER_SIZE_GS_11 | ||
130 | 0x000281F0 SQ_ALU_CONST_BUFFER_SIZE_GS_12 | ||
131 | 0x000281F4 SQ_ALU_CONST_BUFFER_SIZE_GS_13 | ||
132 | 0x000281F8 SQ_ALU_CONST_BUFFER_SIZE_GS_14 | ||
133 | 0x000281FC SQ_ALU_CONST_BUFFER_SIZE_GS_15 | ||
134 | 0x00028200 PA_SC_WINDOW_OFFSET | ||
135 | 0x00028204 PA_SC_WINDOW_SCISSOR_TL | ||
136 | 0x00028208 PA_SC_WINDOW_SCISSOR_BR | ||
137 | 0x0002820C PA_SC_CLIPRECT_RULE | ||
138 | 0x00028210 PA_SC_CLIPRECT_0_TL | ||
139 | 0x00028214 PA_SC_CLIPRECT_0_BR | ||
140 | 0x00028218 PA_SC_CLIPRECT_1_TL | ||
141 | 0x0002821C PA_SC_CLIPRECT_1_BR | ||
142 | 0x00028220 PA_SC_CLIPRECT_2_TL | ||
143 | 0x00028224 PA_SC_CLIPRECT_2_BR | ||
144 | 0x00028228 PA_SC_CLIPRECT_3_TL | ||
145 | 0x0002822C PA_SC_CLIPRECT_3_BR | ||
146 | 0x00028230 PA_SC_EDGERULE | ||
147 | 0x00028234 PA_SU_HARDWARE_SCREEN_OFFSET | ||
148 | 0x00028240 PA_SC_GENERIC_SCISSOR_TL | ||
149 | 0x00028244 PA_SC_GENERIC_SCISSOR_BR | ||
150 | 0x00028250 PA_SC_VPORT_SCISSOR_0_TL | ||
151 | 0x00028254 PA_SC_VPORT_SCISSOR_0_BR | ||
152 | 0x00028258 PA_SC_VPORT_SCISSOR_1_TL | ||
153 | 0x0002825C PA_SC_VPORT_SCISSOR_1_BR | ||
154 | 0x00028260 PA_SC_VPORT_SCISSOR_2_TL | ||
155 | 0x00028264 PA_SC_VPORT_SCISSOR_2_BR | ||
156 | 0x00028268 PA_SC_VPORT_SCISSOR_3_TL | ||
157 | 0x0002826C PA_SC_VPORT_SCISSOR_3_BR | ||
158 | 0x00028270 PA_SC_VPORT_SCISSOR_4_TL | ||
159 | 0x00028274 PA_SC_VPORT_SCISSOR_4_BR | ||
160 | 0x00028278 PA_SC_VPORT_SCISSOR_5_TL | ||
161 | 0x0002827C PA_SC_VPORT_SCISSOR_5_BR | ||
162 | 0x00028280 PA_SC_VPORT_SCISSOR_6_TL | ||
163 | 0x00028284 PA_SC_VPORT_SCISSOR_6_BR | ||
164 | 0x00028288 PA_SC_VPORT_SCISSOR_7_TL | ||
165 | 0x0002828C PA_SC_VPORT_SCISSOR_7_BR | ||
166 | 0x00028290 PA_SC_VPORT_SCISSOR_8_TL | ||
167 | 0x00028294 PA_SC_VPORT_SCISSOR_8_BR | ||
168 | 0x00028298 PA_SC_VPORT_SCISSOR_9_TL | ||
169 | 0x0002829C PA_SC_VPORT_SCISSOR_9_BR | ||
170 | 0x000282A0 PA_SC_VPORT_SCISSOR_10_TL | ||
171 | 0x000282A4 PA_SC_VPORT_SCISSOR_10_BR | ||
172 | 0x000282A8 PA_SC_VPORT_SCISSOR_11_TL | ||
173 | 0x000282AC PA_SC_VPORT_SCISSOR_11_BR | ||
174 | 0x000282B0 PA_SC_VPORT_SCISSOR_12_TL | ||
175 | 0x000282B4 PA_SC_VPORT_SCISSOR_12_BR | ||
176 | 0x000282B8 PA_SC_VPORT_SCISSOR_13_TL | ||
177 | 0x000282BC PA_SC_VPORT_SCISSOR_13_BR | ||
178 | 0x000282C0 PA_SC_VPORT_SCISSOR_14_TL | ||
179 | 0x000282C4 PA_SC_VPORT_SCISSOR_14_BR | ||
180 | 0x000282C8 PA_SC_VPORT_SCISSOR_15_TL | ||
181 | 0x000282CC PA_SC_VPORT_SCISSOR_15_BR | ||
182 | 0x000282D0 PA_SC_VPORT_ZMIN_0 | ||
183 | 0x000282D4 PA_SC_VPORT_ZMAX_0 | ||
184 | 0x000282D8 PA_SC_VPORT_ZMIN_1 | ||
185 | 0x000282DC PA_SC_VPORT_ZMAX_1 | ||
186 | 0x000282E0 PA_SC_VPORT_ZMIN_2 | ||
187 | 0x000282E4 PA_SC_VPORT_ZMAX_2 | ||
188 | 0x000282E8 PA_SC_VPORT_ZMIN_3 | ||
189 | 0x000282EC PA_SC_VPORT_ZMAX_3 | ||
190 | 0x000282F0 PA_SC_VPORT_ZMIN_4 | ||
191 | 0x000282F4 PA_SC_VPORT_ZMAX_4 | ||
192 | 0x000282F8 PA_SC_VPORT_ZMIN_5 | ||
193 | 0x000282FC PA_SC_VPORT_ZMAX_5 | ||
194 | 0x00028300 PA_SC_VPORT_ZMIN_6 | ||
195 | 0x00028304 PA_SC_VPORT_ZMAX_6 | ||
196 | 0x00028308 PA_SC_VPORT_ZMIN_7 | ||
197 | 0x0002830C PA_SC_VPORT_ZMAX_7 | ||
198 | 0x00028310 PA_SC_VPORT_ZMIN_8 | ||
199 | 0x00028314 PA_SC_VPORT_ZMAX_8 | ||
200 | 0x00028318 PA_SC_VPORT_ZMIN_9 | ||
201 | 0x0002831C PA_SC_VPORT_ZMAX_9 | ||
202 | 0x00028320 PA_SC_VPORT_ZMIN_10 | ||
203 | 0x00028324 PA_SC_VPORT_ZMAX_10 | ||
204 | 0x00028328 PA_SC_VPORT_ZMIN_11 | ||
205 | 0x0002832C PA_SC_VPORT_ZMAX_11 | ||
206 | 0x00028330 PA_SC_VPORT_ZMIN_12 | ||
207 | 0x00028334 PA_SC_VPORT_ZMAX_12 | ||
208 | 0x00028338 PA_SC_VPORT_ZMIN_13 | ||
209 | 0x0002833C PA_SC_VPORT_ZMAX_13 | ||
210 | 0x00028340 PA_SC_VPORT_ZMIN_14 | ||
211 | 0x00028344 PA_SC_VPORT_ZMAX_14 | ||
212 | 0x00028348 PA_SC_VPORT_ZMIN_15 | ||
213 | 0x0002834C PA_SC_VPORT_ZMAX_15 | ||
214 | 0x00028350 SX_MISC | ||
215 | 0x00028380 SQ_VTX_SEMANTIC_0 | ||
216 | 0x00028384 SQ_VTX_SEMANTIC_1 | ||
217 | 0x00028388 SQ_VTX_SEMANTIC_2 | ||
218 | 0x0002838C SQ_VTX_SEMANTIC_3 | ||
219 | 0x00028390 SQ_VTX_SEMANTIC_4 | ||
220 | 0x00028394 SQ_VTX_SEMANTIC_5 | ||
221 | 0x00028398 SQ_VTX_SEMANTIC_6 | ||
222 | 0x0002839C SQ_VTX_SEMANTIC_7 | ||
223 | 0x000283A0 SQ_VTX_SEMANTIC_8 | ||
224 | 0x000283A4 SQ_VTX_SEMANTIC_9 | ||
225 | 0x000283A8 SQ_VTX_SEMANTIC_10 | ||
226 | 0x000283AC SQ_VTX_SEMANTIC_11 | ||
227 | 0x000283B0 SQ_VTX_SEMANTIC_12 | ||
228 | 0x000283B4 SQ_VTX_SEMANTIC_13 | ||
229 | 0x000283B8 SQ_VTX_SEMANTIC_14 | ||
230 | 0x000283BC SQ_VTX_SEMANTIC_15 | ||
231 | 0x000283C0 SQ_VTX_SEMANTIC_16 | ||
232 | 0x000283C4 SQ_VTX_SEMANTIC_17 | ||
233 | 0x000283C8 SQ_VTX_SEMANTIC_18 | ||
234 | 0x000283CC SQ_VTX_SEMANTIC_19 | ||
235 | 0x000283D0 SQ_VTX_SEMANTIC_20 | ||
236 | 0x000283D4 SQ_VTX_SEMANTIC_21 | ||
237 | 0x000283D8 SQ_VTX_SEMANTIC_22 | ||
238 | 0x000283DC SQ_VTX_SEMANTIC_23 | ||
239 | 0x000283E0 SQ_VTX_SEMANTIC_24 | ||
240 | 0x000283E4 SQ_VTX_SEMANTIC_25 | ||
241 | 0x000283E8 SQ_VTX_SEMANTIC_26 | ||
242 | 0x000283EC SQ_VTX_SEMANTIC_27 | ||
243 | 0x000283F0 SQ_VTX_SEMANTIC_28 | ||
244 | 0x000283F4 SQ_VTX_SEMANTIC_29 | ||
245 | 0x000283F8 SQ_VTX_SEMANTIC_30 | ||
246 | 0x000283FC SQ_VTX_SEMANTIC_31 | ||
247 | 0x00028400 VGT_MAX_VTX_INDX | ||
248 | 0x00028404 VGT_MIN_VTX_INDX | ||
249 | 0x00028408 VGT_INDX_OFFSET | ||
250 | 0x0002840C VGT_MULTI_PRIM_IB_RESET_INDX | ||
251 | 0x00028410 SX_ALPHA_TEST_CONTROL | ||
252 | 0x00028414 CB_BLEND_RED | ||
253 | 0x00028418 CB_BLEND_GREEN | ||
254 | 0x0002841C CB_BLEND_BLUE | ||
255 | 0x00028420 CB_BLEND_ALPHA | ||
256 | 0x00028430 DB_STENCILREFMASK | ||
257 | 0x00028434 DB_STENCILREFMASK_BF | ||
258 | 0x00028438 SX_ALPHA_REF | ||
259 | 0x0002843C PA_CL_VPORT_XSCALE_0 | ||
260 | 0x00028440 PA_CL_VPORT_XOFFSET_0 | ||
261 | 0x00028444 PA_CL_VPORT_YSCALE_0 | ||
262 | 0x00028448 PA_CL_VPORT_YOFFSET_0 | ||
263 | 0x0002844C PA_CL_VPORT_ZSCALE_0 | ||
264 | 0x00028450 PA_CL_VPORT_ZOFFSET_0 | ||
265 | 0x00028454 PA_CL_VPORT_XSCALE_1 | ||
266 | 0x00028458 PA_CL_VPORT_XOFFSET_1 | ||
267 | 0x0002845C PA_CL_VPORT_YSCALE_1 | ||
268 | 0x00028460 PA_CL_VPORT_YOFFSET_1 | ||
269 | 0x00028464 PA_CL_VPORT_ZSCALE_1 | ||
270 | 0x00028468 PA_CL_VPORT_ZOFFSET_1 | ||
271 | 0x0002846C PA_CL_VPORT_XSCALE_2 | ||
272 | 0x00028470 PA_CL_VPORT_XOFFSET_2 | ||
273 | 0x00028474 PA_CL_VPORT_YSCALE_2 | ||
274 | 0x00028478 PA_CL_VPORT_YOFFSET_2 | ||
275 | 0x0002847C PA_CL_VPORT_ZSCALE_2 | ||
276 | 0x00028480 PA_CL_VPORT_ZOFFSET_2 | ||
277 | 0x00028484 PA_CL_VPORT_XSCALE_3 | ||
278 | 0x00028488 PA_CL_VPORT_XOFFSET_3 | ||
279 | 0x0002848C PA_CL_VPORT_YSCALE_3 | ||
280 | 0x00028490 PA_CL_VPORT_YOFFSET_3 | ||
281 | 0x00028494 PA_CL_VPORT_ZSCALE_3 | ||
282 | 0x00028498 PA_CL_VPORT_ZOFFSET_3 | ||
283 | 0x0002849C PA_CL_VPORT_XSCALE_4 | ||
284 | 0x000284A0 PA_CL_VPORT_XOFFSET_4 | ||
285 | 0x000284A4 PA_CL_VPORT_YSCALE_4 | ||
286 | 0x000284A8 PA_CL_VPORT_YOFFSET_4 | ||
287 | 0x000284AC PA_CL_VPORT_ZSCALE_4 | ||
288 | 0x000284B0 PA_CL_VPORT_ZOFFSET_4 | ||
289 | 0x000284B4 PA_CL_VPORT_XSCALE_5 | ||
290 | 0x000284B8 PA_CL_VPORT_XOFFSET_5 | ||
291 | 0x000284BC PA_CL_VPORT_YSCALE_5 | ||
292 | 0x000284C0 PA_CL_VPORT_YOFFSET_5 | ||
293 | 0x000284C4 PA_CL_VPORT_ZSCALE_5 | ||
294 | 0x000284C8 PA_CL_VPORT_ZOFFSET_5 | ||
295 | 0x000284CC PA_CL_VPORT_XSCALE_6 | ||
296 | 0x000284D0 PA_CL_VPORT_XOFFSET_6 | ||
297 | 0x000284D4 PA_CL_VPORT_YSCALE_6 | ||
298 | 0x000284D8 PA_CL_VPORT_YOFFSET_6 | ||
299 | 0x000284DC PA_CL_VPORT_ZSCALE_6 | ||
300 | 0x000284E0 PA_CL_VPORT_ZOFFSET_6 | ||
301 | 0x000284E4 PA_CL_VPORT_XSCALE_7 | ||
302 | 0x000284E8 PA_CL_VPORT_XOFFSET_7 | ||
303 | 0x000284EC PA_CL_VPORT_YSCALE_7 | ||
304 | 0x000284F0 PA_CL_VPORT_YOFFSET_7 | ||
305 | 0x000284F4 PA_CL_VPORT_ZSCALE_7 | ||
306 | 0x000284F8 PA_CL_VPORT_ZOFFSET_7 | ||
307 | 0x000284FC PA_CL_VPORT_XSCALE_8 | ||
308 | 0x00028500 PA_CL_VPORT_XOFFSET_8 | ||
309 | 0x00028504 PA_CL_VPORT_YSCALE_8 | ||
310 | 0x00028508 PA_CL_VPORT_YOFFSET_8 | ||
311 | 0x0002850C PA_CL_VPORT_ZSCALE_8 | ||
312 | 0x00028510 PA_CL_VPORT_ZOFFSET_8 | ||
313 | 0x00028514 PA_CL_VPORT_XSCALE_9 | ||
314 | 0x00028518 PA_CL_VPORT_XOFFSET_9 | ||
315 | 0x0002851C PA_CL_VPORT_YSCALE_9 | ||
316 | 0x00028520 PA_CL_VPORT_YOFFSET_9 | ||
317 | 0x00028524 PA_CL_VPORT_ZSCALE_9 | ||
318 | 0x00028528 PA_CL_VPORT_ZOFFSET_9 | ||
319 | 0x0002852C PA_CL_VPORT_XSCALE_10 | ||
320 | 0x00028530 PA_CL_VPORT_XOFFSET_10 | ||
321 | 0x00028534 PA_CL_VPORT_YSCALE_10 | ||
322 | 0x00028538 PA_CL_VPORT_YOFFSET_10 | ||
323 | 0x0002853C PA_CL_VPORT_ZSCALE_10 | ||
324 | 0x00028540 PA_CL_VPORT_ZOFFSET_10 | ||
325 | 0x00028544 PA_CL_VPORT_XSCALE_11 | ||
326 | 0x00028548 PA_CL_VPORT_XOFFSET_11 | ||
327 | 0x0002854C PA_CL_VPORT_YSCALE_11 | ||
328 | 0x00028550 PA_CL_VPORT_YOFFSET_11 | ||
329 | 0x00028554 PA_CL_VPORT_ZSCALE_11 | ||
330 | 0x00028558 PA_CL_VPORT_ZOFFSET_11 | ||
331 | 0x0002855C PA_CL_VPORT_XSCALE_12 | ||
332 | 0x00028560 PA_CL_VPORT_XOFFSET_12 | ||
333 | 0x00028564 PA_CL_VPORT_YSCALE_12 | ||
334 | 0x00028568 PA_CL_VPORT_YOFFSET_12 | ||
335 | 0x0002856C PA_CL_VPORT_ZSCALE_12 | ||
336 | 0x00028570 PA_CL_VPORT_ZOFFSET_12 | ||
337 | 0x00028574 PA_CL_VPORT_XSCALE_13 | ||
338 | 0x00028578 PA_CL_VPORT_XOFFSET_13 | ||
339 | 0x0002857C PA_CL_VPORT_YSCALE_13 | ||
340 | 0x00028580 PA_CL_VPORT_YOFFSET_13 | ||
341 | 0x00028584 PA_CL_VPORT_ZSCALE_13 | ||
342 | 0x00028588 PA_CL_VPORT_ZOFFSET_13 | ||
343 | 0x0002858C PA_CL_VPORT_XSCALE_14 | ||
344 | 0x00028590 PA_CL_VPORT_XOFFSET_14 | ||
345 | 0x00028594 PA_CL_VPORT_YSCALE_14 | ||
346 | 0x00028598 PA_CL_VPORT_YOFFSET_14 | ||
347 | 0x0002859C PA_CL_VPORT_ZSCALE_14 | ||
348 | 0x000285A0 PA_CL_VPORT_ZOFFSET_14 | ||
349 | 0x000285A4 PA_CL_VPORT_XSCALE_15 | ||
350 | 0x000285A8 PA_CL_VPORT_XOFFSET_15 | ||
351 | 0x000285AC PA_CL_VPORT_YSCALE_15 | ||
352 | 0x000285B0 PA_CL_VPORT_YOFFSET_15 | ||
353 | 0x000285B4 PA_CL_VPORT_ZSCALE_15 | ||
354 | 0x000285B8 PA_CL_VPORT_ZOFFSET_15 | ||
355 | 0x000285BC PA_CL_UCP_0_X | ||
356 | 0x000285C0 PA_CL_UCP_0_Y | ||
357 | 0x000285C4 PA_CL_UCP_0_Z | ||
358 | 0x000285C8 PA_CL_UCP_0_W | ||
359 | 0x000285CC PA_CL_UCP_1_X | ||
360 | 0x000285D0 PA_CL_UCP_1_Y | ||
361 | 0x000285D4 PA_CL_UCP_1_Z | ||
362 | 0x000285D8 PA_CL_UCP_1_W | ||
363 | 0x000285DC PA_CL_UCP_2_X | ||
364 | 0x000285E0 PA_CL_UCP_2_Y | ||
365 | 0x000285E4 PA_CL_UCP_2_Z | ||
366 | 0x000285E8 PA_CL_UCP_2_W | ||
367 | 0x000285EC PA_CL_UCP_3_X | ||
368 | 0x000285F0 PA_CL_UCP_3_Y | ||
369 | 0x000285F4 PA_CL_UCP_3_Z | ||
370 | 0x000285F8 PA_CL_UCP_3_W | ||
371 | 0x000285FC PA_CL_UCP_4_X | ||
372 | 0x00028600 PA_CL_UCP_4_Y | ||
373 | 0x00028604 PA_CL_UCP_4_Z | ||
374 | 0x00028608 PA_CL_UCP_4_W | ||
375 | 0x0002860C PA_CL_UCP_5_X | ||
376 | 0x00028610 PA_CL_UCP_5_Y | ||
377 | 0x00028614 PA_CL_UCP_5_Z | ||
378 | 0x00028618 PA_CL_UCP_5_W | ||
379 | 0x0002861C SPI_VS_OUT_ID_0 | ||
380 | 0x00028620 SPI_VS_OUT_ID_1 | ||
381 | 0x00028624 SPI_VS_OUT_ID_2 | ||
382 | 0x00028628 SPI_VS_OUT_ID_3 | ||
383 | 0x0002862C SPI_VS_OUT_ID_4 | ||
384 | 0x00028630 SPI_VS_OUT_ID_5 | ||
385 | 0x00028634 SPI_VS_OUT_ID_6 | ||
386 | 0x00028638 SPI_VS_OUT_ID_7 | ||
387 | 0x0002863C SPI_VS_OUT_ID_8 | ||
388 | 0x00028640 SPI_VS_OUT_ID_9 | ||
389 | 0x00028644 SPI_PS_INPUT_CNTL_0 | ||
390 | 0x00028648 SPI_PS_INPUT_CNTL_1 | ||
391 | 0x0002864C SPI_PS_INPUT_CNTL_2 | ||
392 | 0x00028650 SPI_PS_INPUT_CNTL_3 | ||
393 | 0x00028654 SPI_PS_INPUT_CNTL_4 | ||
394 | 0x00028658 SPI_PS_INPUT_CNTL_5 | ||
395 | 0x0002865C SPI_PS_INPUT_CNTL_6 | ||
396 | 0x00028660 SPI_PS_INPUT_CNTL_7 | ||
397 | 0x00028664 SPI_PS_INPUT_CNTL_8 | ||
398 | 0x00028668 SPI_PS_INPUT_CNTL_9 | ||
399 | 0x0002866C SPI_PS_INPUT_CNTL_10 | ||
400 | 0x00028670 SPI_PS_INPUT_CNTL_11 | ||
401 | 0x00028674 SPI_PS_INPUT_CNTL_12 | ||
402 | 0x00028678 SPI_PS_INPUT_CNTL_13 | ||
403 | 0x0002867C SPI_PS_INPUT_CNTL_14 | ||
404 | 0x00028680 SPI_PS_INPUT_CNTL_15 | ||
405 | 0x00028684 SPI_PS_INPUT_CNTL_16 | ||
406 | 0x00028688 SPI_PS_INPUT_CNTL_17 | ||
407 | 0x0002868C SPI_PS_INPUT_CNTL_18 | ||
408 | 0x00028690 SPI_PS_INPUT_CNTL_19 | ||
409 | 0x00028694 SPI_PS_INPUT_CNTL_20 | ||
410 | 0x00028698 SPI_PS_INPUT_CNTL_21 | ||
411 | 0x0002869C SPI_PS_INPUT_CNTL_22 | ||
412 | 0x000286A0 SPI_PS_INPUT_CNTL_23 | ||
413 | 0x000286A4 SPI_PS_INPUT_CNTL_24 | ||
414 | 0x000286A8 SPI_PS_INPUT_CNTL_25 | ||
415 | 0x000286AC SPI_PS_INPUT_CNTL_26 | ||
416 | 0x000286B0 SPI_PS_INPUT_CNTL_27 | ||
417 | 0x000286B4 SPI_PS_INPUT_CNTL_28 | ||
418 | 0x000286B8 SPI_PS_INPUT_CNTL_29 | ||
419 | 0x000286BC SPI_PS_INPUT_CNTL_30 | ||
420 | 0x000286C0 SPI_PS_INPUT_CNTL_31 | ||
421 | 0x000286C4 SPI_VS_OUT_CONFIG | ||
422 | 0x000286C8 SPI_THREAD_GROUPING | ||
423 | 0x000286CC SPI_PS_IN_CONTROL_0 | ||
424 | 0x000286D0 SPI_PS_IN_CONTROL_1 | ||
425 | 0x000286D4 SPI_INTERP_CONTROL_0 | ||
426 | 0x000286D8 SPI_INPUT_Z | ||
427 | 0x000286DC SPI_FOG_CNTL | ||
428 | 0x000286E0 SPI_BARYC_CNTL | ||
429 | 0x000286E4 SPI_PS_IN_CONTROL_2 | ||
430 | 0x000286E8 SPI_COMPUTE_INPUT_CNTL | ||
431 | 0x000286EC SPI_COMPUTE_NUM_THREAD_X | ||
432 | 0x000286F0 SPI_COMPUTE_NUM_THREAD_Y | ||
433 | 0x000286F4 SPI_COMPUTE_NUM_THREAD_Z | ||
434 | 0x000286F8 GDS_ADDR_SIZE | ||
435 | 0x00028780 CB_BLEND0_CONTROL | ||
436 | 0x00028784 CB_BLEND1_CONTROL | ||
437 | 0x00028788 CB_BLEND2_CONTROL | ||
438 | 0x0002878C CB_BLEND3_CONTROL | ||
439 | 0x00028790 CB_BLEND4_CONTROL | ||
440 | 0x00028794 CB_BLEND5_CONTROL | ||
441 | 0x00028798 CB_BLEND6_CONTROL | ||
442 | 0x0002879C CB_BLEND7_CONTROL | ||
443 | 0x000287CC CS_COPY_STATE | ||
444 | 0x000287D0 GFX_COPY_STATE | ||
445 | 0x000287D4 PA_CL_POINT_X_RAD | ||
446 | 0x000287D8 PA_CL_POINT_Y_RAD | ||
447 | 0x000287DC PA_CL_POINT_SIZE | ||
448 | 0x000287E0 PA_CL_POINT_CULL_RAD | ||
449 | 0x00028808 CB_COLOR_CONTROL | ||
450 | 0x0002880C DB_SHADER_CONTROL | ||
451 | 0x00028810 PA_CL_CLIP_CNTL | ||
452 | 0x00028814 PA_SU_SC_MODE_CNTL | ||
453 | 0x00028818 PA_CL_VTE_CNTL | ||
454 | 0x0002881C PA_CL_VS_OUT_CNTL | ||
455 | 0x00028820 PA_CL_NANINF_CNTL | ||
456 | 0x00028824 PA_SU_LINE_STIPPLE_CNTL | ||
457 | 0x00028828 PA_SU_LINE_STIPPLE_SCALE | ||
458 | 0x0002882C PA_SU_PRIM_FILTER_CNTL | ||
459 | 0x00028838 SQ_DYN_GPR_RESOURCE_LIMIT_1 | ||
460 | 0x00028844 SQ_PGM_RESOURCES_PS | ||
461 | 0x00028848 SQ_PGM_RESOURCES_2_PS | ||
462 | 0x0002884C SQ_PGM_EXPORTS_PS | ||
463 | 0x0002885C SQ_PGM_RESOURCES_VS | ||
464 | 0x00028860 SQ_PGM_RESOURCES_2_VS | ||
465 | 0x00028878 SQ_PGM_RESOURCES_GS | ||
466 | 0x0002887C SQ_PGM_RESOURCES_2_GS | ||
467 | 0x00028890 SQ_PGM_RESOURCES_ES | ||
468 | 0x00028894 SQ_PGM_RESOURCES_2_ES | ||
469 | 0x000288A8 SQ_PGM_RESOURCES_FS | ||
470 | 0x000288BC SQ_PGM_RESOURCES_HS | ||
471 | 0x000288C0 SQ_PGM_RESOURCES_2_HS | ||
472 | 0x000288D0 SQ_PGM_RESOURCES_LS | ||
473 | 0x000288D4 SQ_PGM_RESOURCES_2_LS | ||
474 | 0x000288E8 SQ_LDS_ALLOC | ||
475 | 0x000288EC SQ_LDS_ALLOC_PS | ||
476 | 0x000288F0 SQ_VTX_SEMANTIC_CLEAR | ||
477 | 0x00028A00 PA_SU_POINT_SIZE | ||
478 | 0x00028A04 PA_SU_POINT_MINMAX | ||
479 | 0x00028A08 PA_SU_LINE_CNTL | ||
480 | 0x00028A0C PA_SC_LINE_STIPPLE | ||
481 | 0x00028A10 VGT_OUTPUT_PATH_CNTL | ||
482 | 0x00028A14 VGT_HOS_CNTL | ||
483 | 0x00028A18 VGT_HOS_MAX_TESS_LEVEL | ||
484 | 0x00028A1C VGT_HOS_MIN_TESS_LEVEL | ||
485 | 0x00028A20 VGT_HOS_REUSE_DEPTH | ||
486 | 0x00028A24 VGT_GROUP_PRIM_TYPE | ||
487 | 0x00028A28 VGT_GROUP_FIRST_DECR | ||
488 | 0x00028A2C VGT_GROUP_DECR | ||
489 | 0x00028A30 VGT_GROUP_VECT_0_CNTL | ||
490 | 0x00028A34 VGT_GROUP_VECT_1_CNTL | ||
491 | 0x00028A38 VGT_GROUP_VECT_0_FMT_CNTL | ||
492 | 0x00028A3C VGT_GROUP_VECT_1_FMT_CNTL | ||
493 | 0x00028A40 VGT_GS_MODE | ||
494 | 0x00028A48 PA_SC_MODE_CNTL_0 | ||
495 | 0x00028A4C PA_SC_MODE_CNTL_1 | ||
496 | 0x00028A50 VGT_ENHANCE | ||
497 | 0x00028A54 VGT_GS_PER_ES | ||
498 | 0x00028A58 VGT_ES_PER_GS | ||
499 | 0x00028A5C VGT_GS_PER_VS | ||
500 | 0x00028A6C VGT_GS_OUT_PRIM_TYPE | ||
501 | 0x00028A84 VGT_PRIMITIVEID_EN | ||
502 | 0x00028A94 VGT_MULTI_PRIM_IB_RESET_EN | ||
503 | 0x00028AA0 VGT_INSTANCE_STEP_RATE_0 | ||
504 | 0x00028AA4 VGT_INSTANCE_STEP_RATE_1 | ||
505 | 0x00028AB4 VGT_REUSE_OFF | ||
506 | 0x00028AB8 VGT_VTX_CNT_EN | ||
507 | 0x00028ABC DB_HTILE_SURFACE | ||
508 | 0x00028AC0 DB_SRESULTS_COMPARE_STATE0 | ||
509 | 0x00028AC4 DB_SRESULTS_COMPARE_STATE1 | ||
510 | 0x00028AC8 DB_PRELOAD_CONTROL | ||
511 | 0x00028B38 VGT_GS_MAX_VERT_OUT | ||
512 | 0x00028B54 VGT_SHADER_STAGES_EN | ||
513 | 0x00028B58 VGT_LS_HS_CONFIG | ||
514 | 0x00028B5C VGT_LS_SIZE | ||
515 | 0x00028B60 VGT_HS_SIZE | ||
516 | 0x00028B64 VGT_LS_HS_ALLOC | ||
517 | 0x00028B68 VGT_HS_PATCH_CONST | ||
518 | 0x00028B6C VGT_TF_PARAM | ||
519 | 0x00028B70 DB_ALPHA_TO_MASK | ||
520 | 0x00028B74 VGT_DISPATCH_INITIATOR | ||
521 | 0x00028B78 PA_SU_POLY_OFFSET_DB_FMT_CNTL | ||
522 | 0x00028B7C PA_SU_POLY_OFFSET_CLAMP | ||
523 | 0x00028B80 PA_SU_POLY_OFFSET_FRONT_SCALE | ||
524 | 0x00028B84 PA_SU_POLY_OFFSET_FRONT_OFFSET | ||
525 | 0x00028B88 PA_SU_POLY_OFFSET_BACK_SCALE | ||
526 | 0x00028B8C PA_SU_POLY_OFFSET_BACK_OFFSET | ||
527 | 0x00028B74 VGT_GS_INSTANCE_CNT | ||
528 | 0x00028C00 PA_SC_LINE_CNTL | ||
529 | 0x00028C08 PA_SU_VTX_CNTL | ||
530 | 0x00028C0C PA_CL_GB_VERT_CLIP_ADJ | ||
531 | 0x00028C10 PA_CL_GB_VERT_DISC_ADJ | ||
532 | 0x00028C14 PA_CL_GB_HORZ_CLIP_ADJ | ||
533 | 0x00028C18 PA_CL_GB_HORZ_DISC_ADJ | ||
534 | 0x00028C1C PA_SC_AA_SAMPLE_LOCS_0 | ||
535 | 0x00028C20 PA_SC_AA_SAMPLE_LOCS_1 | ||
536 | 0x00028C24 PA_SC_AA_SAMPLE_LOCS_2 | ||
537 | 0x00028C28 PA_SC_AA_SAMPLE_LOCS_3 | ||
538 | 0x00028C2C PA_SC_AA_SAMPLE_LOCS_4 | ||
539 | 0x00028C30 PA_SC_AA_SAMPLE_LOCS_5 | ||
540 | 0x00028C34 PA_SC_AA_SAMPLE_LOCS_6 | ||
541 | 0x00028C38 PA_SC_AA_SAMPLE_LOCS_7 | ||
542 | 0x00028C3C PA_SC_AA_MASK | ||
543 | 0x00028C8C CB_COLOR0_CLEAR_WORD0 | ||
544 | 0x00028C90 CB_COLOR0_CLEAR_WORD1 | ||
545 | 0x00028C94 CB_COLOR0_CLEAR_WORD2 | ||
546 | 0x00028C98 CB_COLOR0_CLEAR_WORD3 | ||
547 | 0x00028CC8 CB_COLOR1_CLEAR_WORD0 | ||
548 | 0x00028CCC CB_COLOR1_CLEAR_WORD1 | ||
549 | 0x00028CD0 CB_COLOR1_CLEAR_WORD2 | ||
550 | 0x00028CD4 CB_COLOR1_CLEAR_WORD3 | ||
551 | 0x00028D04 CB_COLOR2_CLEAR_WORD0 | ||
552 | 0x00028D08 CB_COLOR2_CLEAR_WORD1 | ||
553 | 0x00028D0C CB_COLOR2_CLEAR_WORD2 | ||
554 | 0x00028D10 CB_COLOR2_CLEAR_WORD3 | ||
555 | 0x00028D40 CB_COLOR3_CLEAR_WORD0 | ||
556 | 0x00028D44 CB_COLOR3_CLEAR_WORD1 | ||
557 | 0x00028D48 CB_COLOR3_CLEAR_WORD2 | ||
558 | 0x00028D4C CB_COLOR3_CLEAR_WORD3 | ||
559 | 0x00028D7C CB_COLOR4_CLEAR_WORD0 | ||
560 | 0x00028D80 CB_COLOR4_CLEAR_WORD1 | ||
561 | 0x00028D84 CB_COLOR4_CLEAR_WORD2 | ||
562 | 0x00028D88 CB_COLOR4_CLEAR_WORD3 | ||
563 | 0x00028DB8 CB_COLOR5_CLEAR_WORD0 | ||
564 | 0x00028DBC CB_COLOR5_CLEAR_WORD1 | ||
565 | 0x00028DC0 CB_COLOR5_CLEAR_WORD2 | ||
566 | 0x00028DC4 CB_COLOR5_CLEAR_WORD3 | ||
567 | 0x00028DF4 CB_COLOR6_CLEAR_WORD0 | ||
568 | 0x00028DF8 CB_COLOR6_CLEAR_WORD1 | ||
569 | 0x00028DFC CB_COLOR6_CLEAR_WORD2 | ||
570 | 0x00028E00 CB_COLOR6_CLEAR_WORD3 | ||
571 | 0x00028E30 CB_COLOR7_CLEAR_WORD0 | ||
572 | 0x00028E34 CB_COLOR7_CLEAR_WORD1 | ||
573 | 0x00028E38 CB_COLOR7_CLEAR_WORD2 | ||
574 | 0x00028E3C CB_COLOR7_CLEAR_WORD3 | ||
575 | 0x00028F80 SQ_ALU_CONST_BUFFER_SIZE_HS_0 | ||
576 | 0x00028F84 SQ_ALU_CONST_BUFFER_SIZE_HS_1 | ||
577 | 0x00028F88 SQ_ALU_CONST_BUFFER_SIZE_HS_2 | ||
578 | 0x00028F8C SQ_ALU_CONST_BUFFER_SIZE_HS_3 | ||
579 | 0x00028F90 SQ_ALU_CONST_BUFFER_SIZE_HS_4 | ||
580 | 0x00028F94 SQ_ALU_CONST_BUFFER_SIZE_HS_5 | ||
581 | 0x00028F98 SQ_ALU_CONST_BUFFER_SIZE_HS_6 | ||
582 | 0x00028F9C SQ_ALU_CONST_BUFFER_SIZE_HS_7 | ||
583 | 0x00028FA0 SQ_ALU_CONST_BUFFER_SIZE_HS_8 | ||
584 | 0x00028FA4 SQ_ALU_CONST_BUFFER_SIZE_HS_9 | ||
585 | 0x00028FA8 SQ_ALU_CONST_BUFFER_SIZE_HS_10 | ||
586 | 0x00028FAC SQ_ALU_CONST_BUFFER_SIZE_HS_11 | ||
587 | 0x00028FB0 SQ_ALU_CONST_BUFFER_SIZE_HS_12 | ||
588 | 0x00028FB4 SQ_ALU_CONST_BUFFER_SIZE_HS_13 | ||
589 | 0x00028FB8 SQ_ALU_CONST_BUFFER_SIZE_HS_14 | ||
590 | 0x00028FBC SQ_ALU_CONST_BUFFER_SIZE_HS_15 | ||
591 | 0x00028FC0 SQ_ALU_CONST_BUFFER_SIZE_LS_0 | ||
592 | 0x00028FC4 SQ_ALU_CONST_BUFFER_SIZE_LS_1 | ||
593 | 0x00028FC8 SQ_ALU_CONST_BUFFER_SIZE_LS_2 | ||
594 | 0x00028FCC SQ_ALU_CONST_BUFFER_SIZE_LS_3 | ||
595 | 0x00028FD0 SQ_ALU_CONST_BUFFER_SIZE_LS_4 | ||
596 | 0x00028FD4 SQ_ALU_CONST_BUFFER_SIZE_LS_5 | ||
597 | 0x00028FD8 SQ_ALU_CONST_BUFFER_SIZE_LS_6 | ||
598 | 0x00028FDC SQ_ALU_CONST_BUFFER_SIZE_LS_7 | ||
599 | 0x00028FE0 SQ_ALU_CONST_BUFFER_SIZE_LS_8 | ||
600 | 0x00028FE4 SQ_ALU_CONST_BUFFER_SIZE_LS_9 | ||
601 | 0x00028FE8 SQ_ALU_CONST_BUFFER_SIZE_LS_10 | ||
602 | 0x00028FEC SQ_ALU_CONST_BUFFER_SIZE_LS_11 | ||
603 | 0x00028FF0 SQ_ALU_CONST_BUFFER_SIZE_LS_12 | ||
604 | 0x00028FF4 SQ_ALU_CONST_BUFFER_SIZE_LS_13 | ||
605 | 0x00028FF8 SQ_ALU_CONST_BUFFER_SIZE_LS_14 | ||
606 | 0x00028FFC SQ_ALU_CONST_BUFFER_SIZE_LS_15 | ||
607 | 0x0003CFF0 SQ_VTX_BASE_VTX_LOC | ||
608 | 0x0003CFF4 SQ_VTX_START_INST_LOC | ||
609 | 0x0003FF00 SQ_TEX_SAMPLER_CLEAR | ||
610 | 0x0003FF04 SQ_TEX_RESOURCE_CLEAR | ||
611 | 0x0003FF08 SQ_LOOP_BOOL_CLEAR | ||