aboutsummaryrefslogtreecommitdiffstats
path: root/nexus/arch.cc
diff options
context:
space:
mode:
authorDavid Shah <dave@ds0.me>2020-11-09 14:53:11 +0000
committerDavid Shah <dave@ds0.me>2020-11-30 08:45:28 +0000
commit963fd175ad69c5468bfc486e789cf6c7ff85f57e (patch)
tree937d54d46b2096b2ca6510ff391aa58ec214f3c3 /nexus/arch.cc
parent4e5ad7feac5b41876e3b09162cea8815fe0821bf (diff)
downloadnextpnr-963fd175ad69c5468bfc486e789cf6c7ff85f57e.tar.gz
nextpnr-963fd175ad69c5468bfc486e789cf6c7ff85f57e.tar.bz2
nextpnr-963fd175ad69c5468bfc486e789cf6c7ff85f57e.zip
nexus: Lookup speed grade and pip delays
Signed-off-by: David Shah <dave@ds0.me>
Diffstat (limited to 'nexus/arch.cc')
-rw-r--r--nexus/arch.cc21
1 files changed, 21 insertions, 0 deletions
diff --git a/nexus/arch.cc b/nexus/arch.cc
index 7b4e2041..aff00d5d 100644
--- a/nexus/arch.cc
+++ b/nexus/arch.cc
@@ -137,6 +137,27 @@ Arch::Arch(ArchArgs args) : args(args)
}
log_error("Unknown package '%s'. Available package options:%s\n", package.c_str(), all_packages.c_str());
}
+
+ // Validate and set up speed grade
+
+ // Convert speed to speed grade (TODO: low power back bias mode too)
+ if (speed == "7")
+ speed = "10";
+ else if (speed == "8")
+ speed = "11";
+ else if (speed == "9")
+ speed = "12";
+
+ speed_grade = nullptr;
+ for (size_t i = 0; i < db->num_speed_grades; i++) {
+ auto &sg = db->speed_grades[i];
+ if (sg.name.get() == speed) {
+ speed_grade = &sg;
+ break;
+ }
+ }
+ if (!speed_grade)
+ log_error("Unknown speed grade '%s'.\n", speed.c_str());
}
// -----------------------------------------------------------------------