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