aboutsummaryrefslogtreecommitdiff
path: root/sem6/dig/m2/generate_test_file.py
diff options
context:
space:
mode:
authorJulian T <julian@jtle.dk>2021-02-08 16:16:54 +0100
committerJulian T <julian@jtle.dk>2021-02-08 16:16:54 +0100
commit8a37c059748673e14f352fa70dbf974f33310c43 (patch)
tree8de5665d9445ee08e57ab0ffe11bd1dff3836b61 /sem6/dig/m2/generate_test_file.py
parentb7693c4b70ba2514d9007891b267f1876473258e (diff)
Add Makefile and testgenerator to run vhdl files
Diffstat (limited to 'sem6/dig/m2/generate_test_file.py')
-rwxr-xr-xsem6/dig/m2/generate_test_file.py76
1 files changed, 76 insertions, 0 deletions
diff --git a/sem6/dig/m2/generate_test_file.py b/sem6/dig/m2/generate_test_file.py
new file mode 100755
index 0000000..c450f02
--- /dev/null
+++ b/sem6/dig/m2/generate_test_file.py
@@ -0,0 +1,76 @@
+#!/usr/bin/env python
+import json
+import argparse
+import re
+import sys
+import os
+import jinja2 as j2
+
+test_define_re = re.compile("TEST_START(.*)TEST_STOP")
+
+parser = argparse.ArgumentParser()
+parser.add_argument("file", help="vhdl file to read from")
+parser.add_argument("output", help="vhdl file to save to")
+
+args = parser.parse_args()
+
+def load_file_def(fname):
+ filecontent = ""
+ with open(fname, "r") as f:
+ filecontent = f.read()
+
+ groups = test_define_re.search(filecontent).groups()
+ if groups:
+ return json.loads(groups[0])
+ else:
+ print("No def in file", f=sys.stderr)
+
+test_def = load_file_def(args.file)
+name = os.path.splitext(args.file)[0]
+
+# Generate test file, by running all inputs TODO make this more configurable
+
+testbed_template = j2.Template("""
+library IEEE;
+use IEEE.STD_LOGIC_1164.all;
+
+entity test_{{name}} is
+end test_{{name}};
+
+architecture behavior of test_{{name}} is
+ component {{name}} is
+ port (
+ {% for input in inputs %}{{input}}: in std_logic;
+ {% endfor %}{% for output in outputs %}{{output}}: out std_logic{% if not loop.last %};{% endif %}
+ {% endfor %});
+ end component;
+ signal input : std_logic_vector({{ num_inputs - 1 }} downto 0);
+ signal output : std_logic_vector({{ num_inputs - 1 }} downto 0);
+begin
+ uut: {{name}} port map (
+ {% for input in inputs %}{{input}} => input({{loop.index-1}}),
+ {% endfor %}{% for output in outputs %}{{output}} => output({{loop.index-1}}){% if not loop.last %},{% endif %}{% endfor %}
+ );
+
+ stim_proc: process
+ begin
+ {% for test in testin %}
+ input <= "{{test}}"; wait for 1 fs;
+ {% endfor %}
+ wait;
+ end process;
+end;
+""")
+
+render = testbed_template.render(
+ name=name,
+ inputs=test_def["inputs"],
+ num_inputs=len(test_def["inputs"]),
+ outputs=test_def["outputs"],
+ num_outputs=len(test_def["outputs"]),
+ testin=test_def["testin"]
+ )
+
+with open(args.output, "w") as f:
+ print(render, file=f)
+