xref: /third_party/mesa3d/src/asahi/lib/agx_formats.c (revision bf215546)
1/*
2 * Copyright (C) 2021 Alyssa Rosenzweig
3 *
4 * Permission is hereby granted, free of charge, to any person obtaining a
5 * copy of this software and associated documentation files (the "Software"),
6 * to deal in the Software without restriction, including without limitation
7 * the rights to use, copy, modify, merge, publish, distribute, sublicense,
8 * and/or sell copies of the Software, and to permit persons to whom the
9 * Software is furnished to do so, subject to the following conditions:
10 *
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
13 * Software.
14 *
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
18 * THE 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
21 * SOFTWARE.
22 */
23
24#include "agx_pack.h"
25#include "agx_formats.h"
26
27#define T true
28#define F false
29#define AGX_FORMAT__ 0
30
31#define AGX_FMT(pipe, channels, type, is_renderable, internal_fmt) \
32   [PIPE_FORMAT_ ## pipe] = { \
33      .hw = (AGX_CHANNELS_ ## channels) | ((AGX_TEXTURE_TYPE_ ## type) << 7), \
34      .renderable = is_renderable, \
35      .internal = AGX_FORMAT_ ## internal_fmt,\
36   }
37
38const struct agx_pixel_format_entry agx_pixel_format[PIPE_FORMAT_COUNT] = {
39   AGX_FMT(R8_UNORM,                R8,            UNORM,  T, U8NORM),
40   AGX_FMT(R8G8_UNORM,              R8G8,          UNORM,  T, U8NORM),
41   AGX_FMT(R8G8B8A8_UNORM,          R8G8B8A8,      UNORM,  T, U8NORM),
42   AGX_FMT(A8R8G8B8_UNORM,          R8G8B8A8,      UNORM,  T, U8NORM),
43   AGX_FMT(A8B8G8R8_UNORM,          R8G8B8A8,      UNORM,  T, U8NORM),
44   AGX_FMT(B8G8R8A8_UNORM,          R8G8B8A8,      UNORM,  T, U8NORM),
45
46   AGX_FMT(R16_UNORM,               R16,           UNORM,  T, U16NORM),
47   AGX_FMT(R16G16_UNORM,            R16G16,        UNORM,  T, U16NORM),
48   AGX_FMT(R16G16B16A16_UNORM,      R16G16B16A16,  UNORM,  T, U16NORM),
49
50   AGX_FMT(R8_SRGB,                 R8,            UNORM,  T, SRGBA8),
51   AGX_FMT(R8G8_SRGB,               R8G8,          UNORM,  T, SRGBA8),
52   AGX_FMT(R8G8B8A8_SRGB,           R8G8B8A8,      UNORM,  T, SRGBA8),
53   AGX_FMT(A8R8G8B8_SRGB,           R8G8B8A8,      UNORM,  T, SRGBA8),
54   AGX_FMT(A8B8G8R8_SRGB,           R8G8B8A8,      UNORM,  T, SRGBA8),
55   AGX_FMT(B8G8R8A8_SRGB,           R8G8B8A8,      UNORM,  T, SRGBA8),
56
57   AGX_FMT(R8_SNORM,                R8,            SNORM,  T, S8NORM),
58   AGX_FMT(R8G8_SNORM,              R8G8,          SNORM,  T, S8NORM),
59   AGX_FMT(R8G8B8A8_SNORM,          R8G8B8A8,      SNORM,  T, S8NORM),
60   AGX_FMT(A8R8G8B8_SNORM,          R8G8B8A8,      SNORM,  T, S8NORM),
61   AGX_FMT(A8B8G8R8_SNORM,          R8G8B8A8,      SNORM,  T, S8NORM),
62   AGX_FMT(B8G8R8A8_SNORM,          R8G8B8A8,      SNORM,  T, S8NORM),
63
64   AGX_FMT(R16_FLOAT,               R16,           FLOAT,  T, F16),
65   AGX_FMT(R16G16_FLOAT,            R16G16,        FLOAT,  T, F16),
66   AGX_FMT(R16G16B16A16_FLOAT,      R16G16B16A16,  FLOAT,  T, F16),
67
68   AGX_FMT(R32_FLOAT,               R32,           FLOAT,  T, I32),
69   AGX_FMT(R32G32_FLOAT,            R32G32,        FLOAT,  T, I32),
70   AGX_FMT(R32G32B32A32_FLOAT,      R32G32B32A32,  FLOAT,  T, I32),
71
72   AGX_FMT(R8_UINT,                 R8,            UINT,   T, I8),
73   AGX_FMT(R8G8_UINT,               R8G8,          UINT,   T, I8),
74   AGX_FMT(R8G8B8A8_UINT,           R8G8B8A8,      UINT,   T, I8),
75
76   AGX_FMT(R16_UINT,                R16,           UINT,   T, I16),
77   AGX_FMT(R16G16_UINT,             R16G16,        UINT,   T, I16),
78   AGX_FMT(R16G16B16A16_UINT,       R16G16B16A16,  UINT,   T, I16),
79
80   AGX_FMT(R32_UINT,                R32,           UINT,   T, I32),
81   AGX_FMT(R32G32_UINT,             R32G32,        UINT,   T, I32),
82   AGX_FMT(R32G32B32A32_UINT,       R32G32B32A32,  UINT,   T, I32),
83
84   AGX_FMT(R8_SINT,                 R8,            SINT,   T, I8),
85   AGX_FMT(R8G8_SINT,               R8G8,          SINT,   T, I8),
86   AGX_FMT(R8G8B8A8_SINT,           R8G8B8A8,      SINT,   T, I8),
87
88   AGX_FMT(R16_SINT,                R16,           SINT,   T, I16),
89   AGX_FMT(R16G16_SINT,             R16G16,        SINT,   T, I16),
90   AGX_FMT(R16G16B16A16_SINT,       R16G16B16A16,  SINT,   T, I16),
91
92   AGX_FMT(R32_SINT,                R32,           SINT,   T, I32),
93   AGX_FMT(R32G32_SINT,             R32G32,        SINT,   T, I32),
94   AGX_FMT(R32G32B32A32_SINT,       R32G32B32A32,  SINT,   T, I32),
95
96   AGX_FMT(Z16_UNORM,               R16,           UNORM,  F, _),
97   AGX_FMT(Z32_FLOAT,               R32,           FLOAT,  F, _),
98   AGX_FMT(Z32_FLOAT_S8X24_UINT,    R32,           FLOAT,  F, _),
99
100   /* These must be lowered by u_transfer_helper to Z32F */
101   AGX_FMT(Z24X8_UNORM,             R32,           FLOAT,  F, _),
102   AGX_FMT(Z24_UNORM_S8_UINT,       R32,           FLOAT,  F, _),
103
104   AGX_FMT(R10G10B10A2_UNORM,       R10G10B10A2,   UNORM,  T, RGB10A2),
105   AGX_FMT(B10G10R10A2_UNORM,       R10G10B10A2,   UNORM,  T, RGB10A2),
106
107   AGX_FMT(R10G10B10A2_UINT,        R10G10B10A2,   UINT,   T, _),
108   AGX_FMT(B10G10R10A2_UINT,        R10G10B10A2,   UINT,   T, _),
109
110   AGX_FMT(R10G10B10A2_SINT,        R10G10B10A2,   SINT,   T, _),
111   AGX_FMT(B10G10R10A2_SINT,        R10G10B10A2,   SINT,   T, _),
112
113   AGX_FMT(R11G11B10_FLOAT,         R11G11B10,     FLOAT,  T, RG11B10F),
114   AGX_FMT(R9G9B9E5_FLOAT,          R9G9B9E5,      FLOAT,  F, RGB9E5),
115
116   AGX_FMT(ETC2_RGB8,               ETC2_RGB8,     UNORM,  F,_),
117   AGX_FMT(ETC2_SRGB8,              ETC2_RGB8,     UNORM,  F,_),
118   AGX_FMT(ETC2_RGB8A1,             ETC2_RGB8A1,   UNORM,  F,_),
119   AGX_FMT(ETC2_SRGB8A1,            ETC2_RGB8A1,   UNORM,  F,_),
120   AGX_FMT(ETC2_RGBA8,              ETC2_RGBA8,    UNORM,  F,_),
121   AGX_FMT(ETC2_SRGBA8,             ETC2_RGBA8,    UNORM,  F,_),
122   AGX_FMT(ETC2_R11_UNORM,          EAC_R11,       UNORM,  F,_),
123   AGX_FMT(ETC2_R11_SNORM,          EAC_R11,       SNORM,  F,_),
124   AGX_FMT(ETC2_RG11_UNORM,         EAC_RG11,      UNORM,  F,_),
125   AGX_FMT(ETC2_RG11_SNORM,         EAC_RG11,      SNORM,  F,_),
126};
127
128const enum agx_format
129agx_vertex_format[PIPE_FORMAT_COUNT] = {
130   [PIPE_FORMAT_R32_FLOAT] = AGX_FORMAT_I32,
131   [PIPE_FORMAT_R32_SINT] = AGX_FORMAT_I32,
132   [PIPE_FORMAT_R32_UINT] = AGX_FORMAT_I32,
133   [PIPE_FORMAT_R32G32_FLOAT] = AGX_FORMAT_I32,
134   [PIPE_FORMAT_R32G32_SINT] = AGX_FORMAT_I32,
135   [PIPE_FORMAT_R32G32_UINT] = AGX_FORMAT_I32,
136   [PIPE_FORMAT_R32G32B32_FLOAT] = AGX_FORMAT_I32,
137   [PIPE_FORMAT_R32G32B32_UINT] = AGX_FORMAT_I32,
138   [PIPE_FORMAT_R32G32B32_SINT] = AGX_FORMAT_I32,
139   [PIPE_FORMAT_R32G32B32A32_FLOAT] = AGX_FORMAT_I32,
140   [PIPE_FORMAT_R32G32B32A32_UINT] = AGX_FORMAT_I32,
141   [PIPE_FORMAT_R32G32B32A32_SINT] = AGX_FORMAT_I32,
142
143   [PIPE_FORMAT_R8_UNORM] = AGX_FORMAT_U8NORM,
144   [PIPE_FORMAT_R8G8_UNORM] = AGX_FORMAT_U8NORM,
145   [PIPE_FORMAT_R8G8B8_UNORM] = AGX_FORMAT_U8NORM,
146   [PIPE_FORMAT_R8G8B8A8_UNORM] = AGX_FORMAT_U8NORM,
147
148   [PIPE_FORMAT_R8_SNORM] = AGX_FORMAT_S8NORM,
149   [PIPE_FORMAT_R8G8_SNORM] = AGX_FORMAT_S8NORM,
150   [PIPE_FORMAT_R8G8B8_SNORM] = AGX_FORMAT_S8NORM,
151   [PIPE_FORMAT_R8G8B8A8_SNORM] = AGX_FORMAT_S8NORM,
152
153   [PIPE_FORMAT_R16_UNORM] = AGX_FORMAT_U16NORM,
154   [PIPE_FORMAT_R16G16_UNORM] = AGX_FORMAT_U16NORM,
155   [PIPE_FORMAT_R16G16B16_UNORM] = AGX_FORMAT_U16NORM,
156   [PIPE_FORMAT_R16G16B16A16_UNORM] = AGX_FORMAT_U16NORM,
157
158   [PIPE_FORMAT_R16_SNORM] = AGX_FORMAT_S16NORM,
159   [PIPE_FORMAT_R16G16_SNORM] = AGX_FORMAT_S16NORM,
160   [PIPE_FORMAT_R16G16B16_SNORM] = AGX_FORMAT_S16NORM,
161   [PIPE_FORMAT_R16G16B16A16_SNORM] = AGX_FORMAT_S16NORM,
162
163   [PIPE_FORMAT_R8_UINT] = AGX_FORMAT_I8,
164   [PIPE_FORMAT_R8G8_UINT] = AGX_FORMAT_I8,
165   [PIPE_FORMAT_R8G8B8_UINT] = AGX_FORMAT_I8,
166   [PIPE_FORMAT_R8G8B8A8_UINT] = AGX_FORMAT_I8,
167
168   [PIPE_FORMAT_R8_SINT] = AGX_FORMAT_I8,
169   [PIPE_FORMAT_R8G8_SINT] = AGX_FORMAT_I8,
170   [PIPE_FORMAT_R8G8B8_SINT] = AGX_FORMAT_I8,
171   [PIPE_FORMAT_R8G8B8A8_SINT] = AGX_FORMAT_I8,
172
173   [PIPE_FORMAT_R16_UINT] = AGX_FORMAT_I16,
174   [PIPE_FORMAT_R16G16_UINT] = AGX_FORMAT_I16,
175   [PIPE_FORMAT_R16G16B16_UINT] = AGX_FORMAT_I16,
176   [PIPE_FORMAT_R16G16B16A16_UINT] = AGX_FORMAT_I16,
177
178   [PIPE_FORMAT_R16_SINT] = AGX_FORMAT_I16,
179   [PIPE_FORMAT_R16G16_SINT] = AGX_FORMAT_I16,
180   [PIPE_FORMAT_R16G16B16_SINT] = AGX_FORMAT_I16,
181   [PIPE_FORMAT_R16G16B16A16_SINT] = AGX_FORMAT_I16,
182
183   [PIPE_FORMAT_R32_UINT] = AGX_FORMAT_I32,
184   [PIPE_FORMAT_R32G32_UINT] = AGX_FORMAT_I32,
185   [PIPE_FORMAT_R32G32B32_UINT] = AGX_FORMAT_I32,
186   [PIPE_FORMAT_R32G32B32A32_UINT] = AGX_FORMAT_I32,
187
188   [PIPE_FORMAT_R32_SINT] = AGX_FORMAT_I32,
189   [PIPE_FORMAT_R32G32_SINT] = AGX_FORMAT_I32,
190   [PIPE_FORMAT_R32G32B32_SINT] = AGX_FORMAT_I32,
191   [PIPE_FORMAT_R32G32B32A32_SINT] = AGX_FORMAT_I32,
192};
193