aboutsummaryrefslogtreecommitdiffstats
diff options
context:
space:
mode:
authorDavid Shah <dave@ds0.me>2020-06-29 11:08:21 +0100
committerDavid Shah <dave@ds0.me>2020-06-29 19:52:31 +0100
commitb24e0a609b123c8602d763f2cd4af6f935e88962 (patch)
treec4722d1fbf75df77e0640c2ec4baba52c11f9ab2
parent32e655d0afcc01d7a04aca0f1c5be39140e21335 (diff)
downloadnextpnr-b24e0a609b123c8602d763f2cd4af6f935e88962.tar.gz
nextpnr-b24e0a609b123c8602d763f2cd4af6f935e88962.tar.bz2
nextpnr-b24e0a609b123c8602d763f2cd4af6f935e88962.zip
ice40: Fix getBelsByTile
Signed-off-by: David Shah <dave@ds0.me>
-rw-r--r--ice40/arch.cc6
-rw-r--r--ice40/chipdb.py2
2 files changed, 6 insertions, 2 deletions
diff --git a/ice40/arch.cc b/ice40/arch.cc
index 52246001..be346fd7 100644
--- a/ice40/arch.cc
+++ b/ice40/arch.cc
@@ -192,7 +192,11 @@ BelRange Arch::getBelsByTile(int x, int y) const
// are used
BelRange br;
- br.b.cursor = Arch::getBelByLocation(Loc(x, y, 0)).index;
+ for (int i = 0; i < 4; i++) {
+ br.b.cursor = Arch::getBelByLocation(Loc(x, y, i)).index;
+ if (br.b.cursor != -1)
+ break;
+ }
br.e.cursor = br.b.cursor;
if (br.e.cursor != -1) {
diff --git a/ice40/chipdb.py b/ice40/chipdb.py
index 7b3ad999..efdde1a1 100644
--- a/ice40/chipdb.py
+++ b/ice40/chipdb.py
@@ -1060,7 +1060,7 @@ for tile_xy, tile_type in sorted(tiles.items()):
if ec[1] == tile_xy[0] and ec[2] == tile_xy[1]:
add_bel_ec(ec)
-for ec in sorted(extra_cells.keys()):
+for ec in sorted(extra_cells.keys(), key=lambda ec: (ec[1], ec[2], ec[3], ec[0])):
if ec[1] in (0, dev_width - 1) and ec[2] in (0, dev_height - 1):
add_bel_ec(ec)