3
0
Fork 0
mirror of https://github.com/YosysHQ/sby.git synced 2025-04-05 06:04:06 +00:00

Improve sby file pycode/tasks handling

Signed-off-by: Clifford Wolf <clifford@clifford.at>
This commit is contained in:
Clifford Wolf 2019-03-08 10:45:32 -08:00
parent 4a392bb639
commit d5fa89ee0c
2 changed files with 68 additions and 19 deletions

View file

@ -369,4 +369,38 @@ example:
Pycode blocks
-------------
TBD
Blocks enclosed in ``--pycode-begin--`` and ``--pycode-end--`` lines are interpreted
as Python code. The function ``output(line)`` can be used to add configuration
file lines from the python code. The variable ``task`` contains the current task name,
if any, and ``None`` otherwise. The variable ``tags`` contains a set of all tags
associated with the current task.
.. code-block:: text
[tasks]
--pycode-begin--
for uut in "rotate reflect".split():
for op in "SRL SRA SLL SRO SLO ROR ROL FSR FSL".split():
output("%s_%s %s %s" % (uut, op, uut, op))
--pycode-end--
...
[script]
--pycode-begin--
for op in "SRL SRA SLL SRO SLO ROR ROL FSR FSL".split():
if op in tags:
output("read -define %s" % op)
--pycode-end--
rotate: read -define UUT=shifter_rotate
reflect: read -define UUT=shifter_reflect
read -sv test.v
read -sv shifter_reflect.v
read -sv shifter_rotate.v
prep -top test
...
The command ``sby --dumpcfg <sby_file>`` can be used to print the configuration without
specialization for any particular task, and ``sby --dumpcfg <sby_file> <task_name>`` can
be used to print the configuration with specialization for a particular task.

View file

@ -142,10 +142,31 @@ def read_sbyconfig(sbydata, taskname):
task_skip_block = False
task_skiping_blocks = False
for line in sbydata:
def handle_line(line):
nonlocal pycode, tasks_section, task_tags_active, task_tags_all
nonlocal task_skip_block, task_skiping_blocks
line = line.rstrip("\n")
line = line.rstrip("\r")
if pycode is not None:
if line == "--pycode-end--":
gdict = globals().copy()
gdict["task"] = taskname
gdict["tags"] = set(task_tags_active)
gdict["output_lines"] = list()
exec("def output(line):\n output_lines.append(line)\n" + pycode, gdict)
pycode = None
for line in gdict["output_lines"]:
handle_line(line)
return
pycode += line + "\n"
return
if line == "--pycode-begin--":
pycode = ""
return
if tasks_section and line.startswith("["):
tasks_section = False
@ -153,7 +174,7 @@ def read_sbyconfig(sbydata, taskname):
if line == "--":
task_skip_block = False
task_skiping_blocks = False
continue
return
found_task_tag = False
task_skip_line = False
@ -185,11 +206,13 @@ def read_sbyconfig(sbydata, taskname):
sys.exit(1)
if task_skip_line or task_skip_block:
continue
return
if tasks_section:
if taskname is None:
cfgdata.append(line)
if line.startswith("#"):
continue
return
line = line.split()
if len(line) > 0:
tasklist.append(line[0])
@ -199,23 +222,15 @@ def read_sbyconfig(sbydata, taskname):
task_tags_all.add(t)
elif line == "[tasks]":
if taskname is None:
cfgdata.append(line)
tasks_section = True
elif line == "--pycode-begin--":
pycode = ""
elif line == "--pycode-end--":
gdict = globals().copy()
gdict["cfgdata"] = cfgdata
gdict["taskname"] = taskname
exec("def output(line):\n cfgdata.append(line)\n" + pycode, gdict)
pycode = None
else:
if pycode is None:
cfgdata.append(line)
else:
pycode += line + "\n"
cfgdata.append(line)
for line in sbydata:
handle_line(line)
return cfgdata, tasklist