mirror of
https://github.com/YosysHQ/sby.git
synced 2025-04-05 22:14:08 +00:00
Improve sby file pycode/tasks handling
Signed-off-by: Clifford Wolf <clifford@clifford.at>
This commit is contained in:
parent
4a392bb639
commit
d5fa89ee0c
|
@ -369,4 +369,38 @@ example:
|
||||||
Pycode blocks
|
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.
|
||||||
|
|
|
@ -142,10 +142,31 @@ def read_sbyconfig(sbydata, taskname):
|
||||||
task_skip_block = False
|
task_skip_block = False
|
||||||
task_skiping_blocks = 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("\n")
|
||||||
line = line.rstrip("\r")
|
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("["):
|
if tasks_section and line.startswith("["):
|
||||||
tasks_section = False
|
tasks_section = False
|
||||||
|
|
||||||
|
@ -153,7 +174,7 @@ def read_sbyconfig(sbydata, taskname):
|
||||||
if line == "--":
|
if line == "--":
|
||||||
task_skip_block = False
|
task_skip_block = False
|
||||||
task_skiping_blocks = False
|
task_skiping_blocks = False
|
||||||
continue
|
return
|
||||||
|
|
||||||
found_task_tag = False
|
found_task_tag = False
|
||||||
task_skip_line = False
|
task_skip_line = False
|
||||||
|
@ -185,11 +206,13 @@ def read_sbyconfig(sbydata, taskname):
|
||||||
sys.exit(1)
|
sys.exit(1)
|
||||||
|
|
||||||
if task_skip_line or task_skip_block:
|
if task_skip_line or task_skip_block:
|
||||||
continue
|
return
|
||||||
|
|
||||||
if tasks_section:
|
if tasks_section:
|
||||||
|
if taskname is None:
|
||||||
|
cfgdata.append(line)
|
||||||
if line.startswith("#"):
|
if line.startswith("#"):
|
||||||
continue
|
return
|
||||||
line = line.split()
|
line = line.split()
|
||||||
if len(line) > 0:
|
if len(line) > 0:
|
||||||
tasklist.append(line[0])
|
tasklist.append(line[0])
|
||||||
|
@ -199,23 +222,15 @@ def read_sbyconfig(sbydata, taskname):
|
||||||
task_tags_all.add(t)
|
task_tags_all.add(t)
|
||||||
|
|
||||||
elif line == "[tasks]":
|
elif line == "[tasks]":
|
||||||
|
if taskname is None:
|
||||||
|
cfgdata.append(line)
|
||||||
tasks_section = True
|
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:
|
else:
|
||||||
if pycode is None:
|
cfgdata.append(line)
|
||||||
cfgdata.append(line)
|
|
||||||
else:
|
for line in sbydata:
|
||||||
pycode += line + "\n"
|
handle_line(line)
|
||||||
|
|
||||||
return cfgdata, tasklist
|
return cfgdata, tasklist
|
||||||
|
|
||||||
|
|
Loading…
Reference in a new issue