• Home
  • Line#
  • Scopes#
  • Navigate#
  • Raw
  • Download
1// Copyright 2015-2023 The Khronos Group Inc.
2//
3// SPDX-License-Identifier: CC-BY-4.0
4
5[appendix]
6[[compressed_image_formats]]
7= Compressed Image Formats
8
9The compressed texture formats used by Vulkan are described in the
10specifically identified sections of the <<data-format,Khronos Data Format
11Specification>>, version 1.3.
12
13Unless otherwise described, the quantities encoded in these compressed
14formats are treated as normalized, unsigned values.
15
16Those formats listed as sRGB-encoded have in-memory representations of
17[eq]#R#, [eq]#G# and [eq]#B# components which are nonlinearly-encoded as
18[eq]#R'#, [eq]#G'#, and [eq]#B'#; any alpha component is unchanged.
19As part of filtering, the nonlinear [eq]#R'#, [eq]#G'#, and [eq]#B'# values
20are converted to linear [eq]#R#, [eq]#G#, and [eq]#B# components; any alpha
21component is unchanged.
22The conversion between linear and nonlinear encoding is performed as
23described in the "`KHR_DF_TRANSFER_SRGB`" section of the Khronos Data Format
24Specification.
25
26<<<
27
28[[appendix-compressedtex-bc]]
29== Block-Compressed Image Formats
30
31BC1, BC2 and BC3 formats are described in "`S3TC Compressed Texture Image
32Formats`" chapter of the <<data-format,Khronos Data Format Specification>>.
33BC4 and BC5 are described in the "`RGTC Compressed Texture Image Formats`"
34chapter.
35BC6H and BC7 are described in the "`BPTC Compressed Texture Image Formats`"
36chapter.
37
38.Mapping of Vulkan BC formats to descriptions
39[width="90%",options="header",cols="5,4"]
40|====
41| elink:VkFormat | <<data-format,Khronos Data Format Specification>> description
422+^| Formats described in the "`S3TC Compressed Texture Image Formats`" chapter
43| ename:VK_FORMAT_BC1_RGB_UNORM_BLOCK |BC1 with no alpha
44| ename:VK_FORMAT_BC1_RGB_SRGB_BLOCK  |BC1 with no alpha, sRGB-encoded
45| ename:VK_FORMAT_BC1_RGBA_UNORM_BLOCK|BC1 with alpha
46| ename:VK_FORMAT_BC1_RGBA_SRGB_BLOCK |BC1 with alpha, sRGB-encoded
47| ename:VK_FORMAT_BC2_UNORM_BLOCK     |BC2
48| ename:VK_FORMAT_BC2_SRGB_BLOCK      |BC2, sRGB-encoded
49| ename:VK_FORMAT_BC3_UNORM_BLOCK     |BC3
50| ename:VK_FORMAT_BC3_SRGB_BLOCK      |BC3, sRGB-encoded
512+^| Formats described in the "`RGTC Compressed Texture Image Formats`" chapter
52| ename:VK_FORMAT_BC4_UNORM_BLOCK     |BC4 unsigned
53| ename:VK_FORMAT_BC4_SNORM_BLOCK     |BC4 signed
54| ename:VK_FORMAT_BC5_UNORM_BLOCK     |BC5 unsigned
55| ename:VK_FORMAT_BC5_SNORM_BLOCK     |BC5 signed
562+^| Formats described in the "`BPTC Compressed Texture Image Formats`" chapter
57| ename:VK_FORMAT_BC6H_UFLOAT_BLOCK   |BC6H (unsigned version)
58| ename:VK_FORMAT_BC6H_SFLOAT_BLOCK   |BC6H (signed version)
59| ename:VK_FORMAT_BC7_UNORM_BLOCK     |BC7
60| ename:VK_FORMAT_BC7_SRGB_BLOCK      |BC7, sRGB-encoded
61|====
62
63<<<
64
65[[appendix-compressedtex-etc2]]
66== ETC Compressed Image Formats
67
68The following formats are described in the "`ETC2 Compressed Texture Image
69Formats`" chapter of the <<data-format,Khronos Data Format Specification>>.
70
71.Mapping of Vulkan ETC formats to descriptions
72[options="header",cols="1,1"]
73|====
74| elink:VkFormat | <<data-format,Khronos Data Format Specification>> description
75| ename:VK_FORMAT_ETC2_R8G8B8_UNORM_BLOCK     |RGB ETC2
76| ename:VK_FORMAT_ETC2_R8G8B8_SRGB_BLOCK      |RGB ETC2 with sRGB encoding
77| ename:VK_FORMAT_ETC2_R8G8B8A1_UNORM_BLOCK   |RGB ETC2 with punch-through alpha
78| ename:VK_FORMAT_ETC2_R8G8B8A1_SRGB_BLOCK    |RGB ETC2 with punch-through alpha and sRGB
79| ename:VK_FORMAT_ETC2_R8G8B8A8_UNORM_BLOCK   |RGBA ETC2
80| ename:VK_FORMAT_ETC2_R8G8B8A8_SRGB_BLOCK    |RGBA ETC2 with sRGB encoding
81| ename:VK_FORMAT_EAC_R11_UNORM_BLOCK         |Unsigned R11 EAC
82| ename:VK_FORMAT_EAC_R11_SNORM_BLOCK         |Signed R11 EAC
83| ename:VK_FORMAT_EAC_R11G11_UNORM_BLOCK      |Unsigned RG11 EAC
84| ename:VK_FORMAT_EAC_R11G11_SNORM_BLOCK      |Signed RG11 EAC
85|====
86
87<<<
88
89[[appendix-compressedtex-astc]]
90== ASTC Compressed Image Formats
91
92ASTC formats are described in the "`ASTC Compressed Texture Image Formats`"
93chapter of the <<data-format,Khronos Data Format Specification>>.
94
95.Mapping of Vulkan ASTC formats to descriptions
96[width="90%",options="header",cols="55%,20%,25%"]
97|====
98| elink:VkFormat ^| Compressed texel block dimensions ^| Requested mode
99| ename:VK_FORMAT_ASTC_4x4_UNORM_BLOCK        ^|[eq]#4 {times} 4#   ^|Linear LDR
100| ename:VK_FORMAT_ASTC_4x4_SRGB_BLOCK         ^|[eq]#4 {times} 4#   ^|sRGB
101| ename:VK_FORMAT_ASTC_5x4_UNORM_BLOCK        ^|[eq]#5 {times} 4#   ^|Linear LDR
102| ename:VK_FORMAT_ASTC_5x4_SRGB_BLOCK         ^|[eq]#5 {times} 4#   ^|sRGB
103| ename:VK_FORMAT_ASTC_5x5_UNORM_BLOCK        ^|[eq]#5 {times} 5#   ^|Linear LDR
104| ename:VK_FORMAT_ASTC_5x5_SRGB_BLOCK         ^|[eq]#5 {times} 5#   ^|sRGB
105| ename:VK_FORMAT_ASTC_6x5_UNORM_BLOCK        ^|[eq]#6 {times} 5#   ^|Linear LDR
106| ename:VK_FORMAT_ASTC_6x5_SRGB_BLOCK         ^|[eq]#6 {times} 5#   ^|sRGB
107| ename:VK_FORMAT_ASTC_6x6_UNORM_BLOCK        ^|[eq]#6 {times} 6#   ^|Linear LDR
108| ename:VK_FORMAT_ASTC_6x6_SRGB_BLOCK         ^|[eq]#6 {times} 6#   ^|sRGB
109| ename:VK_FORMAT_ASTC_8x5_UNORM_BLOCK        ^|[eq]#8 {times} 5#   ^|Linear LDR
110| ename:VK_FORMAT_ASTC_8x5_SRGB_BLOCK         ^|[eq]#8 {times} 5#   ^|sRGB
111| ename:VK_FORMAT_ASTC_8x6_UNORM_BLOCK        ^|[eq]#8 {times} 6#   ^|Linear LDR
112| ename:VK_FORMAT_ASTC_8x6_SRGB_BLOCK         ^|[eq]#8 {times} 6#   ^|sRGB
113| ename:VK_FORMAT_ASTC_8x8_UNORM_BLOCK        ^|[eq]#8 {times} 8#   ^|Linear LDR
114| ename:VK_FORMAT_ASTC_8x8_SRGB_BLOCK         ^|[eq]#8 {times} 8#   ^|sRGB
115| ename:VK_FORMAT_ASTC_10x5_UNORM_BLOCK       ^|[eq]#10 {times} 5#  ^|Linear LDR
116| ename:VK_FORMAT_ASTC_10x5_SRGB_BLOCK        ^|[eq]#10 {times} 5#  ^|sRGB
117| ename:VK_FORMAT_ASTC_10x6_UNORM_BLOCK       ^|[eq]#10 {times} 6#  ^|Linear LDR
118| ename:VK_FORMAT_ASTC_10x6_SRGB_BLOCK        ^|[eq]#10 {times} 6#  ^|sRGB
119| ename:VK_FORMAT_ASTC_10x8_UNORM_BLOCK       ^|[eq]#10 {times} 8#  ^|Linear LDR
120| ename:VK_FORMAT_ASTC_10x8_SRGB_BLOCK        ^|[eq]#10 {times} 8#  ^|sRGB
121| ename:VK_FORMAT_ASTC_10x10_UNORM_BLOCK      ^|[eq]#10 {times} 10# ^|Linear LDR
122| ename:VK_FORMAT_ASTC_10x10_SRGB_BLOCK       ^|[eq]#10 {times} 10# ^|sRGB
123| ename:VK_FORMAT_ASTC_12x10_UNORM_BLOCK      ^|[eq]#12 {times} 10# ^|Linear LDR
124| ename:VK_FORMAT_ASTC_12x10_SRGB_BLOCK       ^|[eq]#12 {times} 10# ^|sRGB
125| ename:VK_FORMAT_ASTC_12x12_UNORM_BLOCK      ^|[eq]#12 {times} 12# ^|Linear LDR
126| ename:VK_FORMAT_ASTC_12x12_SRGB_BLOCK       ^|[eq]#12 {times} 12# ^|sRGB
127ifdef::VK_VERSION_1_3,VK_EXT_texture_compression_astc_hdr[]
128| ename:VK_FORMAT_ASTC_4x4_SFLOAT_BLOCK       ^|[eq]#4 {times} 4#   ^|HDR
129| ename:VK_FORMAT_ASTC_5x4_SFLOAT_BLOCK       ^|[eq]#5 {times} 4#   ^|HDR
130| ename:VK_FORMAT_ASTC_5x5_SFLOAT_BLOCK       ^|[eq]#5 {times} 5#   ^|HDR
131| ename:VK_FORMAT_ASTC_6x5_SFLOAT_BLOCK       ^|[eq]#6 {times} 5#   ^|HDR
132| ename:VK_FORMAT_ASTC_6x6_SFLOAT_BLOCK       ^|[eq]#6 {times} 6#   ^|HDR
133| ename:VK_FORMAT_ASTC_8x5_SFLOAT_BLOCK       ^|[eq]#8 {times} 5#   ^|HDR
134| ename:VK_FORMAT_ASTC_8x6_SFLOAT_BLOCK       ^|[eq]#8 {times} 6#   ^|HDR
135| ename:VK_FORMAT_ASTC_8x8_SFLOAT_BLOCK       ^|[eq]#8 {times} 8#   ^|HDR
136| ename:VK_FORMAT_ASTC_10x5_SFLOAT_BLOCK      ^|[eq]#10 {times} 5#  ^|HDR
137| ename:VK_FORMAT_ASTC_10x6_SFLOAT_BLOCK      ^|[eq]#10 {times} 6#  ^|HDR
138| ename:VK_FORMAT_ASTC_10x8_SFLOAT_BLOCK      ^|[eq]#10 {times} 8#  ^|HDR
139| ename:VK_FORMAT_ASTC_10x10_SFLOAT_BLOCK     ^|[eq]#10 {times} 10# ^|HDR
140| ename:VK_FORMAT_ASTC_12x10_SFLOAT_BLOCK     ^|[eq]#12 {times} 10# ^|HDR
141| ename:VK_FORMAT_ASTC_12x12_SFLOAT_BLOCK     ^|[eq]#12 {times} 12# ^|HDR
142endif::VK_VERSION_1_3,VK_EXT_texture_compression_astc_hdr[]
143|====
144
145ifndef::VK_VERSION_1_3,VK_EXT_texture_compression_astc_hdr[]
146ASTC textures containing any HDR blocks should: not be passed into the API
147using an sRGB or UNORM texture format.
148endif::VK_VERSION_1_3,VK_EXT_texture_compression_astc_hdr[]
149ifdef::VK_VERSION_1_3,VK_EXT_texture_compression_astc_hdr[]
150ASTC textures containing HDR block encodings should: be passed to the API
151using an ASTC SFLOAT texture format.
152endif::VK_VERSION_1_3,VK_EXT_texture_compression_astc_hdr[]
153
154[NOTE]
155.Note
156====
157An HDR block in a texture passed using a LDR UNORM format will return the
158appropriate ASTC error color if the implementation supports only the ASTC
159LDR profile, but may result in either the error color or a decompressed HDR
160color if the implementation supports HDR decoding.
161====
162
163ifdef::VK_EXT_astc_decode_mode[]
164
165=== ASTC Decode Mode
166
167If the `VK_EXT_astc_decode_mode` extension is enabled, the decode mode is
168determined as follows:
169
170.Mapping of Vulkan ASTC decoding format to ASTC decoding modes
171[width="75%",options="header",cols="75%,25%"]
172|====
173| elink:VkFormat ^| Decoding mode
174| ename:VK_FORMAT_R16G16B16A16_SFLOAT    ^| decode_float16
175| ename:VK_FORMAT_R8G8B8A8_UNORM         ^| decode_unorm8
176| ename:VK_FORMAT_E5B9G9R9_UFLOAT_PACK32 ^| decode_rgb9e5
177|====
178
179Otherwise, the ASTC decode mode is decode_float16.
180
181Note that an implementation may: use HDR mode when linear LDR mode is
182requested unless the decode mode is decode_unorm8.
183endif::VK_EXT_astc_decode_mode[]
184ifndef::VK_EXT_astc_decode_mode[]
185The ASTC decode mode is decode_float16.
186
187Note that an implementation may: use HDR mode when linear LDR mode is
188requested.
189endif::VK_EXT_astc_decode_mode[]
190
191
192ifdef::VK_IMG_format_pvrtc[]
193<<<
194
195[[appendix-compressedtex-pvrtc]]
196== PVRTC Compressed Image Formats
197
198PVRTC formats are described in the "`PVRTC Compressed Texture Image
199Formats`" chapter of the <<data-format,Khronos Data Format Specification>>.
200
201.Mapping of Vulkan PVRTC formats to descriptions
202[width="75%",options="header",cols="63%,15%,22%"]
203|====
204| elink:VkFormat ^| Compressed texel block dimensions ^| sRGB-encoded
205| ename:VK_FORMAT_PVRTC1_2BPP_UNORM_BLOCK_IMG  ^|[eq]#8 {times} 4# ^|No
206| ename:VK_FORMAT_PVRTC1_4BPP_UNORM_BLOCK_IMG  ^|[eq]#4 {times} 4# ^|No
207| ename:VK_FORMAT_PVRTC2_2BPP_UNORM_BLOCK_IMG  ^|[eq]#8 {times} 4# ^|No
208| ename:VK_FORMAT_PVRTC2_4BPP_UNORM_BLOCK_IMG  ^|[eq]#4 {times} 4# ^|No
209| ename:VK_FORMAT_PVRTC1_2BPP_SRGB_BLOCK_IMG   ^|[eq]#8 {times} 4# ^|Yes
210| ename:VK_FORMAT_PVRTC1_4BPP_SRGB_BLOCK_IMG   ^|[eq]#4 {times} 4# ^|Yes
211| ename:VK_FORMAT_PVRTC2_2BPP_SRGB_BLOCK_IMG   ^|[eq]#8 {times} 4# ^|Yes
212| ename:VK_FORMAT_PVRTC2_4BPP_SRGB_BLOCK_IMG   ^|[eq]#4 {times} 4# ^|Yes
213|====
214endif::VK_IMG_format_pvrtc[]
215