summaryrefslogtreecommitdiffstats
path: root/src/intel/vulkan/anv_entrypoints_gen.py
diff options
context:
space:
mode:
authorDylan Baker <[email protected]>2017-02-17 14:31:20 -0800
committerDylan Baker <[email protected]>2017-03-22 16:22:00 -0700
commit0d8e22c5e4a502f6e0ed08e20d51cd37e679a5c2 (patch)
treeb5b19e0bcd4f5c2ae40c35b8b73b03fa3a313492 /src/intel/vulkan/anv_entrypoints_gen.py
parentba1085c6943e87868b712ea4a6adf9f161c48c97 (diff)
anv: convert header generation in anv_entrypoints_gen.py to mako
This produces an identical file except for whitespace. Signed-off-by: Dylan Baker <[email protected]>
Diffstat (limited to 'src/intel/vulkan/anv_entrypoints_gen.py')
-rw-r--r--src/intel/vulkan/anv_entrypoints_gen.py77
1 files changed, 42 insertions, 35 deletions
diff --git a/src/intel/vulkan/anv_entrypoints_gen.py b/src/intel/vulkan/anv_entrypoints_gen.py
index 3bc9b46e2b9..7dd98f960ce 100644
--- a/src/intel/vulkan/anv_entrypoints_gen.py
+++ b/src/intel/vulkan/anv_entrypoints_gen.py
@@ -27,6 +27,8 @@ import os
import textwrap
import xml.etree.ElementTree as et
+from mako.template import Template
+
MAX_API_VERSION = 1.0
SUPPORTED_EXTENSIONS = [
@@ -48,6 +50,44 @@ SUPPORTED_EXTENSIONS = [
# function and a power-of-two size table. The prime numbers are determined
# experimentally.
+TEMPLATE_H = Template(textwrap.dedent("""\
+ /* This file generated from ${filename}, don't edit directly. */
+
+ struct anv_dispatch_table {
+ union {
+ void *entrypoints[${len(entrypoints)}];
+ struct {
+ % for _, name, _, _, _, guard in entrypoints:
+ % if guard is not None:
+ #ifdef ${guard}
+ PFN_vk${name} ${name};
+ #else
+ void *${name};
+ # endif
+ % else:
+ PFN_vk${name} ${name};
+ % endif
+ % endfor
+ };
+ };
+ };
+
+ void anv_set_dispatch_devinfo(const struct gen_device_info *info);
+ % for type_, name, args, num, h, guard in entrypoints:
+ % if guard is not None:
+ #ifdef ${guard}
+ % endif
+ ${type_} anv_${name}(${args});
+ ${type_} gen7_${name}(${args});
+ ${type_} gen75_${name}(${args});
+ ${type_} gen8_${name}(${args});
+ ${type_} gen9_${name}(${args});
+ % if guard is not None:
+ #endif // ${guard}
+ % endif
+ % endfor
+ """))
+
NONE = 0xffff
HASH_SIZE = 256
U32_MASK = 2**32 - 1
@@ -133,40 +173,6 @@ def get_entrypoints_defines(doc):
return entrypoints_to_defines
-def gen_header(entrypoints):
- print "/* This file generated from {}, don't edit directly. */\n".format(
- os.path.basename(__file__))
-
- print "struct anv_dispatch_table {"
- print " union {"
- print " void *entrypoints[%d];" % len(entrypoints)
- print " struct {"
-
- for type, name, args, num, h, guard in entrypoints:
- if guard is not None:
- print "#ifdef {0}".format(guard)
- print " PFN_vk{0} {0};".format(name)
- print "#else"
- print " void *{0};".format(name)
- print "#endif"
- else:
- print " PFN_vk{0} {0};".format(name)
- print " };\n"
- print " };\n"
- print "};\n"
-
- print "void anv_set_dispatch_devinfo(const struct gen_device_info *info);\n"
-
- for type, name, args, num, h, guard in entrypoints:
- print_guard_start(guard)
- print "%s anv_%s(%s);" % (type, name, args)
- print "%s gen7_%s(%s);" % (type, name, args)
- print "%s gen75_%s(%s);" % (type, name, args)
- print "%s gen8_%s(%s);" % (type, name, args)
- print "%s gen9_%s(%s);" % (type, name, args)
- print_guard_end(guard)
-
-
def gen_code(entrypoints):
print textwrap.dedent("""\
/*
@@ -375,7 +381,8 @@ def main():
# For outputting entrypoints.h we generate a anv_EntryPoint() prototype
# per entry point.
if args.target == 'header':
- gen_header(entrypoints)
+ print TEMPLATE_H.render(entrypoints=entrypoints,
+ filename=os.path.basename(__file__))
else:
gen_code(entrypoints)