• Home
  • Line#
  • Scopes#
  • Navigate#
  • Raw
  • Download
1 /*
2  * Copyright 2021 Alyssa Rosenzweig
3  * SPDX-License-Identifier: MIT
4  */
5 
6 #include "agx_formats.h"
7 #include "agx_internal_formats.h"
8 #include "agx_pack.h"
9 
10 #define AGX_INTERNAL_FORMAT__ PIPE_FORMAT_NONE
11 
12 #define AGX_FMT(pipe, channels_, type_, renderable_)                           \
13    [PIPE_FORMAT_##pipe] = {                                                    \
14       .channels = AGX_CHANNELS_##channels_,                                    \
15       .type = AGX_TEXTURE_TYPE_##type_,                                        \
16       .texturable = true,                                                      \
17       .renderable = (enum pipe_format)AGX_INTERNAL_FORMAT_##renderable_,       \
18    }
19 
20 /* clang-format off */
21 const struct agx_pixel_format_entry agx_pixel_format[PIPE_FORMAT_COUNT] = {
22    AGX_FMT(R5G6B5_UNORM,            R5G6B5,                UNORM, F16),
23    AGX_FMT(B5G6R5_UNORM,            R5G6B5,                UNORM, F16),
24 
25    AGX_FMT(R5G5B5A1_UNORM,          R5G5B5A1,              UNORM, F16),
26    AGX_FMT(B5G5R5A1_UNORM,          R5G5B5A1,              UNORM, F16),
27    AGX_FMT(R5G5B5X1_UNORM,          R5G5B5A1,              UNORM, F16),
28    AGX_FMT(B5G5R5X1_UNORM,          R5G5B5A1,              UNORM, F16),
29 
30    AGX_FMT(R4G4B4A4_UNORM,          R4G4B4A4,              UNORM, F16),
31    AGX_FMT(B4G4R4A4_UNORM,          R4G4B4A4,              UNORM, F16),
32    AGX_FMT(A4B4G4R4_UNORM,          R4G4B4A4,              UNORM, F16),
33 
34    AGX_FMT(R8_UNORM,                R8,                    UNORM, U8NORM),
35    AGX_FMT(R8G8_UNORM,              R8G8,                  UNORM, U8NORM),
36    AGX_FMT(R8G8B8A8_UNORM,          R8G8B8A8,              UNORM, U8NORM),
37    AGX_FMT(A8R8G8B8_UNORM,          R8G8B8A8,              UNORM, U8NORM),
38    AGX_FMT(A8B8G8R8_UNORM,          R8G8B8A8,              UNORM, U8NORM),
39    AGX_FMT(B8G8R8A8_UNORM,          R8G8B8A8,              UNORM, U8NORM),
40    AGX_FMT(R8G8B8X8_UNORM,          R8G8B8A8,              UNORM, U8NORM),
41    AGX_FMT(X8R8G8B8_UNORM,          R8G8B8A8,              UNORM, U8NORM),
42    AGX_FMT(X8B8G8R8_UNORM,          R8G8B8A8,              UNORM, U8NORM),
43    AGX_FMT(B8G8R8X8_UNORM,          R8G8B8A8,              UNORM, U8NORM),
44 
45    AGX_FMT(R16_UNORM,               R16,                   UNORM, U16NORM),
46    AGX_FMT(R16G16_UNORM,            R16G16,                UNORM, U16NORM),
47    AGX_FMT(R16G16B16A16_UNORM,      R16G16B16A16,          UNORM, U16NORM),
48    AGX_FMT(R16_SNORM,               R16,                   SNORM, S16NORM),
49    AGX_FMT(R16G16_SNORM,            R16G16,                SNORM, S16NORM),
50    AGX_FMT(R16G16B16A16_SNORM,      R16G16B16A16,          SNORM, S16NORM),
51 
52    AGX_FMT(R8_SRGB,                 R8,                    UNORM, SRGBA8),
53    AGX_FMT(R8G8_SRGB,               R8G8,                  UNORM, SRGBA8),
54    AGX_FMT(R8G8B8A8_SRGB,           R8G8B8A8,              UNORM, SRGBA8),
55    AGX_FMT(A8R8G8B8_SRGB,           R8G8B8A8,              UNORM, SRGBA8),
56    AGX_FMT(A8B8G8R8_SRGB,           R8G8B8A8,              UNORM, SRGBA8),
57    AGX_FMT(B8G8R8A8_SRGB,           R8G8B8A8,              UNORM, SRGBA8),
58    AGX_FMT(R8G8B8X8_SRGB,           R8G8B8A8,              UNORM, SRGBA8),
59    AGX_FMT(X8R8G8B8_SRGB,           R8G8B8A8,              UNORM, SRGBA8),
60    AGX_FMT(X8B8G8R8_SRGB,           R8G8B8A8,              UNORM, SRGBA8),
61    AGX_FMT(B8G8R8X8_SRGB,           R8G8B8A8,              UNORM, SRGBA8),
62 
63    AGX_FMT(R8_SNORM,                R8,                    SNORM, S8NORM),
64    AGX_FMT(R8G8_SNORM,              R8G8,                  SNORM, S8NORM),
65    AGX_FMT(R8G8B8A8_SNORM,          R8G8B8A8,              SNORM, S8NORM),
66    AGX_FMT(A8R8G8B8_SNORM,          R8G8B8A8,              SNORM, S8NORM),
67    AGX_FMT(A8B8G8R8_SNORM,          R8G8B8A8,              SNORM, S8NORM),
68    AGX_FMT(B8G8R8A8_SNORM,          R8G8B8A8,              SNORM, S8NORM),
69    AGX_FMT(R8G8B8X8_SNORM,          R8G8B8A8,              SNORM, S8NORM),
70    AGX_FMT(X8R8G8B8_SNORM,          R8G8B8A8,              SNORM, S8NORM),
71    AGX_FMT(X8B8G8R8_SNORM,          R8G8B8A8,              SNORM, S8NORM),
72    AGX_FMT(B8G8R8X8_SNORM,          R8G8B8A8,              SNORM, S8NORM),
73 
74    AGX_FMT(R16_FLOAT,               R16,                   FLOAT, F16),
75    AGX_FMT(R16G16_FLOAT,            R16G16,                FLOAT, F16),
76    AGX_FMT(R16G16B16X16_FLOAT,      R16G16B16A16,          FLOAT, F16),
77    AGX_FMT(R16G16B16A16_FLOAT,      R16G16B16A16,          FLOAT, F16),
78 
79    AGX_FMT(R32_FLOAT,               R32,                   FLOAT, I32),
80    AGX_FMT(R32G32_FLOAT,            R32G32,                FLOAT, I32),
81    AGX_FMT(R32G32B32X32_FLOAT,      R32G32B32A32,          FLOAT, I32),
82    AGX_FMT(R32G32B32A32_FLOAT,      R32G32B32A32,          FLOAT, I32),
83 
84    AGX_FMT(R8_UINT,                 R8,                    UINT,  I8),
85    AGX_FMT(R8G8_UINT,               R8G8,                  UINT,  I8),
86    AGX_FMT(R8G8B8X8_UINT,           R8G8B8A8,              UINT,  I8),
87    AGX_FMT(R8G8B8A8_UINT,           R8G8B8A8,              UINT,  I8),
88    AGX_FMT(B8G8R8X8_UINT,           R8G8B8A8,              UINT,  I8),
89    AGX_FMT(B8G8R8A8_UINT,           R8G8B8A8,              UINT,  I8),
90 
91    AGX_FMT(R16_UINT,                R16,                   UINT,  I16),
92    AGX_FMT(R16G16_UINT,             R16G16,                UINT,  I16),
93    AGX_FMT(R16G16B16X16_UINT,       R16G16B16A16,          UINT,  I16),
94    AGX_FMT(R16G16B16A16_UINT,       R16G16B16A16,          UINT,  I16),
95 
96    AGX_FMT(R32_UINT,                R32,                   UINT,  I32),
97    AGX_FMT(R32G32_UINT,             R32G32,                UINT,  I32),
98    AGX_FMT(R32G32B32X32_UINT,       R32G32B32A32,          UINT,  I32),
99    AGX_FMT(R32G32B32A32_UINT,       R32G32B32A32,          UINT,  I32),
100 
101    AGX_FMT(R8_SINT,                 R8,                    SINT,  I8),
102    AGX_FMT(R8G8_SINT,               R8G8,                  SINT,  I8),
103    AGX_FMT(R8G8B8X8_SINT,           R8G8B8A8,              SINT,  I8),
104    AGX_FMT(R8G8B8A8_SINT,           R8G8B8A8,              SINT,  I8),
105    AGX_FMT(B8G8R8X8_SINT,           R8G8B8A8,              SINT,  I8),
106    AGX_FMT(B8G8R8A8_SINT,           R8G8B8A8,              SINT,  I8),
107 
108    AGX_FMT(R16_SINT,                R16,                   SINT,  I16),
109    AGX_FMT(R16G16_SINT,             R16G16,                SINT,  I16),
110    AGX_FMT(R16G16B16X16_SINT,       R16G16B16A16,          SINT,  I16),
111    AGX_FMT(R16G16B16A16_SINT,       R16G16B16A16,          SINT,  I16),
112 
113    AGX_FMT(R32_SINT,                R32,                   SINT,  I32),
114    AGX_FMT(R32G32_SINT,             R32G32,                SINT,  I32),
115    AGX_FMT(R32G32B32X32_SINT,       R32G32B32A32,          SINT,  I32),
116    AGX_FMT(R32G32B32A32_SINT,       R32G32B32A32,          SINT,  I32),
117 
118    AGX_FMT(Z16_UNORM,               R16,                   UNORM, _),
119    AGX_FMT(Z32_FLOAT,               R32,                   FLOAT, _),
120    AGX_FMT(Z32_FLOAT_S8X24_UINT,    R32,                   FLOAT, _),
121    AGX_FMT(S8_UINT,                 R8,                    UINT,  _),
122 
123    /* The stencil part of Z32F + S8 is just S8 */
124    AGX_FMT(X32_S8X24_UINT,          R8,                    UINT,  _),
125 
126    /* These must be lowered by u_transfer_helper to Z32F + S8 */
127    AGX_FMT(Z24X8_UNORM,             R32,                   FLOAT, _),
128    AGX_FMT(Z24_UNORM_S8_UINT,       R32,                   FLOAT, _),
129 
130    AGX_FMT(R10G10B10A2_UNORM,       R10G10B10A2,           UNORM, RGB10A2),
131    AGX_FMT(R10G10B10X2_UNORM,       R10G10B10A2,           UNORM, RGB10A2),
132    AGX_FMT(B10G10R10A2_UNORM,       R10G10B10A2,           UNORM, RGB10A2),
133    AGX_FMT(B10G10R10X2_UNORM,       R10G10B10A2,           UNORM, RGB10A2),
134 
135    AGX_FMT(R10G10B10A2_UINT,        R10G10B10A2,           UINT,  I16),
136    AGX_FMT(B10G10R10A2_UINT,        R10G10B10A2,           UINT,  I16),
137 
138    AGX_FMT(R10G10B10A2_SINT,        R10G10B10A2,           SINT,  I16),
139    AGX_FMT(B10G10R10A2_SINT,        R10G10B10A2,           SINT,  I16),
140 
141    AGX_FMT(R11G11B10_FLOAT,         R11G11B10,             FLOAT, RG11B10F),
142 
143    /* TODO: This should be renderable but there are copyimage issues */
144    AGX_FMT(R9G9B9E5_FLOAT,          R9G9B9E5,              FLOAT, _),
145 
146    /* These formats are emulated for texture buffers only */
147    AGX_FMT(R32G32B32_FLOAT,         R32G32B32_EMULATED,    FLOAT, _),
148    AGX_FMT(R32G32B32_UINT,          R32G32B32_EMULATED,    UINT,  _),
149    AGX_FMT(R32G32B32_SINT,          R32G32B32_EMULATED,    SINT,  _),
150 
151    /* Likewise, luminance/alpha/intensity formats are supported for texturing,
152     * because they are required for texture buffers in the compat profile and
153     * mesa/st is unable to emulate them for texture buffers. Our Gallium driver
154     * handles the swizzles appropriately, so we just need to plumb through the
155     * enums.
156     *
157     * If mesa/st grows emulation for these formats later, we can drop this.
158     */
159    AGX_FMT(A8_UNORM,                R8,                    UNORM, _),
160    AGX_FMT(A16_UNORM,               R16,                   UNORM, _),
161    AGX_FMT(A8_SINT,                 R8,                    SINT,  _),
162    AGX_FMT(A16_SINT,                R16,                   SINT,  _),
163    AGX_FMT(A32_SINT,                R32,                   SINT,  _),
164    AGX_FMT(A8_UINT,                 R8,                    UINT,  _),
165    AGX_FMT(A16_UINT,                R16,                   UINT,  _),
166    AGX_FMT(A32_UINT,                R32,                   UINT,  _),
167    AGX_FMT(A16_FLOAT,               R16,                   FLOAT, _),
168    AGX_FMT(A32_FLOAT,               R32,                   FLOAT, _),
169 
170    AGX_FMT(L8_UNORM,                R8,                    UNORM, _),
171    AGX_FMT(L16_UNORM,               R16,                   UNORM, _),
172    AGX_FMT(L8_SINT,                 R8,                    SINT,  _),
173    AGX_FMT(L16_SINT,                R16,                   SINT,  _),
174    AGX_FMT(L32_SINT,                R32,                   SINT,  _),
175    AGX_FMT(L8_UINT,                 R8,                    UINT,  _),
176    AGX_FMT(L16_UINT,                R16,                   UINT,  _),
177    AGX_FMT(L32_UINT,                R32,                   UINT,  _),
178    AGX_FMT(L16_FLOAT,               R16,                   FLOAT, _),
179    AGX_FMT(L32_FLOAT,               R32,                   FLOAT, _),
180 
181    AGX_FMT(L8A8_UNORM,              R8G8,                  UNORM, _),
182    AGX_FMT(L16A16_UNORM,            R16G16,                UNORM, _),
183    AGX_FMT(L8A8_SINT,               R8G8,                  SINT,  _),
184    AGX_FMT(L16A16_SINT,             R16G16,                SINT,  _),
185    AGX_FMT(L32A32_SINT,             R32G32,                SINT,  _),
186    AGX_FMT(L8A8_UINT,               R8G8,                  UINT,  _),
187    AGX_FMT(L16A16_UINT,             R16G16,                UINT,  _),
188    AGX_FMT(L32A32_UINT,             R32G32,                UINT,  _),
189    AGX_FMT(L16A16_FLOAT,            R16G16,                FLOAT, _),
190    AGX_FMT(L32A32_FLOAT,            R32G32,                FLOAT, _),
191 
192    AGX_FMT(I8_UNORM,                R8,                    UNORM, _),
193    AGX_FMT(I16_UNORM,               R16,                   UNORM, _),
194    AGX_FMT(I8_SINT,                 R8,                    SINT,  _),
195    AGX_FMT(I16_SINT,                R16,                   SINT,  _),
196    AGX_FMT(I32_SINT,                R32,                   SINT,  _),
197    AGX_FMT(I8_UINT,                 R8,                    UINT,  _),
198    AGX_FMT(I16_UINT,                R16,                   UINT,  _),
199    AGX_FMT(I32_UINT,                R32,                   UINT,  _),
200    AGX_FMT(I16_FLOAT,               R16,                   FLOAT, _),
201    AGX_FMT(I32_FLOAT,               R32,                   FLOAT, _),
202 
203    AGX_FMT(ETC1_RGB8,               ETC2_RGB8,             UNORM, _),
204    AGX_FMT(ETC2_RGB8,               ETC2_RGB8,             UNORM, _),
205    AGX_FMT(ETC2_SRGB8,              ETC2_RGB8,             UNORM, _),
206    AGX_FMT(ETC2_RGB8A1,             ETC2_RGB8A1,           UNORM, _),
207    AGX_FMT(ETC2_SRGB8A1,            ETC2_RGB8A1,           UNORM, _),
208    AGX_FMT(ETC2_RGBA8,              ETC2_RGBA8,            UNORM, _),
209    AGX_FMT(ETC2_SRGBA8,             ETC2_RGBA8,            UNORM, _),
210    AGX_FMT(ETC2_R11_UNORM,          EAC_R11,               UNORM, _),
211    AGX_FMT(ETC2_R11_SNORM,          EAC_R11,               SNORM, _),
212    AGX_FMT(ETC2_RG11_UNORM,         EAC_RG11,              UNORM, _),
213    AGX_FMT(ETC2_RG11_SNORM,         EAC_RG11,              SNORM, _),
214 
215    AGX_FMT(ASTC_4x4,                ASTC_4X4,              UNORM, _),
216    AGX_FMT(ASTC_5x4,                ASTC_5X4,              UNORM, _),
217    AGX_FMT(ASTC_5x5,                ASTC_5X5,              UNORM, _),
218    AGX_FMT(ASTC_6x5,                ASTC_6X5,              UNORM, _),
219    AGX_FMT(ASTC_6x6,                ASTC_6X6,              UNORM, _),
220    AGX_FMT(ASTC_8x5,                ASTC_8X5,              UNORM, _),
221    AGX_FMT(ASTC_8x6,                ASTC_8X6,              UNORM, _),
222    AGX_FMT(ASTC_8x8,                ASTC_8X8,              UNORM, _),
223    AGX_FMT(ASTC_10x5,               ASTC_10X5,             UNORM, _),
224    AGX_FMT(ASTC_10x6,               ASTC_10X6,             UNORM, _),
225    AGX_FMT(ASTC_10x8,               ASTC_10X8,             UNORM, _),
226    AGX_FMT(ASTC_10x10,              ASTC_10X10,            UNORM, _),
227    AGX_FMT(ASTC_12x10,              ASTC_12X10,            UNORM, _),
228    AGX_FMT(ASTC_12x12,              ASTC_12X12,            UNORM, _),
229 
230    AGX_FMT(ASTC_4x4_SRGB,           ASTC_4X4,              UNORM, _),
231    AGX_FMT(ASTC_5x4_SRGB,           ASTC_5X4,              UNORM, _),
232    AGX_FMT(ASTC_5x5_SRGB,           ASTC_5X5,              UNORM, _),
233    AGX_FMT(ASTC_6x5_SRGB,           ASTC_6X5,              UNORM, _),
234    AGX_FMT(ASTC_6x6_SRGB,           ASTC_6X6,              UNORM, _),
235    AGX_FMT(ASTC_8x5_SRGB,           ASTC_8X5,              UNORM, _),
236    AGX_FMT(ASTC_8x6_SRGB,           ASTC_8X6,              UNORM, _),
237    AGX_FMT(ASTC_8x8_SRGB,           ASTC_8X8,              UNORM, _),
238    AGX_FMT(ASTC_10x5_SRGB,          ASTC_10X5,             UNORM, _),
239    AGX_FMT(ASTC_10x6_SRGB,          ASTC_10X6,             UNORM, _),
240    AGX_FMT(ASTC_10x8_SRGB,          ASTC_10X8,             UNORM, _),
241    AGX_FMT(ASTC_10x10_SRGB,         ASTC_10X10,            UNORM, _),
242    AGX_FMT(ASTC_12x10_SRGB,         ASTC_12X10,            UNORM, _),
243    AGX_FMT(ASTC_12x12_SRGB,         ASTC_12X12,            UNORM, _),
244 
245    AGX_FMT(DXT1_RGB,                BC1,                   UNORM, _),
246    AGX_FMT(DXT1_RGBA,               BC1,                   UNORM, _),
247    AGX_FMT(DXT1_SRGB,               BC1,                   UNORM, _),
248    AGX_FMT(DXT1_SRGBA,              BC1,                   UNORM, _),
249    AGX_FMT(DXT3_RGBA,               BC2,                   UNORM, _),
250    AGX_FMT(DXT3_SRGBA,              BC2,                   UNORM, _),
251    AGX_FMT(DXT5_RGBA,               BC3,                   UNORM, _),
252    AGX_FMT(DXT5_SRGBA,              BC3,                   UNORM, _),
253    AGX_FMT(RGTC1_UNORM,             BC4,                   UNORM, _),
254    AGX_FMT(RGTC1_SNORM,             BC4,                   SNORM, _),
255    AGX_FMT(RGTC2_UNORM,             BC5,                   UNORM, _),
256    AGX_FMT(RGTC2_SNORM,             BC5,                   SNORM, _),
257    AGX_FMT(BPTC_RGB_FLOAT,          BC6H,                  FLOAT, _),
258    AGX_FMT(BPTC_RGB_UFLOAT,         BC6H_UFLOAT,           FLOAT, _),
259    AGX_FMT(BPTC_RGBA_UNORM,         BC7,                   UNORM, _),
260    AGX_FMT(BPTC_SRGBA,              BC7,                   UNORM, _),
261 };
262 /* clang-format on */
263