aboutsummaryrefslogtreecommitdiffstats
path: root/passes/pmgen/pmgen.py
diff options
context:
space:
mode:
authorClifford Wolf <clifford@clifford.at>2019-01-14 13:29:27 +0100
committerClifford Wolf <clifford@clifford.at>2019-01-15 11:23:25 +0100
commit5216735210f1b081f84c8ec110acb1cf9c3a0555 (patch)
tree8d69b9a4a54252888eca838c8c974fe82ed89218 /passes/pmgen/pmgen.py
parent55ac03038270f4a70da5e579dd317487e20fe6cf (diff)
downloadyosys-5216735210f1b081f84c8ec110acb1cf9c3a0555.tar.gz
yosys-5216735210f1b081f84c8ec110acb1cf9c3a0555.tar.bz2
yosys-5216735210f1b081f84c8ec110acb1cf9c3a0555.zip
Progress in pmgen, add pmgen README
Signed-off-by: Clifford Wolf <clifford@clifford.at>
Diffstat (limited to 'passes/pmgen/pmgen.py')
-rw-r--r--passes/pmgen/pmgen.py46
1 files changed, 34 insertions, 12 deletions
diff --git a/passes/pmgen/pmgen.py b/passes/pmgen/pmgen.py
index 6486278d4..885f6db1c 100644
--- a/passes/pmgen/pmgen.py
+++ b/passes/pmgen/pmgen.py
@@ -9,6 +9,7 @@ pp = pprint.PrettyPrinter(indent=4)
prefix = sys.argv[1]
state_types = dict()
+udata_types = dict()
blocks = list()
ids = dict()
@@ -92,6 +93,16 @@ with open("%s.pmg" % prefix, "r") as f:
state_types[s] = type_str
continue
+ if cmd == "udata":
+ m = re.match(r"^udata\s+<(.*?)>\s+(([A-Za-z_][A-Za-z_0-9]*\s+)*[A-Za-z_][A-Za-z_0-9]*)\s*$", line)
+ assert m
+ type_str = m.group(1)
+ udatas_str = m.group(2)
+ for s in re.split(r"\s+", udatas_str):
+ assert s not in udata_types
+ udata_types[s] = type_str
+ continue
+
if cmd == "match":
block = dict()
block["type"] = "match"
@@ -196,12 +207,17 @@ with open("%s_pm.h" % prefix, "w") as f:
print("", file=f)
print(" struct state_t {", file=f)
-
for s, t in sorted(state_types.items()):
print(" {} {};".format(t, s), file=f)
print(" } st;", file=f)
print("", file=f)
+ print(" struct udata_t {", file=f)
+ for s, t in sorted(udata_types.items()):
+ print(" {} {};".format(t, s), file=f)
+ print(" } ud;", file=f)
+ print("", file=f)
+
for v, n in sorted(ids.items()):
if n[0] == "\\":
print(" IdString {}{{\"\\{}\"}};".format(v, n), file=f)
@@ -258,7 +274,12 @@ with open("%s_pm.h" % prefix, "w") as f:
print(" {}_pm(Module *module, const vector<Cell*> &cells) :".format(prefix), file=f)
print(" module(module), sigmap(module) {", file=f)
- print(" for (auto cell : cells) {", file=f)
+ for s, t in sorted(udata_types.items()):
+ if t.endswith("*"):
+ print(" ud.{} = nullptr;".format(s), file=f)
+ else:
+ print(" ud.{} = {}();".format(s, t), file=f)
+ print(" for (auto cell : module->cells()) {", file=f)
print(" for (auto &conn : cell->connections())", file=f)
print(" add_siguser(conn.second, cell);", file=f)
print(" }", file=f)
@@ -281,7 +302,7 @@ with open("%s_pm.h" % prefix, "w") as f:
print(" }", file=f)
print("", file=f)
- print(" void match(std::function<void()> on_accept_f) {{".format(prefix), file=f)
+ print(" void run(std::function<void()> on_accept_f) {{".format(prefix), file=f)
print(" on_accept = on_accept_f;", file=f)
print(" rollback = 0;", file=f)
for s, t in sorted(state_types.items()):
@@ -293,10 +314,6 @@ with open("%s_pm.h" % prefix, "w") as f:
print(" }", file=f)
print("", file=f)
- print("#define reject do { check_blacklist(); goto rollback_label; } while(0)", file=f)
- print("#define accept do { on_accept(); check_blacklist(); if (rollback) goto rollback_label; } while(0)", file=f)
- print("", file=f)
-
for index in range(len(blocks)):
block = blocks[index]
@@ -348,13 +365,22 @@ with open("%s_pm.h" % prefix, "w") as f:
if block["type"] == "code":
print("", file=f)
print(" do {", file=f)
+ print("#define reject do { check_blacklist(); goto rollback_label; } while(0)", file=f)
+ print("#define accept do { on_accept(); check_blacklist(); if (rollback) goto rollback_label; } while(0)", file=f)
+ print("#define branch do {{ block_{}(); }} while(0)".format(index+1), file=f)
+
for line in block["code"]:
print(" " + line, file=f)
print("", file=f)
print(" block_{}();".format(index+1), file=f)
- print("rollback_label: YS_ATTRIBUTE(unused);", file=f)
+ print("#undef reject", file=f)
+ print("#undef accept", file=f)
+ print("#undef branch", file=f)
print(" } while (0);", file=f)
+ print("", file=f)
+ print("rollback_label:", file=f)
+ print(" YS_ATTRIBUTE(unused);", file=f)
if len(restore_st) or len(nonconst_st):
print("", file=f)
@@ -415,10 +441,6 @@ with open("%s_pm.h" % prefix, "w") as f:
print(" }", file=f)
print("", file=f)
- print("#undef reject", file=f)
- print("#undef accept", file=f)
- print("", file=f)
-
print(" void block_{}() {{".format(len(blocks)), file=f)
print(" on_accept();", file=f)
print(" check_blacklist();", file=f)