diff options
author | David Shah <dave@ds0.me> | 2020-11-09 14:53:11 +0000 |
---|---|---|
committer | David Shah <dave@ds0.me> | 2020-11-30 08:45:28 +0000 |
commit | 963fd175ad69c5468bfc486e789cf6c7ff85f57e (patch) | |
tree | 937d54d46b2096b2ca6510ff391aa58ec214f3c3 /nexus/arch.cc | |
parent | 4e5ad7feac5b41876e3b09162cea8815fe0821bf (diff) | |
download | nextpnr-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.cc | 21 |
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()); } // ----------------------------------------------------------------------- |