<div dir="ltr"><div class="gmail_extra"><div class="gmail_quote">On Mon, Jul 17, 2017 at 10:09 AM, Ian Romanick <span dir="ltr"><<a href="mailto:idr@freedesktop.org" target="_blank">idr@freedesktop.org</a>></span> wrote:<br><blockquote class="gmail_quote" style="margin:0 0 0 .8ex;border-left:1px #ccc solid;padding-left:1ex"><span class="">On 07/14/2017 09:22 PM, Jason Ekstrand wrote:<br>
> On Fri, Jul 14, 2017 at 6:39 PM, Ian Romanick <<a href="mailto:idr@freedesktop.org">idr@freedesktop.org</a><br>
</span><span class="">> <mailto:<a href="mailto:idr@freedesktop.org">idr@freedesktop.org</a>>> wrote:<br>
><br>
>     From: Ian Romanick <<a href="mailto:ian.d.romanick@intel.com">ian.d.romanick@intel.com</a><br>
</span>>     <mailto:<a href="mailto:ian.d.romanick@intel.com">ian.d.romanick@intel.<wbr>com</a>>><br>
<span class="">><br>
>     The old table based spirv_*_to_string functions would return NULL for<br>
>     any values "inside" the table that didn't have entries.  The tables also<br>
>     needed to be updated by hand each time a new spirv.h was imported.<br>
>     Generate the file instead.<br>
><br>
><br>
> Thanks for working on this!  This is way better than having a<br>
> hand-rolled table that requires updating.<br>
<br>
</span>The one unfortunate thing is that spirv.h and spirv.core.grammar.json<br>
need to be updated together.<br>
<br>
>     Signed-off-by: Ian Romanick <<a href="mailto:ian.d.romanick@intel.com">ian.d.romanick@intel.com</a><br>
>     <mailto:<a href="mailto:ian.d.romanick@intel.com">ian.d.romanick@intel.<wbr>com</a>>><br>
>     Suggested-by: Jason Ekstrand <<a href="mailto:jason@jlekstrand.net">jason@jlekstrand.net</a><br>
>     <mailto:<a href="mailto:jason@jlekstrand.net">jason@jlekstrand.net</a>>><br>
<span class="">>     ---<br>
>     I am pretty sure the scons changes are bogus... halp, plz?<br>
><br>
><br>
> I'm going to let Emil review your autotools and write you some Android.mk.<br>
><br>
><br>
>      src/compiler/Makefile.am           |   2 +<br>
</span>>      src/compiler/<a href="http://Makefile.nir.am" rel="noreferrer" target="_blank">Makefile.nir.am</a> <<a href="http://Makefile.nir.am" rel="noreferrer" target="_blank">http://Makefile.nir.am</a>>       |   1 +<br>
>      src/compiler/Makefile.sources      |   4 +-<br>
>      src/compiler/<a href="http://Makefile.spirv.am" rel="noreferrer" target="_blank">Makefile.spirv.am</a> <<a href="http://Makefile.spirv.am" rel="noreferrer" target="_blank">http://Makefile.spirv.am</a>>     |  31<br>
<span class="">>     ++++++++<br>
>      src/compiler/SConscript            |   1 +<br>
>      src/compiler/SConscript.spirv      |  32 ++++++++<br>
>      src/compiler/spirv/spirv_info.<wbr>c    | 156<br>
>     ------------------------------<wbr>-------<br>
>      src/compiler/spirv/spirv_info_<wbr>c.py |  90 +++++++++++++++++++++<br>
>      8 files changed, 160 insertions(+), 157 deletions(-)<br>
>      create mode 100644 src/compiler/<a href="http://Makefile.spirv.am" rel="noreferrer" target="_blank">Makefile.spirv.am</a><br>
</span>>     <<a href="http://Makefile.spirv.am" rel="noreferrer" target="_blank">http://Makefile.spirv.am</a>><br>
<span class="">>      create mode 100644 src/compiler/SConscript.spirv<br>
>      delete mode 100644 src/compiler/spirv/spirv_info.<wbr>c<br>
>      create mode 100644 src/compiler/spirv/spirv_info_<wbr>c.py<br>
><br>
>     diff --git a/src/compiler/Makefile.am b/src/compiler/Makefile.am<br>
>     index 4c83365..b8f6697 100644<br>
>     --- a/src/compiler/Makefile.am<br>
>     +++ b/src/compiler/Makefile.am<br>
>     @@ -63,3 +63,5 @@ PYTHON_GEN = $(AM_V_GEN)$(PYTHON2) $(PYTHON_FLAGS)<br>
</span>>      include <a href="http://Makefile.glsl.am" rel="noreferrer" target="_blank">Makefile.glsl.am</a> <<a href="http://Makefile.glsl.am" rel="noreferrer" target="_blank">http://Makefile.glsl.am</a>><br>
><br>
>      include <a href="http://Makefile.nir.am" rel="noreferrer" target="_blank">Makefile.nir.am</a> <<a href="http://Makefile.nir.am" rel="noreferrer" target="_blank">http://Makefile.nir.am</a>><br>
>     +<br>
>     +include <a href="http://Makefile.spirv.am" rel="noreferrer" target="_blank">Makefile.spirv.am</a> <<a href="http://Makefile.spirv.am" rel="noreferrer" target="_blank">http://Makefile.spirv.am</a>><br>
>     diff --git a/src/compiler/<a href="http://Makefile.nir.am" rel="noreferrer" target="_blank">Makefile.nir.am</a> <<a href="http://Makefile.nir.am" rel="noreferrer" target="_blank">http://Makefile.nir.am</a>><br>
>     b/src/compiler/<a href="http://Makefile.nir.am" rel="noreferrer" target="_blank">Makefile.nir.am</a> <<a href="http://Makefile.nir.am" rel="noreferrer" target="_blank">http://Makefile.nir.am</a>><br>
>     index 13f02a7..d10f173 100644<br>
>     --- a/src/compiler/<a href="http://Makefile.nir.am" rel="noreferrer" target="_blank">Makefile.nir.am</a> <<a href="http://Makefile.nir.am" rel="noreferrer" target="_blank">http://Makefile.nir.am</a>><br>
>     +++ b/src/compiler/<a href="http://Makefile.nir.am" rel="noreferrer" target="_blank">Makefile.nir.am</a> <<a href="http://Makefile.nir.am" rel="noreferrer" target="_blank">http://Makefile.nir.am</a>><br>
<div><div class="h5">>     @@ -29,6 +29,7 @@ nir_libnir_la_LIBADD = \<br>
>      nir_libnir_la_SOURCES =                                        \<br>
>             $(NIR_FILES)                                    \<br>
>             $(SPIRV_FILES)                                  \<br>
>     +       $(SPIRV_GENERATED_FILES)                        \<br>
>             $(NIR_GENERATED_FILES)<br>
><br>
>      nir/nir_builder_opcodes.h: nir/nir_opcodes.py<br>
>     nir/nir_builder_opcodes_h.py<br>
>     diff --git a/src/compiler/Makefile.<wbr>sources<br>
>     b/src/compiler/Makefile.<wbr>sources<br>
>     index d3447fb..785782b 100644<br>
>     --- a/src/compiler/Makefile.<wbr>sources<br>
>     +++ b/src/compiler/Makefile.<wbr>sources<br>
>     @@ -277,12 +277,14 @@ NIR_FILES = \<br>
>             nir/nir_worklist.c \<br>
>             nir/nir_worklist.h<br>
><br>
>     +SPIRV_GENERATED_FILES = \<br>
>     +       spirv/spirv_info.c<br>
>     +<br>
>      SPIRV_FILES = \<br>
>             spirv/GLSL.std.450.h \<br>
>             spirv/nir_spirv.h \<br>
>             spirv/spirv.h \<br>
>             spirv/spirv_info.h \<br>
>     -       spirv/spirv_info.c \<br>
>             spirv/spirv_to_nir.c \<br>
>             spirv/vtn_alu.c \<br>
>             spirv/vtn_cfg.c \<br>
>     diff --git a/src/compiler/<a href="http://Makefile.spirv.am" rel="noreferrer" target="_blank">Makefile.spirv.<wbr>am</a><br>
</div></div>>     <<a href="http://Makefile.spirv.am" rel="noreferrer" target="_blank">http://Makefile.spirv.am</a>> b/src/compiler/<a href="http://Makefile.spirv.am" rel="noreferrer" target="_blank">Makefile.spirv.<wbr>am</a><br>
>     <<a href="http://Makefile.spirv.am" rel="noreferrer" target="_blank">http://Makefile.spirv.am</a>><br>
<span class="">>     new file mode 100644<br>
>     index 0000000..6d5dfc0<br>
>     --- /dev/null<br>
</span>>     +++ b/src/compiler/<a href="http://Makefile.spirv.am" rel="noreferrer" target="_blank">Makefile.spirv.<wbr>am</a> <<a href="http://Makefile.spirv.am" rel="noreferrer" target="_blank">http://Makefile.spirv.am</a>><br>
<div><div class="h5">>     @@ -0,0 +1,31 @@<br>
>     +# Copyright (C) 2017 Intel Corporation<br>
>     +#<br>
>     +# Permission is hereby granted, free of charge, to any person<br>
>     obtaining a<br>
>     +# copy of this software and associated documentation files (the<br>
>     "Software"),<br>
>     +# to deal in the Software without restriction, including without<br>
>     limitation<br>
>     +# the rights to use, copy, modify, merge, publish, distribute,<br>
>     sublicense,<br>
>     +# and/or sell copies of the Software, and to permit persons to whom the<br>
>     +# Software is furnished to do so, subject to the following conditions:<br>
>     +#<br>
>     +# The above copyright notice and this permission notice (including<br>
>     the next<br>
>     +# paragraph) shall be included in all copies or substantial<br>
>     portions of the<br>
>     +# Software.<br>
>     +#<br>
>     +# THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND,<br>
>     EXPRESS OR<br>
>     +# IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF<br>
>     MERCHANTABILITY,<br>
>     +# FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT.  IN NO<br>
>     EVENT SHALL<br>
>     +# THE AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES<br>
>     OR OTHER<br>
>     +# LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE,<br>
>     ARISING<br>
>     +# FROM, OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR<br>
>     OTHER DEALINGS<br>
>     +# IN THE SOFTWARE.<br>
>     +<br>
>     +spirv/spirv_info.c: spirv/spirv_info_c.py spirv/spirv.core.grammar.json<br>
>     +       $(MKDIR_GEN)<br>
>     +       $(PYTHON_GEN) $(srcdir)/spirv/spirv_info_c.<wbr>py > $@ || ($(RM)<br>
>     $@; false)<br>
><br>
><br>
> I'm sorry for all the pain I'm sure this caused you...  Being the first<br>
> one to add auto-generation to a directory is the worst...<br>
<br>
</div></div>It turns out that the biggest problem was me typoing SPRIV instead of<br>
SPIRV in a couple places.  Once Ken pointed that out to me, everything<br>
worked.  Sigh...<br>
<div><div class="h5"><br>
>     +<br>
>     +BUILT_SOURCES += $(SPIRV_GENERATED_FILES)<br>
>     +CLEANFILES += $(SPIRV_GENERATED_FILES)<br>
>     +<br>
>     +EXTRA_DIST += \<br>
>     +       spirv/spirv_info_c.py \<br>
>     +       spirv/spirv.core.grammar.json<br>
>     diff --git a/src/compiler/SConscript b/src/compiler/SConscript<br>
>     index 44509a9..2797abe 100644<br>
>     --- a/src/compiler/SConscript<br>
>     +++ b/src/compiler/SConscript<br>
>     @@ -26,4 +26,5 @@ compiler = env.ConvenienceLibrary(<br>
>      Export('compiler')<br>
><br>
>      SConscript('SConscript.glsl')<br>
>     +SConscript('SConscript.spirv'<wbr>)<br>
>      SConscript('SConscript.nir')<br>
>     diff --git a/src/compiler/SConscript.<wbr>spirv<br>
>     b/src/compiler/SConscript.<wbr>spirv<br>
>     new file mode 100644<br>
>     index 0000000..8a90c2f<br>
>     --- /dev/null<br>
>     +++ b/src/compiler/SConscript.<wbr>spirv<br>
>     @@ -0,0 +1,32 @@<br>
>     +import common<br>
>     +<br>
>     +Import('*')<br>
>     +<br>
>     +from sys import executable as python_cmd<br>
>     +<br>
>     +env = env.Clone()<br>
>     +<br>
>     +env.MSVC2013Compat()<br>
>     +<br>
>     +env.Prepend(CPPPATH = [<br>
>     +    '#include',<br>
>     +    '#src',<br>
>     +    '#src/mapi',<br>
>     +    '#src/mesa',<br>
>     +    '#src/gallium/include',<br>
>     +    '#src/gallium/auxiliary',<br>
>     +    '#src/compiler/nir',<br>
>     +])<br>
>     +<br>
>     +# Make generated headers reachable from the include path.<br>
>     +env.Prepend(CPPPATH = [Dir('.').abspath, Dir('glsl').abspath])<br>
>     +env.Prepend(CPPPATH = [Dir('.').abspath, Dir('nir').abspath])<br>
>     +<br>
>     +# SPIR-V generated sources<br>
>     +<br>
>     +spirv_info_c = env.CodeGenerate(<br>
>     +    target = 'spirv/spirv_info.c',<br>
>     +    script = 'spirv/spirv_info_c.py',<br>
>     +    source = [],<br>
>     +    command = python_cmd + ' $SCRIPT > $TARGET'<br>
>     +)<br>
>     diff --git a/src/compiler/spirv/spirv_<wbr>info.c<br>
>     b/src/compiler/spirv/spirv_<wbr>info.c<br>
>     deleted file mode 100644<br>
>     index 1036b41..0000000<br>
>     --- a/src/compiler/spirv/spirv_<wbr>info.c<br>
>     +++ /dev/null<br>
>     @@ -1,156 +0,0 @@<br>
>     -/*<br>
>     - * Copyright © 2016 Intel Corporation<br>
>     - *<br>
>     - * Permission is hereby granted, free of charge, to any person<br>
>     obtaining a<br>
>     - * copy of this software and associated documentation files (the<br>
>     "Software"),<br>
>     - * to deal in the Software without restriction, including without<br>
>     limitation<br>
>     - * the rights to use, copy, modify, merge, publish, distribute,<br>
>     sublicense,<br>
>     - * and/or sell copies of the Software, and to permit persons to<br>
>     whom the<br>
>     - * Software is furnished to do so, subject to the following conditions:<br>
>     - *<br>
>     - * The above copyright notice and this permission notice (including<br>
>     the next<br>
>     - * paragraph) shall be included in all copies or substantial<br>
>     portions of the<br>
>     - * Software.<br>
>     - *<br>
>     - * THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND,<br>
>     EXPRESS OR<br>
>     - * IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF<br>
>     MERCHANTABILITY,<br>
>     - * FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT.  IN NO<br>
>     EVENT SHALL<br>
>     - * THE AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM,<br>
>     DAMAGES OR OTHER<br>
>     - * LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE,<br>
>     ARISING<br>
>     - * FROM, OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR<br>
>     OTHER DEALINGS<br>
>     - * IN THE SOFTWARE.<br>
>     - */<br>
>     -<br>
>     -#include "spirv_info.h"<br>
>     -#include "util/macros.h"<br>
>     -<br>
>     -#define CAPABILITY(cap) [SpvCapability##cap] = #cap<br>
>     -static const char * const capability_to_string[] = {<br>
>     -   CAPABILITY(Matrix),<br>
>     -   CAPABILITY(Shader),<br>
>     -   CAPABILITY(Geometry),<br>
>     -   CAPABILITY(Tessellation),<br>
>     -   CAPABILITY(Addresses),<br>
>     -   CAPABILITY(Linkage),<br>
>     -   CAPABILITY(Kernel),<br>
>     -   CAPABILITY(Vector16),<br>
>     -   CAPABILITY(Float16Buffer),<br>
>     -   CAPABILITY(Float16),<br>
>     -   CAPABILITY(Float64),<br>
>     -   CAPABILITY(Int64),<br>
>     -   CAPABILITY(Int64Atomics),<br>
>     -   CAPABILITY(ImageBasic),<br>
>     -   CAPABILITY(ImageReadWrite),<br>
>     -   CAPABILITY(ImageMipmap),<br>
>     -   CAPABILITY(Pipes),<br>
>     -   CAPABILITY(Groups),<br>
>     -   CAPABILITY(DeviceEnqueue),<br>
>     -   CAPABILITY(LiteralSampler),<br>
>     -   CAPABILITY(AtomicStorage),<br>
>     -   CAPABILITY(Int16),<br>
>     -   CAPABILITY(<wbr>TessellationPointSize),<br>
>     -   CAPABILITY(GeometryPointSize),<br>
>     -   CAPABILITY(<wbr>ImageGatherExtended),<br>
>     -   CAPABILITY(<wbr>StorageImageMultisample),<br>
>     -   CAPABILITY(<wbr>UniformBufferArrayDynamicIndex<wbr>ing),<br>
>     -   CAPABILITY(<wbr>SampledImageArrayDynamicIndexi<wbr>ng),<br>
>     -   CAPABILITY(<wbr>StorageBufferArrayDynamicIndex<wbr>ing),<br>
>     -   CAPABILITY(<wbr>StorageImageArrayDynamicIndexi<wbr>ng),<br>
>     -   CAPABILITY(ClipDistance),<br>
>     -   CAPABILITY(CullDistance),<br>
>     -   CAPABILITY(ImageCubeArray),<br>
>     -   CAPABILITY(SampleRateShading),<br>
>     -   CAPABILITY(ImageRect),<br>
>     -   CAPABILITY(SampledRect),<br>
>     -   CAPABILITY(GenericPointer),<br>
>     -   CAPABILITY(Int8),<br>
>     -   CAPABILITY(InputAttachment),<br>
>     -   CAPABILITY(SparseResidency),<br>
>     -   CAPABILITY(MinLod),<br>
>     -   CAPABILITY(Sampled1D),<br>
>     -   CAPABILITY(Image1D),<br>
>     -   CAPABILITY(SampledCubeArray),<br>
>     -   CAPABILITY(SampledBuffer),<br>
>     -   CAPABILITY(ImageBuffer),<br>
>     -   CAPABILITY(ImageMSArray),<br>
>     -   CAPABILITY(<wbr>StorageImageExtendedFormats),<br>
>     -   CAPABILITY(ImageQuery),<br>
>     -   CAPABILITY(DerivativeControl),<br>
>     -   CAPABILITY(<wbr>InterpolationFunction),<br>
>     -   CAPABILITY(TransformFeedback),<br>
>     -   CAPABILITY(GeometryStreams),<br>
>     -   CAPABILITY(<wbr>StorageImageReadWithoutFormat)<wbr>,<br>
>     -   CAPABILITY(<wbr>StorageImageWriteWithoutFormat<wbr>),<br>
>     -   CAPABILITY(MultiViewport),<br>
>     -   CAPABILITY(SubgroupDispatch),<br>
>     -   CAPABILITY(NamedBarrier),<br>
>     -   CAPABILITY(PipeStorage),<br>
>     -   CAPABILITY(SubgroupBallotKHR),<br>
>     -   CAPABILITY(DrawParameters),<br>
>     -};<br>
>     -<br>
>     -const char *<br>
>     -spirv_capability_to_string(<wbr>SpvCapability cap)<br>
>     -{<br>
>     -   if (cap < ARRAY_SIZE(capability_to_<wbr>string))<br>
>     -      return capability_to_string[cap];<br>
>     -   else<br>
>     -      return "unknown";<br>
>     -}<br>
>     -<br>
>     -#define DECORATION(dec) [SpvDecoration##dec] = #dec<br>
>     -static const char * const decoration_to_string[] = {<br>
>     -   DECORATION(RelaxedPrecision),<br>
>     -   DECORATION(SpecId),<br>
>     -   DECORATION(Block),<br>
>     -   DECORATION(BufferBlock),<br>
>     -   DECORATION(RowMajor),<br>
>     -   DECORATION(ColMajor),<br>
>     -   DECORATION(ArrayStride),<br>
>     -   DECORATION(MatrixStride),<br>
>     -   DECORATION(GLSLShared),<br>
>     -   DECORATION(GLSLPacked),<br>
>     -   DECORATION(CPacked),<br>
>     -   DECORATION(BuiltIn),<br>
>     -   DECORATION(NoPerspective),<br>
>     -   DECORATION(Flat),<br>
>     -   DECORATION(Patch),<br>
>     -   DECORATION(Centroid),<br>
>     -   DECORATION(Sample),<br>
>     -   DECORATION(Invariant),<br>
>     -   DECORATION(Restrict),<br>
>     -   DECORATION(Aliased),<br>
>     -   DECORATION(Volatile),<br>
>     -   DECORATION(Constant),<br>
>     -   DECORATION(Coherent),<br>
>     -   DECORATION(NonWritable),<br>
>     -   DECORATION(NonReadable),<br>
>     -   DECORATION(Uniform),<br>
>     -   DECORATION(<wbr>SaturatedConversion),<br>
>     -   DECORATION(Stream),<br>
>     -   DECORATION(Location),<br>
>     -   DECORATION(Component),<br>
>     -   DECORATION(Index),<br>
>     -   DECORATION(Binding),<br>
>     -   DECORATION(DescriptorSet),<br>
>     -   DECORATION(Offset),<br>
>     -   DECORATION(XfbBuffer),<br>
>     -   DECORATION(XfbStride),<br>
>     -   DECORATION(FuncParamAttr),<br>
>     -   DECORATION(FPRoundingMode),<br>
>     -   DECORATION(FPFastMathMode),<br>
>     -   DECORATION(LinkageAttributes),<br>
>     -   DECORATION(NoContraction),<br>
>     -   DECORATION(<wbr>InputAttachmentIndex),<br>
>     -   DECORATION(Alignment),<br>
>     -   DECORATION(MaxByteOffset),<br>
>     -};<br>
>     -<br>
>     -const char *<br>
>     -spirv_decoration_to_string(<wbr>SpvDecoration dec)<br>
>     -{<br>
>     -   if (dec < ARRAY_SIZE(decoration_to_<wbr>string))<br>
>     -      return decoration_to_string[dec];<br>
>     -   else<br>
>     -      return "unknown";<br>
>     -}<br>
>     diff --git a/src/compiler/spirv/spirv_<wbr>info_c.py<br>
>     b/src/compiler/spirv/spirv_<wbr>info_c.py<br>
>     new file mode 100644<br>
>     index 0000000..5af832e<br>
>     --- /dev/null<br>
>     +++ b/src/compiler/spirv/spirv_<wbr>info_c.py<br>
>     @@ -0,0 +1,90 @@<br>
>     +# -*- coding: utf-8 -*-<br>
>     +<br>
>     +# Copyright © 2017 Intel Corporation<br>
>     +#<br>
>     +# Permission is hereby granted, free of charge, to any person<br>
>     obtaining a<br>
>     +# copy of this software and associated documentation files (the<br>
>     "Software"),<br>
>     +# to deal in the Software without restriction, including without<br>
>     limitation<br>
>     +# the rights to use, copy, modify, merge, publish, distribute,<br>
>     sublicense,<br>
>     +# and/or sell copies of the Software, and to permit persons to whom the<br>
>     +# Software is furnished to do so, subject to the following conditions:<br>
>     +#<br>
>     +# The above copyright notice and this permission notice (including<br>
>     the next<br>
>     +# paragraph) shall be included in all copies or substantial<br>
>     portions of the<br>
>     +# Software.<br>
>     +#<br>
>     +# THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND,<br>
>     EXPRESS OR<br>
>     +# IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF<br>
>     MERCHANTABILITY,<br>
>     +# FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT.  IN NO<br>
>     EVENT SHALL<br>
>     +# THE AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES<br>
>     OR OTHER<br>
>     +# LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE,<br>
>     ARISING<br>
>     +# FROM, OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR<br>
>     OTHER DEALINGS<br>
>     +# IN THE SOFTWARE.<br>
><br>
><br>
> What you have is fine here but I've been really liking the style that's<br>
> used in mesa/main/format_fallbacks.py and the anv_extensions.py that I<br>
> sent out which does<br>
><br>
> COPYRIGHT="""<br>
> \* The usual C copyright<br>
>  */<br>
> """<br>
<br>
</div></div>I've done this in some other places where the same copyright is used<br>
with multiple templates.  In the GLX protocol scripts, I actually had a<br>
function that generated the copyright boilerplate parameterized with a<br>
list of copyright holders.  Maybe to reduce the copy-and-paste we should<br>
make something like that generally available?<span class=""><br></span></blockquote><div><br></div><div>Generally available things tend to be painful in Python because you have to set the python path if you ever want to import anything that isn't in your directory.  That doesn't mean we shouldn't do it, just that the pain may be too high.  Also, having a copyright block at the top of the file as suggested means that the python file still has a copyright block.<br></div><div> </div><blockquote class="gmail_quote" style="margin:0 0 0 .8ex;border-left:1px #ccc solid;padding-left:1ex"><span class="">
> and then maybe some functions and then<br>
><br>
> TEMPLATE = mako.template.Template(<wbr>COPYRIGHT + """<br>
> /* My template goes here */<br>
> """)<br>
><br>
> Followed by the main function.  Putting the template inside the main<br>
> function (or if statement in this case) means the indentation gets<br>
> really weird.<br>
><br>
><br>
>     +<br>
>     +import json<br>
>     +import mako.template<br>
>     +<br>
>     +def collect_data(spirv, kind):<br>
>     +    for x in spirv["operand_kinds"]:<br>
>     +        if x["kind"] == kind:<br>
>     +            operands = x<br>
><br>
><br>
> break?<br>
<br>
</span>Yes.  I originally structured this a bit differently (finding both<br>
Capability and Decoration in one loop), and that didn't need a break<br>
here.  I'll add it.<br>
<span class=""><br>
>     +<br>
>     +    # There are some duplicate values in some of the tables (thanks<br>
>     guys!), so<br>
>     +    # filter them out.<br>
><br>
><br>
> That's unfortunate...<br>
><br>
><br>
>     +    last_value = -1<br>
>     +    values = []<br>
>     +    for x in operands["enumerants"]:<br>
>     +        if x["value"] != last_value:<br>
>     +            last_value = x["value"]<br>
>     +            values.append(x["enumerant"])<br>
><br>
><br>
> This assumes that the duplicate values will be sequential.  Is that<br>
> always the case?  I suppose it isn't since the C compiles.  Maybe better<br>
> to use a set and do<br>
><br>
> if x["value"] not in seen_values:<br>
>    seen_values.add(x["value"])<br>
><br>
> What you have here works though so we can always make that change later<br>
> if it's ever a problem.<br>
<br>
</span>Right now there are two pairs of duplicated values, and they appear<br>
sequentially in the file.  This happens because the names are currently<br>
sorted by value.  I don't know if that will always be the case, but I've<br>
made that assumption in another script too.  I considered a more complex<br>
scheme for dealing with this that used another table to track names by<br>
value, but I opted for simpler.<br></blockquote><div><br></div><div>That's fair.  We can always change it if this ever becomes a problem.<br></div><div> </div><blockquote class="gmail_quote" style="margin:0 0 0 .8ex;border-left:1px #ccc solid;padding-left:1ex">
        {<br>
          "enumerant" : "StorageBuffer16BitAccess",<br>
          "value" : 4433,<br>
          "extensions" : [ "SPV_KHR_16bit_storage" ]<br>
        },<br>
        {<br>
          "enumerant" : "StorageUniformBufferBlock16",<br>
          "value" : 4433,<br>
          "extensions" : [ "SPV_KHR_16bit_storage" ]<br>
        },<br>
        {<br>
          "enumerant" : "<wbr>UniformAndStorageBuffer16BitAc<wbr>cess",<br>
          "value" : 4434,<br>
          "capabilities" : [<br>
            "StorageBuffer16BitAccess",<br>
            "StorageUniformBufferBlock16"<br>
          ],<br>
          "extensions" : [ "SPV_KHR_16bit_storage" ]<br>
        },<br>
        {<br>
          "enumerant" : "StorageUniform16",<br>
          "value" : 4434,<br>
          "capabilities" : [<br>
            "StorageBuffer16BitAccess",<br>
            "StorageUniformBufferBlock16"<br>
          ],<br>
          "extensions" : [ "SPV_KHR_16bit_storage" ]<br>
        },<br>
