aboutsummaryrefslogtreecommitdiffstats
path: root/generic/arch.h
diff options
context:
space:
mode:
authorgatecat <gatecat@ds0.me>2021-02-15 09:58:56 +0000
committergatecat <gatecat@ds0.me>2021-02-15 09:58:56 +0000
commita002ccfbc1b627a8de921e7940e9ffe37dc94ca3 (patch)
treecba53fb43bf9a4eee1eed9f30c31ab4a624d3a25 /generic/arch.h
parent065f46daeb05a8b12cc663a44410b6da27a8d9e3 (diff)
downloadnextpnr-a002ccfbc1b627a8de921e7940e9ffe37dc94ca3.tar.gz
nextpnr-a002ccfbc1b627a8de921e7940e9ffe37dc94ca3.tar.bz2
nextpnr-a002ccfbc1b627a8de921e7940e9ffe37dc94ca3.zip
generic: Add APIs for controlling cell->bel pin mapping
Signed-off-by: gatecat <gatecat@ds0.me>
Diffstat (limited to 'generic/arch.h')
-rw-r--r--generic/arch.h7
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;