1*61046927SAndroid Build Coastguard Worker /*
2*61046927SAndroid Build Coastguard Worker * Copyright © 2023 Imagination Technologies Ltd.
3*61046927SAndroid Build Coastguard Worker *
4*61046927SAndroid Build Coastguard Worker * Permission is hereby granted, free of charge, to any person obtaining a copy
5*61046927SAndroid Build Coastguard Worker * of this software and associated documentation files (the "Software"), to deal
6*61046927SAndroid Build Coastguard Worker * in the Software without restriction, including without limitation the rights
7*61046927SAndroid Build Coastguard Worker * to use, copy, modify, merge, publish, distribute, sublicense, and/or sell
8*61046927SAndroid Build Coastguard Worker * copies of the Software, and to permit persons to whom the Software is
9*61046927SAndroid Build Coastguard Worker * furnished to do so, subject to the following conditions:
10*61046927SAndroid Build Coastguard Worker *
11*61046927SAndroid Build Coastguard Worker * The above copyright notice and this permission notice (including the next
12*61046927SAndroid Build Coastguard Worker * paragraph) shall be included in all copies or substantial portions of the
13*61046927SAndroid Build Coastguard Worker * Software.
14*61046927SAndroid Build Coastguard Worker *
15*61046927SAndroid Build Coastguard Worker * THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR
16*61046927SAndroid Build Coastguard Worker * IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY,
17*61046927SAndroid Build Coastguard Worker * FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE
18*61046927SAndroid Build Coastguard Worker * AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER
19*61046927SAndroid Build Coastguard Worker * LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM,
20*61046927SAndroid Build Coastguard Worker * OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN THE
21*61046927SAndroid Build Coastguard Worker * SOFTWARE.
22*61046927SAndroid Build Coastguard Worker */
23*61046927SAndroid Build Coastguard Worker
24*61046927SAndroid Build Coastguard Worker #include <stdint.h>
25*61046927SAndroid Build Coastguard Worker #include <vulkan/vulkan_core.h>
26*61046927SAndroid Build Coastguard Worker
27*61046927SAndroid Build Coastguard Worker #include "pvr_bo.h"
28*61046927SAndroid Build Coastguard Worker #include "pvr_private.h"
29*61046927SAndroid Build Coastguard Worker #include "pvr_robustness.h"
30*61046927SAndroid Build Coastguard Worker #include "util/u_math.h"
31*61046927SAndroid Build Coastguard Worker
32*61046927SAndroid Build Coastguard Worker enum pvr_robustness_buffer_format {
33*61046927SAndroid Build Coastguard Worker PVR_ROBUSTNESS_BUFFER_FORMAT_UINT64,
34*61046927SAndroid Build Coastguard Worker PVR_ROBUSTNESS_BUFFER_FORMAT_UINT32,
35*61046927SAndroid Build Coastguard Worker PVR_ROBUSTNESS_BUFFER_FORMAT_UINT16,
36*61046927SAndroid Build Coastguard Worker PVR_ROBUSTNESS_BUFFER_FORMAT_UINT8,
37*61046927SAndroid Build Coastguard Worker PVR_ROBUSTNESS_BUFFER_FORMAT_SINT64,
38*61046927SAndroid Build Coastguard Worker PVR_ROBUSTNESS_BUFFER_FORMAT_SINT32,
39*61046927SAndroid Build Coastguard Worker PVR_ROBUSTNESS_BUFFER_FORMAT_SINT16,
40*61046927SAndroid Build Coastguard Worker PVR_ROBUSTNESS_BUFFER_FORMAT_SINT8,
41*61046927SAndroid Build Coastguard Worker PVR_ROBUSTNESS_BUFFER_FORMAT_SFLOAT64,
42*61046927SAndroid Build Coastguard Worker PVR_ROBUSTNESS_BUFFER_FORMAT_SFLOAT32,
43*61046927SAndroid Build Coastguard Worker PVR_ROBUSTNESS_BUFFER_FORMAT_SFLOAT16,
44*61046927SAndroid Build Coastguard Worker PVR_ROBUSTNESS_BUFFER_FORMAT_A8B8G8R8_UINT,
45*61046927SAndroid Build Coastguard Worker PVR_ROBUSTNESS_BUFFER_FORMAT_A8B8G8R8_SINT,
46*61046927SAndroid Build Coastguard Worker PVR_ROBUSTNESS_BUFFER_FORMAT_A2R10G10B10_UINT,
47*61046927SAndroid Build Coastguard Worker PVR_ROBUSTNESS_BUFFER_FORMAT_A2R10G10B10_SINT,
48*61046927SAndroid Build Coastguard Worker PVR_ROBUSTNESS_BUFFER_FORMAT_R4G4B4A4_UNORM,
49*61046927SAndroid Build Coastguard Worker PVR_ROBUSTNESS_BUFFER_FORMAT_R5G5B5A1_UNORM,
50*61046927SAndroid Build Coastguard Worker PVR_ROBUSTNESS_BUFFER_FORMAT_A1R5G5B5_UNORM,
51*61046927SAndroid Build Coastguard Worker PVR_ROBUSTNESS_BUFFER_FORMAT_COUNT
52*61046927SAndroid Build Coastguard Worker };
53*61046927SAndroid Build Coastguard Worker
54*61046927SAndroid Build Coastguard Worker /* Offsets in bytes of the [0, 0, 0, 1] vectors within the robustness buffer */
55*61046927SAndroid Build Coastguard Worker static uint16_t robustness_buffer_offsets[PVR_ROBUSTNESS_BUFFER_FORMAT_COUNT];
56*61046927SAndroid Build Coastguard Worker
pvr_init_robustness_buffer(struct pvr_device * device)57*61046927SAndroid Build Coastguard Worker VkResult pvr_init_robustness_buffer(struct pvr_device *device)
58*61046927SAndroid Build Coastguard Worker {
59*61046927SAndroid Build Coastguard Worker uint16_t offset = 0;
60*61046927SAndroid Build Coastguard Worker uint8_t *robustness_buffer_map;
61*61046927SAndroid Build Coastguard Worker VkResult result;
62*61046927SAndroid Build Coastguard Worker
63*61046927SAndroid Build Coastguard Worker #define ROBUSTNESS_BUFFER_OFFSET_ALIGN16(cur_offset, add) \
64*61046927SAndroid Build Coastguard Worker ((uint16_t)ALIGN((cur_offset + (uint16_t)(add)), 16))
65*61046927SAndroid Build Coastguard Worker
66*61046927SAndroid Build Coastguard Worker robustness_buffer_offsets[PVR_ROBUSTNESS_BUFFER_FORMAT_UINT64] = offset;
67*61046927SAndroid Build Coastguard Worker offset = ROBUSTNESS_BUFFER_OFFSET_ALIGN16(offset, sizeof(uint64_t) * 4);
68*61046927SAndroid Build Coastguard Worker
69*61046927SAndroid Build Coastguard Worker robustness_buffer_offsets[PVR_ROBUSTNESS_BUFFER_FORMAT_UINT32] = offset;
70*61046927SAndroid Build Coastguard Worker offset = ROBUSTNESS_BUFFER_OFFSET_ALIGN16(offset, sizeof(uint32_t) * 4);
71*61046927SAndroid Build Coastguard Worker
72*61046927SAndroid Build Coastguard Worker robustness_buffer_offsets[PVR_ROBUSTNESS_BUFFER_FORMAT_UINT16] = offset;
73*61046927SAndroid Build Coastguard Worker offset = ROBUSTNESS_BUFFER_OFFSET_ALIGN16(offset, sizeof(uint16_t) * 4);
74*61046927SAndroid Build Coastguard Worker
75*61046927SAndroid Build Coastguard Worker robustness_buffer_offsets[PVR_ROBUSTNESS_BUFFER_FORMAT_UINT8] = offset;
76*61046927SAndroid Build Coastguard Worker offset = ROBUSTNESS_BUFFER_OFFSET_ALIGN16(offset, sizeof(uint8_t) * 4);
77*61046927SAndroid Build Coastguard Worker
78*61046927SAndroid Build Coastguard Worker robustness_buffer_offsets[PVR_ROBUSTNESS_BUFFER_FORMAT_SINT64] = offset;
79*61046927SAndroid Build Coastguard Worker offset = ROBUSTNESS_BUFFER_OFFSET_ALIGN16(offset, sizeof(int64_t) * 4);
80*61046927SAndroid Build Coastguard Worker
81*61046927SAndroid Build Coastguard Worker robustness_buffer_offsets[PVR_ROBUSTNESS_BUFFER_FORMAT_SINT32] = offset;
82*61046927SAndroid Build Coastguard Worker offset = ROBUSTNESS_BUFFER_OFFSET_ALIGN16(offset, sizeof(int32_t) * 4);
83*61046927SAndroid Build Coastguard Worker
84*61046927SAndroid Build Coastguard Worker robustness_buffer_offsets[PVR_ROBUSTNESS_BUFFER_FORMAT_SINT16] = offset;
85*61046927SAndroid Build Coastguard Worker offset = ROBUSTNESS_BUFFER_OFFSET_ALIGN16(offset, sizeof(int16_t) * 4);
86*61046927SAndroid Build Coastguard Worker
87*61046927SAndroid Build Coastguard Worker robustness_buffer_offsets[PVR_ROBUSTNESS_BUFFER_FORMAT_SINT8] = offset;
88*61046927SAndroid Build Coastguard Worker offset = ROBUSTNESS_BUFFER_OFFSET_ALIGN16(offset, sizeof(int8_t) * 4);
89*61046927SAndroid Build Coastguard Worker
90*61046927SAndroid Build Coastguard Worker robustness_buffer_offsets[PVR_ROBUSTNESS_BUFFER_FORMAT_SFLOAT64] = offset;
91*61046927SAndroid Build Coastguard Worker offset = ROBUSTNESS_BUFFER_OFFSET_ALIGN16(offset, sizeof(double) * 4);
92*61046927SAndroid Build Coastguard Worker
93*61046927SAndroid Build Coastguard Worker robustness_buffer_offsets[PVR_ROBUSTNESS_BUFFER_FORMAT_SFLOAT32] = offset;
94*61046927SAndroid Build Coastguard Worker offset = ROBUSTNESS_BUFFER_OFFSET_ALIGN16(offset, sizeof(float) * 4);
95*61046927SAndroid Build Coastguard Worker
96*61046927SAndroid Build Coastguard Worker robustness_buffer_offsets[PVR_ROBUSTNESS_BUFFER_FORMAT_SFLOAT16] = offset;
97*61046927SAndroid Build Coastguard Worker offset = ROBUSTNESS_BUFFER_OFFSET_ALIGN16(offset, sizeof(uint16_t) * 4);
98*61046927SAndroid Build Coastguard Worker
99*61046927SAndroid Build Coastguard Worker robustness_buffer_offsets[PVR_ROBUSTNESS_BUFFER_FORMAT_A8B8G8R8_UINT] =
100*61046927SAndroid Build Coastguard Worker offset;
101*61046927SAndroid Build Coastguard Worker offset = ROBUSTNESS_BUFFER_OFFSET_ALIGN16(offset, 4);
102*61046927SAndroid Build Coastguard Worker
103*61046927SAndroid Build Coastguard Worker robustness_buffer_offsets[PVR_ROBUSTNESS_BUFFER_FORMAT_A8B8G8R8_SINT] =
104*61046927SAndroid Build Coastguard Worker offset;
105*61046927SAndroid Build Coastguard Worker offset = ROBUSTNESS_BUFFER_OFFSET_ALIGN16(offset, 4);
106*61046927SAndroid Build Coastguard Worker
107*61046927SAndroid Build Coastguard Worker robustness_buffer_offsets[PVR_ROBUSTNESS_BUFFER_FORMAT_A2R10G10B10_UINT] =
108*61046927SAndroid Build Coastguard Worker offset;
109*61046927SAndroid Build Coastguard Worker offset = ROBUSTNESS_BUFFER_OFFSET_ALIGN16(offset, 4);
110*61046927SAndroid Build Coastguard Worker
111*61046927SAndroid Build Coastguard Worker robustness_buffer_offsets[PVR_ROBUSTNESS_BUFFER_FORMAT_A2R10G10B10_SINT] =
112*61046927SAndroid Build Coastguard Worker offset;
113*61046927SAndroid Build Coastguard Worker offset = ROBUSTNESS_BUFFER_OFFSET_ALIGN16(offset, 4);
114*61046927SAndroid Build Coastguard Worker
115*61046927SAndroid Build Coastguard Worker robustness_buffer_offsets[PVR_ROBUSTNESS_BUFFER_FORMAT_R4G4B4A4_UNORM] =
116*61046927SAndroid Build Coastguard Worker offset;
117*61046927SAndroid Build Coastguard Worker offset = ROBUSTNESS_BUFFER_OFFSET_ALIGN16(offset, 2);
118*61046927SAndroid Build Coastguard Worker
119*61046927SAndroid Build Coastguard Worker robustness_buffer_offsets[PVR_ROBUSTNESS_BUFFER_FORMAT_R5G5B5A1_UNORM] =
120*61046927SAndroid Build Coastguard Worker offset;
121*61046927SAndroid Build Coastguard Worker offset = ROBUSTNESS_BUFFER_OFFSET_ALIGN16(offset, 2);
122*61046927SAndroid Build Coastguard Worker
123*61046927SAndroid Build Coastguard Worker robustness_buffer_offsets[PVR_ROBUSTNESS_BUFFER_FORMAT_A1R5G5B5_UNORM] =
124*61046927SAndroid Build Coastguard Worker offset;
125*61046927SAndroid Build Coastguard Worker offset = ROBUSTNESS_BUFFER_OFFSET_ALIGN16(offset, 2);
126*61046927SAndroid Build Coastguard Worker
127*61046927SAndroid Build Coastguard Worker #undef ROBUSTNESS_BUFFER_OFFSET_ALIGN16
128*61046927SAndroid Build Coastguard Worker
129*61046927SAndroid Build Coastguard Worker result = pvr_bo_alloc(device,
130*61046927SAndroid Build Coastguard Worker device->heaps.general_heap,
131*61046927SAndroid Build Coastguard Worker offset,
132*61046927SAndroid Build Coastguard Worker 16,
133*61046927SAndroid Build Coastguard Worker PVR_BO_ALLOC_FLAG_CPU_MAPPED,
134*61046927SAndroid Build Coastguard Worker &device->robustness_buffer);
135*61046927SAndroid Build Coastguard Worker if (result != VK_SUCCESS)
136*61046927SAndroid Build Coastguard Worker return result;
137*61046927SAndroid Build Coastguard Worker
138*61046927SAndroid Build Coastguard Worker robustness_buffer_map = device->robustness_buffer->bo->map;
139*61046927SAndroid Build Coastguard Worker
140*61046927SAndroid Build Coastguard Worker #define ROBUSTNESS_BUFFER_RGBA(format, type, zero, one) \
141*61046927SAndroid Build Coastguard Worker do { \
142*61046927SAndroid Build Coastguard Worker type *const buffer = \
143*61046927SAndroid Build Coastguard Worker (type *)robustness_buffer_map + robustness_buffer_offsets[format]; \
144*61046927SAndroid Build Coastguard Worker buffer[0] = (type)zero; \
145*61046927SAndroid Build Coastguard Worker buffer[1] = (type)zero; \
146*61046927SAndroid Build Coastguard Worker buffer[2] = (type)zero; \
147*61046927SAndroid Build Coastguard Worker buffer[3] = (type)one; \
148*61046927SAndroid Build Coastguard Worker } while (0)
149*61046927SAndroid Build Coastguard Worker
150*61046927SAndroid Build Coastguard Worker #define ROBUSTNESS_BUFFER_ABGR(format, type, zero, one) \
151*61046927SAndroid Build Coastguard Worker do { \
152*61046927SAndroid Build Coastguard Worker type *const buffer = \
153*61046927SAndroid Build Coastguard Worker (type *)robustness_buffer_map + robustness_buffer_offsets[format]; \
154*61046927SAndroid Build Coastguard Worker buffer[0] = (type)one; \
155*61046927SAndroid Build Coastguard Worker buffer[1] = (type)zero; \
156*61046927SAndroid Build Coastguard Worker buffer[2] = (type)zero; \
157*61046927SAndroid Build Coastguard Worker buffer[3] = (type)zero; \
158*61046927SAndroid Build Coastguard Worker } while (0)
159*61046927SAndroid Build Coastguard Worker
160*61046927SAndroid Build Coastguard Worker #define ROBUSTNESS_BUFFER_PACKED(format, type, val) \
161*61046927SAndroid Build Coastguard Worker do { \
162*61046927SAndroid Build Coastguard Worker type *const buffer = \
163*61046927SAndroid Build Coastguard Worker (type *)robustness_buffer_map + robustness_buffer_offsets[format]; \
164*61046927SAndroid Build Coastguard Worker *buffer = (type)val; \
165*61046927SAndroid Build Coastguard Worker } while (0)
166*61046927SAndroid Build Coastguard Worker
167*61046927SAndroid Build Coastguard Worker ROBUSTNESS_BUFFER_RGBA(PVR_ROBUSTNESS_BUFFER_FORMAT_UINT64,
168*61046927SAndroid Build Coastguard Worker uint64_t,
169*61046927SAndroid Build Coastguard Worker 0ull,
170*61046927SAndroid Build Coastguard Worker UINT64_MAX);
171*61046927SAndroid Build Coastguard Worker ROBUSTNESS_BUFFER_RGBA(PVR_ROBUSTNESS_BUFFER_FORMAT_UINT32,
172*61046927SAndroid Build Coastguard Worker uint32_t,
173*61046927SAndroid Build Coastguard Worker 0ul,
174*61046927SAndroid Build Coastguard Worker UINT32_MAX);
175*61046927SAndroid Build Coastguard Worker ROBUSTNESS_BUFFER_RGBA(PVR_ROBUSTNESS_BUFFER_FORMAT_UINT16,
176*61046927SAndroid Build Coastguard Worker uint16_t,
177*61046927SAndroid Build Coastguard Worker 0u,
178*61046927SAndroid Build Coastguard Worker UINT16_MAX);
179*61046927SAndroid Build Coastguard Worker ROBUSTNESS_BUFFER_RGBA(PVR_ROBUSTNESS_BUFFER_FORMAT_UINT8,
180*61046927SAndroid Build Coastguard Worker uint8_t,
181*61046927SAndroid Build Coastguard Worker 0u,
182*61046927SAndroid Build Coastguard Worker UINT8_MAX);
183*61046927SAndroid Build Coastguard Worker
184*61046927SAndroid Build Coastguard Worker ROBUSTNESS_BUFFER_RGBA(PVR_ROBUSTNESS_BUFFER_FORMAT_SINT64,
185*61046927SAndroid Build Coastguard Worker int64_t,
186*61046927SAndroid Build Coastguard Worker 0ull,
187*61046927SAndroid Build Coastguard Worker INT64_MAX);
188*61046927SAndroid Build Coastguard Worker ROBUSTNESS_BUFFER_RGBA(PVR_ROBUSTNESS_BUFFER_FORMAT_SINT32,
189*61046927SAndroid Build Coastguard Worker int32_t,
190*61046927SAndroid Build Coastguard Worker 0ul,
191*61046927SAndroid Build Coastguard Worker INT32_MAX);
192*61046927SAndroid Build Coastguard Worker ROBUSTNESS_BUFFER_RGBA(PVR_ROBUSTNESS_BUFFER_FORMAT_SINT16,
193*61046927SAndroid Build Coastguard Worker int16_t,
194*61046927SAndroid Build Coastguard Worker 0u,
195*61046927SAndroid Build Coastguard Worker INT16_MAX);
196*61046927SAndroid Build Coastguard Worker ROBUSTNESS_BUFFER_RGBA(PVR_ROBUSTNESS_BUFFER_FORMAT_SINT8,
197*61046927SAndroid Build Coastguard Worker int8_t,
198*61046927SAndroid Build Coastguard Worker 0u,
199*61046927SAndroid Build Coastguard Worker INT8_MAX);
200*61046927SAndroid Build Coastguard Worker
201*61046927SAndroid Build Coastguard Worker ROBUSTNESS_BUFFER_RGBA(PVR_ROBUSTNESS_BUFFER_FORMAT_SFLOAT64,
202*61046927SAndroid Build Coastguard Worker uint64_t,
203*61046927SAndroid Build Coastguard Worker 0x0000000000000000ull,
204*61046927SAndroid Build Coastguard Worker 0x3ff0000000000000ull);
205*61046927SAndroid Build Coastguard Worker ROBUSTNESS_BUFFER_RGBA(PVR_ROBUSTNESS_BUFFER_FORMAT_SFLOAT32,
206*61046927SAndroid Build Coastguard Worker float,
207*61046927SAndroid Build Coastguard Worker 0.0f,
208*61046927SAndroid Build Coastguard Worker 1.0f);
209*61046927SAndroid Build Coastguard Worker ROBUSTNESS_BUFFER_RGBA(PVR_ROBUSTNESS_BUFFER_FORMAT_SFLOAT16,
210*61046927SAndroid Build Coastguard Worker uint16_t,
211*61046927SAndroid Build Coastguard Worker 0x0000,
212*61046927SAndroid Build Coastguard Worker 0x3c00);
213*61046927SAndroid Build Coastguard Worker
214*61046927SAndroid Build Coastguard Worker ROBUSTNESS_BUFFER_ABGR(PVR_ROBUSTNESS_BUFFER_FORMAT_A8B8G8R8_UINT,
215*61046927SAndroid Build Coastguard Worker uint8_t,
216*61046927SAndroid Build Coastguard Worker 0u,
217*61046927SAndroid Build Coastguard Worker UINT8_MAX);
218*61046927SAndroid Build Coastguard Worker ROBUSTNESS_BUFFER_ABGR(PVR_ROBUSTNESS_BUFFER_FORMAT_A8B8G8R8_UINT,
219*61046927SAndroid Build Coastguard Worker int8_t,
220*61046927SAndroid Build Coastguard Worker 0u,
221*61046927SAndroid Build Coastguard Worker INT8_MAX);
222*61046927SAndroid Build Coastguard Worker
223*61046927SAndroid Build Coastguard Worker ROBUSTNESS_BUFFER_PACKED(PVR_ROBUSTNESS_BUFFER_FORMAT_A2R10G10B10_UINT,
224*61046927SAndroid Build Coastguard Worker uint32_t,
225*61046927SAndroid Build Coastguard Worker 0xC0000000u);
226*61046927SAndroid Build Coastguard Worker ROBUSTNESS_BUFFER_PACKED(PVR_ROBUSTNESS_BUFFER_FORMAT_A2R10G10B10_SINT,
227*61046927SAndroid Build Coastguard Worker uint32_t,
228*61046927SAndroid Build Coastguard Worker 0x40000000u);
229*61046927SAndroid Build Coastguard Worker ROBUSTNESS_BUFFER_PACKED(PVR_ROBUSTNESS_BUFFER_FORMAT_R4G4B4A4_UNORM,
230*61046927SAndroid Build Coastguard Worker uint16_t,
231*61046927SAndroid Build Coastguard Worker 0x000Fu);
232*61046927SAndroid Build Coastguard Worker ROBUSTNESS_BUFFER_PACKED(PVR_ROBUSTNESS_BUFFER_FORMAT_R5G5B5A1_UNORM,
233*61046927SAndroid Build Coastguard Worker uint16_t,
234*61046927SAndroid Build Coastguard Worker 0x0001u);
235*61046927SAndroid Build Coastguard Worker ROBUSTNESS_BUFFER_PACKED(PVR_ROBUSTNESS_BUFFER_FORMAT_A1R5G5B5_UNORM,
236*61046927SAndroid Build Coastguard Worker uint16_t,
237*61046927SAndroid Build Coastguard Worker 0x8000u);
238*61046927SAndroid Build Coastguard Worker
239*61046927SAndroid Build Coastguard Worker #undef ROBUSTNESS_BUFFER_RGBA
240*61046927SAndroid Build Coastguard Worker #undef ROBUSTNESS_BUFFER_ABGR
241*61046927SAndroid Build Coastguard Worker #undef ROBUSTNESS_BUFFER_PACKED
242*61046927SAndroid Build Coastguard Worker
243*61046927SAndroid Build Coastguard Worker return VK_SUCCESS;
244*61046927SAndroid Build Coastguard Worker }
245*61046927SAndroid Build Coastguard Worker
pvr_robustness_buffer_finish(struct pvr_device * device)246*61046927SAndroid Build Coastguard Worker void pvr_robustness_buffer_finish(struct pvr_device *device)
247*61046927SAndroid Build Coastguard Worker {
248*61046927SAndroid Build Coastguard Worker pvr_bo_free(device, device->robustness_buffer);
249*61046927SAndroid Build Coastguard Worker }
250*61046927SAndroid Build Coastguard Worker
pvr_get_robustness_buffer_format_offset(VkFormat format)251*61046927SAndroid Build Coastguard Worker uint16_t pvr_get_robustness_buffer_format_offset(VkFormat format)
252*61046927SAndroid Build Coastguard Worker {
253*61046927SAndroid Build Coastguard Worker switch (format) {
254*61046927SAndroid Build Coastguard Worker case VK_FORMAT_R64G64B64A64_SFLOAT:
255*61046927SAndroid Build Coastguard Worker return robustness_buffer_offsets[PVR_ROBUSTNESS_BUFFER_FORMAT_SFLOAT64];
256*61046927SAndroid Build Coastguard Worker
257*61046927SAndroid Build Coastguard Worker case VK_FORMAT_R32G32B32A32_SFLOAT:
258*61046927SAndroid Build Coastguard Worker return robustness_buffer_offsets[PVR_ROBUSTNESS_BUFFER_FORMAT_SFLOAT32];
259*61046927SAndroid Build Coastguard Worker
260*61046927SAndroid Build Coastguard Worker case VK_FORMAT_R16G16B16A16_SFLOAT:
261*61046927SAndroid Build Coastguard Worker return robustness_buffer_offsets[PVR_ROBUSTNESS_BUFFER_FORMAT_SFLOAT16];
262*61046927SAndroid Build Coastguard Worker
263*61046927SAndroid Build Coastguard Worker case VK_FORMAT_R64G64B64A64_UINT:
264*61046927SAndroid Build Coastguard Worker return robustness_buffer_offsets[PVR_ROBUSTNESS_BUFFER_FORMAT_UINT64];
265*61046927SAndroid Build Coastguard Worker
266*61046927SAndroid Build Coastguard Worker case VK_FORMAT_R32G32B32A32_UINT:
267*61046927SAndroid Build Coastguard Worker return robustness_buffer_offsets[PVR_ROBUSTNESS_BUFFER_FORMAT_UINT32];
268*61046927SAndroid Build Coastguard Worker
269*61046927SAndroid Build Coastguard Worker case VK_FORMAT_R16G16B16A16_UNORM:
270*61046927SAndroid Build Coastguard Worker case VK_FORMAT_R16G16B16A16_USCALED:
271*61046927SAndroid Build Coastguard Worker case VK_FORMAT_R16G16B16A16_UINT:
272*61046927SAndroid Build Coastguard Worker return robustness_buffer_offsets[PVR_ROBUSTNESS_BUFFER_FORMAT_UINT16];
273*61046927SAndroid Build Coastguard Worker
274*61046927SAndroid Build Coastguard Worker case VK_FORMAT_R8G8B8A8_UNORM:
275*61046927SAndroid Build Coastguard Worker case VK_FORMAT_R8G8B8A8_USCALED:
276*61046927SAndroid Build Coastguard Worker case VK_FORMAT_R8G8B8A8_UINT:
277*61046927SAndroid Build Coastguard Worker case VK_FORMAT_R8G8B8A8_SRGB:
278*61046927SAndroid Build Coastguard Worker case VK_FORMAT_B8G8R8A8_UNORM:
279*61046927SAndroid Build Coastguard Worker case VK_FORMAT_B8G8R8A8_USCALED:
280*61046927SAndroid Build Coastguard Worker case VK_FORMAT_B8G8R8A8_UINT:
281*61046927SAndroid Build Coastguard Worker case VK_FORMAT_B8G8R8A8_SRGB:
282*61046927SAndroid Build Coastguard Worker return robustness_buffer_offsets[PVR_ROBUSTNESS_BUFFER_FORMAT_UINT8];
283*61046927SAndroid Build Coastguard Worker
284*61046927SAndroid Build Coastguard Worker case VK_FORMAT_R64G64B64A64_SINT:
285*61046927SAndroid Build Coastguard Worker return robustness_buffer_offsets[PVR_ROBUSTNESS_BUFFER_FORMAT_SINT64];
286*61046927SAndroid Build Coastguard Worker
287*61046927SAndroid Build Coastguard Worker case VK_FORMAT_R32G32B32A32_SINT:
288*61046927SAndroid Build Coastguard Worker return robustness_buffer_offsets[PVR_ROBUSTNESS_BUFFER_FORMAT_SINT32];
289*61046927SAndroid Build Coastguard Worker
290*61046927SAndroid Build Coastguard Worker case VK_FORMAT_R16G16B16A16_SNORM:
291*61046927SAndroid Build Coastguard Worker case VK_FORMAT_R16G16B16A16_SSCALED:
292*61046927SAndroid Build Coastguard Worker case VK_FORMAT_R16G16B16A16_SINT:
293*61046927SAndroid Build Coastguard Worker return robustness_buffer_offsets[PVR_ROBUSTNESS_BUFFER_FORMAT_SINT16];
294*61046927SAndroid Build Coastguard Worker
295*61046927SAndroid Build Coastguard Worker case VK_FORMAT_R8G8B8A8_SNORM:
296*61046927SAndroid Build Coastguard Worker case VK_FORMAT_R8G8B8A8_SSCALED:
297*61046927SAndroid Build Coastguard Worker case VK_FORMAT_R8G8B8A8_SINT:
298*61046927SAndroid Build Coastguard Worker case VK_FORMAT_B8G8R8A8_SNORM:
299*61046927SAndroid Build Coastguard Worker case VK_FORMAT_B8G8R8A8_SSCALED:
300*61046927SAndroid Build Coastguard Worker case VK_FORMAT_B8G8R8A8_SINT:
301*61046927SAndroid Build Coastguard Worker return robustness_buffer_offsets[PVR_ROBUSTNESS_BUFFER_FORMAT_SINT8];
302*61046927SAndroid Build Coastguard Worker
303*61046927SAndroid Build Coastguard Worker case VK_FORMAT_A8B8G8R8_UNORM_PACK32:
304*61046927SAndroid Build Coastguard Worker case VK_FORMAT_A8B8G8R8_USCALED_PACK32:
305*61046927SAndroid Build Coastguard Worker case VK_FORMAT_A8B8G8R8_UINT_PACK32:
306*61046927SAndroid Build Coastguard Worker case VK_FORMAT_A8B8G8R8_SRGB_PACK32:
307*61046927SAndroid Build Coastguard Worker return robustness_buffer_offsets
308*61046927SAndroid Build Coastguard Worker [PVR_ROBUSTNESS_BUFFER_FORMAT_A8B8G8R8_UINT];
309*61046927SAndroid Build Coastguard Worker
310*61046927SAndroid Build Coastguard Worker case VK_FORMAT_A8B8G8R8_SNORM_PACK32:
311*61046927SAndroid Build Coastguard Worker case VK_FORMAT_A8B8G8R8_SSCALED_PACK32:
312*61046927SAndroid Build Coastguard Worker case VK_FORMAT_A8B8G8R8_SINT_PACK32:
313*61046927SAndroid Build Coastguard Worker return robustness_buffer_offsets
314*61046927SAndroid Build Coastguard Worker [PVR_ROBUSTNESS_BUFFER_FORMAT_A8B8G8R8_SINT];
315*61046927SAndroid Build Coastguard Worker
316*61046927SAndroid Build Coastguard Worker case VK_FORMAT_A2R10G10B10_UNORM_PACK32:
317*61046927SAndroid Build Coastguard Worker case VK_FORMAT_A2R10G10B10_USCALED_PACK32:
318*61046927SAndroid Build Coastguard Worker case VK_FORMAT_A2R10G10B10_UINT_PACK32:
319*61046927SAndroid Build Coastguard Worker case VK_FORMAT_A2B10G10R10_UNORM_PACK32:
320*61046927SAndroid Build Coastguard Worker case VK_FORMAT_A2B10G10R10_USCALED_PACK32:
321*61046927SAndroid Build Coastguard Worker case VK_FORMAT_A2B10G10R10_UINT_PACK32:
322*61046927SAndroid Build Coastguard Worker return robustness_buffer_offsets
323*61046927SAndroid Build Coastguard Worker [PVR_ROBUSTNESS_BUFFER_FORMAT_A2R10G10B10_UINT];
324*61046927SAndroid Build Coastguard Worker
325*61046927SAndroid Build Coastguard Worker case VK_FORMAT_A2R10G10B10_SNORM_PACK32:
326*61046927SAndroid Build Coastguard Worker case VK_FORMAT_A2R10G10B10_SSCALED_PACK32:
327*61046927SAndroid Build Coastguard Worker case VK_FORMAT_A2R10G10B10_SINT_PACK32:
328*61046927SAndroid Build Coastguard Worker case VK_FORMAT_A2B10G10R10_SNORM_PACK32:
329*61046927SAndroid Build Coastguard Worker case VK_FORMAT_A2B10G10R10_SSCALED_PACK32:
330*61046927SAndroid Build Coastguard Worker case VK_FORMAT_A2B10G10R10_SINT_PACK32:
331*61046927SAndroid Build Coastguard Worker return robustness_buffer_offsets
332*61046927SAndroid Build Coastguard Worker [PVR_ROBUSTNESS_BUFFER_FORMAT_A2R10G10B10_SINT];
333*61046927SAndroid Build Coastguard Worker
334*61046927SAndroid Build Coastguard Worker case VK_FORMAT_R4G4B4A4_UNORM_PACK16:
335*61046927SAndroid Build Coastguard Worker case VK_FORMAT_B4G4R4A4_UNORM_PACK16:
336*61046927SAndroid Build Coastguard Worker return robustness_buffer_offsets
337*61046927SAndroid Build Coastguard Worker [PVR_ROBUSTNESS_BUFFER_FORMAT_R4G4B4A4_UNORM];
338*61046927SAndroid Build Coastguard Worker
339*61046927SAndroid Build Coastguard Worker case VK_FORMAT_R5G5B5A1_UNORM_PACK16:
340*61046927SAndroid Build Coastguard Worker case VK_FORMAT_B5G5R5A1_UNORM_PACK16:
341*61046927SAndroid Build Coastguard Worker return robustness_buffer_offsets
342*61046927SAndroid Build Coastguard Worker [PVR_ROBUSTNESS_BUFFER_FORMAT_R5G5B5A1_UNORM];
343*61046927SAndroid Build Coastguard Worker
344*61046927SAndroid Build Coastguard Worker case VK_FORMAT_A1R5G5B5_UNORM_PACK16:
345*61046927SAndroid Build Coastguard Worker return robustness_buffer_offsets
346*61046927SAndroid Build Coastguard Worker [PVR_ROBUSTNESS_BUFFER_FORMAT_A1R5G5B5_UNORM];
347*61046927SAndroid Build Coastguard Worker
348*61046927SAndroid Build Coastguard Worker default:
349*61046927SAndroid Build Coastguard Worker return robustness_buffer_offsets[PVR_ROBUSTNESS_BUFFER_FORMAT_UINT64];
350*61046927SAndroid Build Coastguard Worker }
351*61046927SAndroid Build Coastguard Worker }
352