<br>
One of the pairs is used as a dependency, and both are listed.  This<br>
isn't relevant for this script, but it was a hassle for another that I'm<br>
writing.<br>
<br>
        {<br>
          "enumerant" : "<wbr>UniformAndStorageBuffer16BitAc<wbr>cess",<br>
          "value" : 4434,<br>
          "capabilities" : [<br>
            "StorageBuffer16BitAccess",<br>
            "StorageUniformBufferBlock16"<br>
          ],<br>
          "extensions" : [ "SPV_KHR_16bit_storage" ]<br>
        },<br>
        {<br>
          "enumerant" : "StorageUniform16",<br>
          "value" : 4434,<br>
          "capabilities" : [<br>
            "StorageBuffer16BitAccess",<br>
            "StorageUniformBufferBlock16"<br>
          ],<br>
          "extensions" : [ "SPV_KHR_16bit_storage" ]<br>
        },<br>
<div><div class="h5"><br>
>     +<br>
>     +    return (kind, values)<br>
>     +<br>
>     +if __name__ == "__main__":<br>
>     +    t = mako.template.Template("""/*<br>
>     + * Copyright (C) 2017 Intel Corporation<br>
>     + *<br>
>     + * Permission is hereby granted, free of charge, to any person<br>
>     obtaining a<br>
>     + * copy of this software and associated documentation files (the<br>
>     "Software"),<br>
>     + * to deal in the Software without restriction, including without<br>
>     limitation<br>
>     + * the rights to use, copy, modify, merge, publish, distribute,<br>
>     sublicense,<br>
>     + * and/or sell copies of the Software, and to permit persons to<br>
>     whom the<br>
>     + * Software is furnished to do so, subject to the following conditions:<br>
>     + *<br>
>     + * The above copyright notice and this permission notice (including<br>
>     the next<br>
>     + * paragraph) shall be included in all copies or substantial<br>
>     portions of the<br>
>     + * Software.<br>
>     + *<br>
>     + * THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND,<br>
>     EXPRESS OR<br>
>     + * IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF<br>
>     MERCHANTABILITY,<br>
>     + * FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT.  IN NO<br>
>     EVENT SHALL<br>
>     + * THE AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM,<br>
>     DAMAGES OR OTHER<br>
>     + * LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE,<br>
>     ARISING<br>
>     + * FROM, OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER<br>
>     + * DEALINGS IN THE SOFTWARE.<br>
>     + */<br>
>     +<br>
>     +#include "spirv_info.h"<br>
>     +    % for kind,values in info:<br>
><br>
><br>
> Dylan will probably tell you to indent your C code along with the mako.<br>
> I, personally, don't care.  If anything, I would just dedent all the<br>
> mako by a step.  But I don't really care all that much.  It's readable<br>
> as-is and we don't really have a mako style guide.<br>
><br>
><br>
>     +<br>
>     +const char *<br>
>     +spirv_${kind.lower()}_to_<wbr>string(Spv${kind} v)<br>
>     +{<br>
>     +   switch (v) {<br>
>     +        % for name in values:<br>
>     +   case Spv${kind}${name}: return "Spv${kind}${name}";<br>
>     +        % endfor<br>
>     +   case Spv${kind}Max: break; /* silence warnings about unhandled<br>
>     enums. */<br>
>     +   }<br>
>     +<br>
>     +   return "unknown";<br>
>     +}<br>
>     +    % endfor<br>
>     +""")<br>
>     +<br>
>     +    spirv_info =<br>
>     json.JSONDecoder().decode(<wbr>open("spirv/spirv.core.<wbr>grammar.json",<br>
>     "r").read())<br>
>     +<br>
>     +    capabilities = collect_data(spirv_info, "Capability")<br>
>     +    decorations = collect_data(spirv_info, "Decoration")<br>
>     +<br>
>     +    print(t.render(info=[<wbr>capabilities, decorations]))<br>
><br>
><br>
> The more recent generators have started using python's argparse and have<br>
> --xml (or --json in this case) parameter for the input and --out for the<br>
> output.  Take a look at mesa/main/format_fallbacks.py for an example.<br>
> Having the generator write the output file makes adding it to automake a<br>
> bit easier to do correctly.<br>
<br>
</div></div>That's a good suggestion.  I'll look into that.  I wasn't terribly happy<br>
with hard coding the path.<br>
<br>
> --Jason<br>
</blockquote></div><br></div></div>