2
* Copyright © 2022 Imagination Technologies Ltd.
4
* Permission is hereby granted, free of charge, to any person obtaining a copy
5
* of this software and associated documentation files (the "Software"), to deal
6
* in the Software without restriction, including without limitation the rights
7
* to use, copy, modify, merge, publish, distribute, sublicense, and/or sell
8
* copies of the Software, and to permit persons to whom the Software is
9
* furnished to do so, subject to the following conditions:
11
* The above copyright notice and this permission notice (including the next
12
* paragraph) shall be included in all copies or substantial portions of the
15
* THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR
16
* IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY,
17
* FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE
18
* AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER
19
* LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM,
20
* OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN THE
24
#ifndef PVR_DRAW_INDIRECTELEMENTS2_H
25
#define PVR_DRAW_INDIRECTELEMENTS2_H
27
/* Initially generated from ARB_draw_indirect_elements.pds */
29
static const uint32_t pvr_draw_indirect_elements2_code[21] = {
30
0xd0000000, /* LD const[0].64: dst(?) <= mem(?) */
32
0x9000a160, /* ADD32 ptemp[0].32 = const[2].32 + temp[5].32 */
33
0x04201820, /* MAD temp[0].64 = (temp[4].32 * const[3].32) +
35
0x53083006, /* SFTLP32 temp[6].32 = (temp[1].32 | const[6].32) << 0
37
0x50040007, /* SFTLP32 temp[7].32 = temp[0].32 << 0 */
38
0x04183840, /* MAD temp[0].64 = (temp[3].32 * const[7].32) +
40
0x50040003, /* SFTLP32 temp[3].32 = temp[0].32 << 0 */
41
0x50141008, /* SFTLP32 temp[8].32 = temp[2].32 << 0 */
42
0x9120c289, /* ADD32 temp[9].32 = temp[3].32 - const[10].32 */
43
0x502c280a, /* SFTLP32 temp[10].32 = temp[5].32 << 0 */
44
0xc8000001, /* BRA if keep 1 ( setc = p0 ) */
45
0xd1840000, /* LIMM temp[1].32 = 0000 */
46
0x501c1800, /* SFTLP32 temp[0].32 = temp[3].32 << 0 */
47
0xb1800000, /* CMP P0 = (temp[0].64 = 0000) */
48
0xd9a00000, /* LIMM ? temp[8].32 = 0000 */
49
0xd9a40000, /* LIMM ? temp[9].32 = 0000 */
50
0xd0800006, /* ST const[12].64: mem(?) <= src(?) */
51
0xd0000007, /* LD const[14].64: dst(?) <= mem(?) */
53
0xf4024003, /* DOUT doutv = temp[0].64, const[2].32; HALT */
56
static const struct pvr_psc_program_output pvr_draw_indirect_elements2_program = {
57
pvr_draw_indirect_elements2_code, /* code segment */
58
0, /* constant mappings, zeroed since we use the macros below */
59
7, /* number of constant mappings */
61
16, /* size of data segment, in dwords, aligned to 4 */
62
24, /* size of code segment, in dwords, aligned to 4 */
63
20, /* size of temp segment, in dwords, aligned to 4 */
64
16, /* size of data segment, in dwords */
65
21, /* size of code segment, in dwords */
66
18, /* size of temp segment, in dwords */
67
NULL /* function pointer to write data segment */
70
#define pvr_write_draw_indirect_elements2_di_data(buffer, addr, device) \
72
uint64_t data = ((addr) | (0x60000000000ULL) | \
73
ENABLE_SLC_MCU_CACHE_CONTROLS(device)); \
74
PVR_PDS_PRINT_DATA("DRAW_INDIRECT_ELEMENTS", data, 0); \
75
memcpy(buffer + 0, &data, sizeof(data)); \
77
#define pvr_write_draw_indirect_elements2_write_vdm(buffer, addr) \
79
uint64_t data = ((addr) | (0x1850000000000ULL)); \
80
PVR_PDS_PRINT_DATA("DRAW_INDIRECT_ELEMENTS", data, 0); \
81
memcpy(buffer + 12, &data, sizeof(data)); \
83
#define pvr_write_draw_indirect_elements2_flush_vdm(buffer, addr) \
85
uint64_t data = ((addr) | (0x3160000000000ULL)); \
86
PVR_PDS_PRINT_DATA("DRAW_INDIRECT_ELEMENTS", data, 0); \
87
memcpy(buffer + 14, &data, sizeof(data)); \
89
#define pvr_write_draw_indirect_elements2_idx_stride(buffer, value) \
91
uint32_t data = value; \
92
PVR_PDS_PRINT_DATA("DRAW_INDIRECT_ELEMENTS", data, 0); \
93
memcpy(buffer + 3, &data, sizeof(data)); \
95
#define pvr_write_draw_indirect_elements2_idx_base(buffer, value) \
97
uint64_t data = value; \
98
PVR_PDS_PRINT_DATA("DRAW_INDIRECT_ELEMENTS", data, 0); \
99
memcpy(buffer + 4, &data, sizeof(data)); \
101
#define pvr_write_draw_indirect_elements2_idx_header(buffer, value) \
103
uint32_t data = value; \
104
PVR_PDS_PRINT_DATA("DRAW_INDIRECT_ELEMENTS", data, 0); \
105
memcpy(buffer + 6, &data, sizeof(data)); \
107
#define pvr_write_draw_indirect_elements2_num_views(buffer, value) \
109
uint32_t data = value; \
110
PVR_PDS_PRINT_DATA("DRAW_INDIRECT_ELEMENTS", data, 0); \
111
memcpy(buffer + 7, &data, sizeof(data)); \
113
#define pvr_write_draw_indirect_elements2_immediates(buffer) \
116
uint32_t data = 0x0; \
117
PVR_PDS_PRINT_DATA("DRAW_INDIRECT_ELEMENTS", data, 0); \
118
memcpy(buffer + 2, &data, sizeof(data)); \
121
uint64_t data = 0x0; \
122
PVR_PDS_PRINT_DATA("DRAW_INDIRECT_ELEMENTS", data, 0); \
123
memcpy(buffer + 8, &data, sizeof(data)); \
126
uint32_t data = 0x1; \
127
PVR_PDS_PRINT_DATA("DRAW_INDIRECT_ELEMENTS", data, 0); \
128
memcpy(buffer + 10, &data, sizeof(data)); \