aboutsummaryrefslogtreecommitdiffstats
diff options
context:
space:
mode:
authorgatecat <gatecat@ds0.me>2021-08-23 21:56:42 +0100
committerGitHub <noreply@github.com>2021-08-23 21:56:42 +0100
commit42166f2e3e4a319e0519e52ae1905db7761e322e (patch)
tree6b4b34b50d53018b6efaaa8f39bb4b75a64ea99f
parent897a2fccb64ac52ec4d3ce728fad91c3a5a96ff1 (diff)
parentde311e052fdb749d4acfd6608f6b416a4206e6ae (diff)
downloadnextpnr-42166f2e3e4a319e0519e52ae1905db7761e322e.tar.gz
nextpnr-42166f2e3e4a319e0519e52ae1905db7761e322e.tar.bz2
nextpnr-42166f2e3e4a319e0519e52ae1905db7761e322e.zip
Merge pull request #802 from YosysHQ/gatecat/python-rt-dly
python: Allow querying route delays
-rw-r--r--common/arch_pybindings_shared.h3
-rw-r--r--python/delay_vs_fanout.py10
2 files changed, 13 insertions, 0 deletions
diff --git a/common/arch_pybindings_shared.h b/common/arch_pybindings_shared.h
index 46f1f9be..f44aa70e 100644
--- a/common/arch_pybindings_shared.h
+++ b/common/arch_pybindings_shared.h
@@ -27,6 +27,9 @@ fn_wrapper_2a_v<Context, decltype(&Context::addBelToRegion), &Context::addBelToR
fn_wrapper_2a_v<Context, decltype(&Context::constrainCellToRegion), &Context::constrainCellToRegion,
conv_from_str<IdString>, conv_from_str<IdString>>::def_wrap(ctx_cls, "constrainCellToRegion");
+fn_wrapper_2a<Context, decltype(&Context::getNetinfoRouteDelay), &Context::getNetinfoRouteDelay, pass_through<delay_t>,
+ addr_and_unwrap<NetInfo>, unwrap_context<PortRef &>>::def_wrap(ctx_cls, "getNetinfoRouteDelay");
+
fn_wrapper_1a<Context, decltype(&Context::createNet), &Context::createNet, deref_and_wrap<NetInfo>,
conv_from_str<IdString>>::def_wrap(ctx_cls, "createNet");
fn_wrapper_3a_v<Context, decltype(&Context::connectPort), &Context::connectPort, conv_from_str<IdString>,
diff --git a/python/delay_vs_fanout.py b/python/delay_vs_fanout.py
new file mode 100644
index 00000000..c417ac78
--- /dev/null
+++ b/python/delay_vs_fanout.py
@@ -0,0 +1,10 @@
+with open("delay_vs_fanout.csv", "w") as f:
+ print("fanout,delay", file=f)
+ for net_name, net in ctx.nets:
+ if net.driver.cell is None:
+ continue
+ if net.driver.cell.type == "DCCA":
+ continue # ignore global clocks
+ for user in net.users:
+ print(f"{len(net.users)},{ctx.getNetinfoRouteDelay(net, user)}", file=f)
+