mesa: Fix bug in unclamped float to ubyte conversion.
[mesa.git] / src / gallium / auxiliary / util / u_format_table.py
1 #!/usr/bin/env python
2
3 CopyRight = '''
4 /**************************************************************************
5 *
6 * Copyright 2010 VMware, Inc.
7 * All Rights Reserved.
8 *
9 * Permission is hereby granted, free of charge, to any person obtaining a
10 * copy of this software and associated documentation files (the
11 * "Software"), to deal in the Software without restriction, including
12 * without limitation the rights to use, copy, modify, merge, publish,
13 * distribute, sub license, and/or sell copies of the Software, and to
14 * permit persons to whom the Software is furnished to do so, subject to
15 * the following conditions:
16 *
17 * The above copyright notice and this permission notice (including the
18 * next paragraph) shall be included in all copies or substantial portions
19 * of the Software.
20 *
21 * THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS
22 * OR IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF
23 * MERCHANTABILITY, FITNESS FOR A PARTICULAR PURPOSE AND NON-INFRINGEMENT.
24 * IN NO EVENT SHALL VMWARE AND/OR ITS SUPPLIERS BE LIABLE FOR
25 * ANY CLAIM, DAMAGES OR OTHER LIABILITY, WHETHER IN AN ACTION OF CONTRACT,
26 * TORT OR OTHERWISE, ARISING FROM, OUT OF OR IN CONNECTION WITH THE
27 * SOFTWARE OR THE USE OR OTHER DEALINGS IN THE SOFTWARE.
28 *
29 **************************************************************************/
30 '''
31
32
33 import sys
34
35 from u_format_parse import *
36 import u_format_pack
37
38
39 def layout_map(layout):
40 return 'UTIL_FORMAT_LAYOUT_' + str(layout).upper()
41
42
43 def colorspace_map(colorspace):
44 return 'UTIL_FORMAT_COLORSPACE_' + str(colorspace).upper()
45
46
47 colorspace_channels_map = {
48 'rgb': ['r', 'g', 'b', 'a'],
49 'srgb': ['sr', 'sg', 'sb', 'a'],
50 'zs': ['z', 's'],
51 'yuv': ['y', 'u', 'v'],
52 }
53
54
55 type_map = {
56 VOID: "UTIL_FORMAT_TYPE_VOID",
57 UNSIGNED: "UTIL_FORMAT_TYPE_UNSIGNED",
58 SIGNED: "UTIL_FORMAT_TYPE_SIGNED",
59 FIXED: "UTIL_FORMAT_TYPE_FIXED",
60 FLOAT: "UTIL_FORMAT_TYPE_FLOAT",
61 }
62
63
64 def bool_map(value):
65 if value:
66 return "TRUE"
67 else:
68 return "FALSE"
69
70
71 swizzle_map = {
72 SWIZZLE_X: "UTIL_FORMAT_SWIZZLE_X",
73 SWIZZLE_Y: "UTIL_FORMAT_SWIZZLE_Y",
74 SWIZZLE_Z: "UTIL_FORMAT_SWIZZLE_Z",
75 SWIZZLE_W: "UTIL_FORMAT_SWIZZLE_W",
76 SWIZZLE_0: "UTIL_FORMAT_SWIZZLE_0",
77 SWIZZLE_1: "UTIL_FORMAT_SWIZZLE_1",
78 SWIZZLE_NONE: "UTIL_FORMAT_SWIZZLE_NONE",
79 }
80
81
82 def write_format_table(formats):
83 print '/* This file is autogenerated by u_format_table.py from u_format.csv. Do not edit directly. */'
84 print
85 # This will print the copyright message on the top of this file
86 print CopyRight.strip()
87 print
88 print '#include "u_format.h"'
89 print '#include "u_format_s3tc.h"'
90 print '#include "u_format_rgtc.h"'
91 print '#include "u_format_latc.h"'
92 print '#include "u_format_etc.h"'
93 print
94
95 u_format_pack.generate(formats)
96
97 for format in formats:
98 print 'const struct util_format_description'
99 print 'util_format_%s_description = {' % (format.short_name(),)
100 print " %s," % (format.name,)
101 print " \"%s\"," % (format.name,)
102 print " \"%s\"," % (format.short_name(),)
103 print " {%u, %u, %u},\t/* block */" % (format.block_width, format.block_height, format.block_size())
104 print " %s," % (layout_map(format.layout),)
105 print " %u,\t/* nr_channels */" % (format.nr_channels(),)
106 print " %s,\t/* is_array */" % (bool_map(format.is_array()),)
107 print " %s,\t/* is_bitmask */" % (bool_map(format.is_bitmask()),)
108 print " %s,\t/* is_mixed */" % (bool_map(format.is_mixed()),)
109 print " {"
110 for i in range(4):
111 channel = format.channels[i]
112 if i < 3:
113 sep = ","
114 else:
115 sep = ""
116 if channel.size:
117 print " {%s, %s, %s, %u}%s\t/* %s = %s */" % (type_map[channel.type], bool_map(channel.norm), bool_map(channel.pure), channel.size, sep, "xyzw"[i], channel.name)
118 else:
119 print " {0, 0, 0, 0}%s" % (sep,)
120 print " },"
121 print " {"
122 for i in range(4):
123 swizzle = format.swizzles[i]
124 if i < 3:
125 sep = ","
126 else:
127 sep = ""
128 try:
129 comment = colorspace_channels_map[format.colorspace][i]
130 except (KeyError, IndexError):
131 comment = 'ignored'
132 print " %s%s\t/* %s */" % (swizzle_map[swizzle], sep, comment)
133 print " },"
134 print " %s," % (colorspace_map(format.colorspace),)
135 if format.colorspace != ZS and format.channels[0].pure == False:
136 print " &util_format_%s_unpack_rgba_8unorm," % format.short_name()
137 print " &util_format_%s_pack_rgba_8unorm," % format.short_name()
138 if format.layout == 's3tc' or format.layout == 'rgtc':
139 print " &util_format_%s_fetch_rgba_8unorm," % format.short_name()
140 else:
141 print " NULL, /* fetch_rgba_8unorm */"
142 print " &util_format_%s_unpack_rgba_float," % format.short_name()
143 print " &util_format_%s_pack_rgba_float," % format.short_name()
144 print " &util_format_%s_fetch_rgba_float," % format.short_name()
145 else:
146 print " NULL, /* unpack_rgba_8unorm */"
147 print " NULL, /* pack_rgba_8unorm */"
148 print " NULL, /* fetch_rgba_8unorm */"
149 print " NULL, /* unpack_rgba_float */"
150 print " NULL, /* pack_rgba_float */"
151 print " NULL, /* fetch_rgba_float */"
152 if format.colorspace == ZS and format.swizzles[0] != SWIZZLE_NONE:
153 print " &util_format_%s_unpack_z_32unorm," % format.short_name()
154 print " &util_format_%s_pack_z_32unorm," % format.short_name()
155 print " &util_format_%s_unpack_z_float," % format.short_name()
156 print " &util_format_%s_pack_z_float," % format.short_name()
157 else:
158 print " NULL, /* unpack_z_32unorm */"
159 print " NULL, /* pack_z_32unorm */"
160 print " NULL, /* unpack_z_float */"
161 print " NULL, /* pack_z_float */"
162 if format.colorspace == ZS and format.swizzles[1] != SWIZZLE_NONE:
163 print " &util_format_%s_unpack_s_8uint," % format.short_name()
164 print " &util_format_%s_pack_s_8uint," % format.short_name()
165 else:
166 print " NULL, /* unpack_s_8uint */"
167 print " NULL, /* pack_s_8uint */"
168 if format.colorspace != ZS and format.channels[0].pure == True and format.channels[0].type == UNSIGNED:
169 print " &util_format_%s_unpack_unsigned, /* unpack_rgba_uint */" % format.short_name()
170 print " &util_format_%s_pack_unsigned, /* pack_rgba_uint */" % format.short_name()
171 print " &util_format_%s_unpack_signed, /* unpack_rgba_sint */" % format.short_name()
172 print " &util_format_%s_pack_signed, /* pack_rgba_sint */" % format.short_name()
173 print " &util_format_%s_fetch_unsigned, /* fetch_rgba_uint */" % format.short_name()
174 print " NULL /* fetch_rgba_sint */"
175 elif format.colorspace != ZS and format.channels[0].pure == True and format.channels[0].type == SIGNED:
176 print " &util_format_%s_unpack_unsigned, /* unpack_rgba_uint */" % format.short_name()
177 print " &util_format_%s_pack_unsigned, /* pack_rgba_uint */" % format.short_name()
178 print " &util_format_%s_unpack_signed, /* unpack_rgba_sint */" % format.short_name()
179 print " &util_format_%s_pack_signed, /* pack_rgba_sint */" % format.short_name()
180 print " NULL, /* fetch_rgba_uint */"
181 print " &util_format_%s_fetch_signed /* fetch_rgba_sint */" % format.short_name()
182 else:
183 print " NULL, /* unpack_rgba_uint */"
184 print " NULL, /* pack_rgba_uint */"
185 print " NULL, /* unpack_rgba_sint */"
186 print " NULL, /* pack_rgba_sint */"
187 print " NULL, /* fetch_rgba_uint */"
188 print " NULL /* fetch_rgba_sint */"
189 print "};"
190 print
191
192 print "const struct util_format_description *"
193 print "util_format_description(enum pipe_format format)"
194 print "{"
195 print " if (format >= PIPE_FORMAT_COUNT) {"
196 print " return NULL;"
197 print " }"
198 print
199 print " switch (format) {"
200 for format in formats:
201 print " case %s:" % format.name
202 print " return &util_format_%s_description;" % (format.short_name(),)
203 print " default:"
204 print " return NULL;"
205 print " }"
206 print "}"
207 print
208
209
210 def main():
211
212 formats = []
213 for arg in sys.argv[1:]:
214 formats.extend(parse(arg))
215 write_format_table(formats)
216
217
218 if __name__ == '__main__':
219 main()