diff options
author | gatecat <gatecat@ds0.me> | 2021-02-15 16:19:25 +0000 |
---|---|---|
committer | GitHub <noreply@github.com> | 2021-02-15 16:19:25 +0000 |
commit | 9fc02041fe7bdcbac99e54f30423b2c39b92bb8a (patch) | |
tree | 077d4bcba094cfd602ab5188e2fd05eaccf3cb2c /generic/arch.h | |
parent | 065f46daeb05a8b12cc663a44410b6da27a8d9e3 (diff) | |
parent | f0b2a91bdaf77eb1bdb0a47f5f342e98e8db38c9 (diff) | |
download | nextpnr-9fc02041fe7bdcbac99e54f30423b2c39b92bb8a.tar.gz nextpnr-9fc02041fe7bdcbac99e54f30423b2c39b92bb8a.tar.bz2 nextpnr-9fc02041fe7bdcbac99e54f30423b2c39b92bb8a.zip |
Merge pull request #584 from YosysHQ/gatecat/generic-belpin
Add bel pin mapping control to nextpnr-generic
Diffstat (limited to 'generic/arch.h')
-rw-r--r-- | generic/arch.h | 7 |
1 files changed, 5 insertions, 2 deletions
diff --git a/generic/arch.h b/generic/arch.h index 2a0c7158..007478eb 100644 --- a/generic/arch.h +++ b/generic/arch.h @@ -125,7 +125,7 @@ struct ArchRanges using TileBelsRangeT = const std::vector<BelId> &; using BelAttrsRangeT = const std::map<IdString, std::string> &; using BelPinsRangeT = std::vector<IdString>; - using CellBelPinRangeT = std::array<IdString, 1>; + using CellBelPinRangeT = const std::vector<IdString> &; // Wires using AllWiresRangeT = const std::vector<WireId> &; using DownhillPipRangeT = const std::vector<PipId> &; @@ -207,6 +207,9 @@ struct Arch : ArchAPI<ArchRanges> void addCellTimingSetupHold(IdString cell, IdString port, IdString clock, DelayInfo setup, DelayInfo hold); void addCellTimingClockToOut(IdString cell, IdString port, IdString clock, DelayInfo clktoq); + void clearCellBelPinMap(IdString cell, IdString cell_pin); + void addCellBelPinMapping(IdString cell, IdString cell_pin, IdString bel_pin); + // --------------------------------------------------------------- // Common Arch API. Every arch must provide the following methods. @@ -244,7 +247,7 @@ struct Arch : ArchAPI<ArchRanges> WireId getBelPinWire(BelId bel, IdString pin) const override; PortType getBelPinType(BelId bel, IdString pin) const override; std::vector<IdString> getBelPins(BelId bel) const override; - std::array<IdString, 1> getBelPinsForCellPin(CellInfo *cell_info, IdString pin) const override; + const std::vector<IdString> &getBelPinsForCellPin(CellInfo *cell_info, IdString pin) const override; WireId getWireByName(IdStringList name) const override; IdStringList getWireName(WireId wire) const override; |