aboutsummaryrefslogtreecommitdiffstats
diff options
context:
space:
mode:
authorClifford Wolf <clifford@clifford.at>2018-05-23 17:58:57 +0200
committerClifford Wolf <clifford@clifford.at>2018-05-23 17:58:57 +0200
commit22558704460b19425d28cc91b2565c7964ed7a19 (patch)
tree600f3477c33837df80ad4a114017fdee8f953de0
parentdaa48858201d1f4851efcb6754e44b95e8fae656 (diff)
downloadnextpnr-22558704460b19425d28cc91b2565c7964ed7a19.tar.gz
nextpnr-22558704460b19425d28cc91b2565c7964ed7a19.tar.bz2
nextpnr-22558704460b19425d28cc91b2565c7964ed7a19.zip
Create compile-able demo that doesn't do anything
Signed-off-by: Clifford Wolf <clifford@clifford.at>
-rw-r--r--.gitignore1
-rw-r--r--database.cc15
-rw-r--r--database.h (renamed from apidraft.h)56
-rw-r--r--demo.cc13
4 files changed, 71 insertions, 14 deletions
diff --git a/.gitignore b/.gitignore
new file mode 100644
index 00000000..69ff7396
--- /dev/null
+++ b/.gitignore
@@ -0,0 +1 @@
+/demo
diff --git a/database.cc b/database.cc
new file mode 100644
index 00000000..8eb64473
--- /dev/null
+++ b/database.cc
@@ -0,0 +1,15 @@
+#include "database.h"
+
+Chip::Chip(std::string)
+{
+}
+
+ObjRange Chip::getBels() const
+{
+ return ObjRange();
+}
+
+IdString Chip::getObjName(ObjId obj) const
+{
+ return "*unknown*";
+}
diff --git a/apidraft.h b/database.h
index b14ddfee..81205f20 100644
--- a/apidraft.h
+++ b/database.h
@@ -1,13 +1,20 @@
#include <stdint.h>
+#include <vector>
#include <string>
+#include <unordered_set>
+#include <unordered_map>
// replace with proper IdString later
typedef std::string IdString;
+// replace with haslib later
+template<typename T> using pool = std::unordered_set<T>;
+template<typename T, typename U> using dict = std::unordered_map<T, U>;
+using std::vector;
+
// -------------------------------------------------------
// Arch-specific declarations
-#ifdef ARCH_ICE40
struct ObjId
{
uint8_t tile_x = 0, tile_y = 0;
@@ -18,16 +25,34 @@ struct ObjId
}
} __attribute__((packed));
+namespace std
+{
+ template<> struct hash<ObjId>
+ {
+ std::size_t operator()(const ObjId &obj) const noexcept
+ {
+ std::size_t result = std::hash<int>{}(obj.index);
+ result ^= std::hash<int>{}(obj.tile_x) + 0x9e3779b9 + (result << 6) + (result >> 2);
+ result ^= std::hash<int>{}(obj.tile_y) + 0x9e3779b9 + (result << 6) + (result >> 2);
+ return result;
+ }
+ };
+}
+
struct ObjIterator
{
- // ...
- ObjId operator*() const;
+ ObjId *ptr = nullptr;
+
+ void operator++() { ptr++; }
+ bool operator!=(const ObjIterator &other) const { return ptr != other.ptr; }
+ ObjId operator*() const { return *ptr; }
};
struct ObjRange
{
- ObjIterator begin();
- ObjIterator end();
+ ObjIterator b, e;
+ ObjIterator begin() const { return b; }
+ ObjIterator end() const { return e; }
};
struct BelPin
@@ -38,14 +63,18 @@ struct BelPin
struct BelPinIterator
{
- // ...
- BelPin operator*() const;
+ BelPin *ptr = nullptr;
+
+ void operator++() { ptr++; }
+ bool operator!=(const BelPinIterator &other) const { return ptr != other.ptr; }
+ BelPin operator*() const { return *ptr; }
};
struct BelPinRange
{
- BelPinIterator begin();
- BelPinIterator end();
+ BelPinIterator b, e;
+ BelPinIterator begin() const { return b; }
+ BelPinIterator end() const { return e; }
};
struct GuiLine
@@ -84,7 +113,6 @@ struct Chip
BelPin getBelPinUphill(ObjId wire) const;
BelPinRange getBelPinsDownhill(ObjId wire) const;
};
-#endif
// -------------------------------------------------------
// Generic declarations
@@ -132,12 +160,12 @@ struct CellInfo
struct Design
{
- struct Chip;
+ struct Chip chip;
- Design(std::string chipCfg) : Chip(chipCfg) {
+ Design(std::string chipCfg) : chip(chipCfg) {
// ...
}
- dict<IdString, *NetInfo> nets;
- dict<IdString, *CellInfo> cells;
+ dict<IdString, NetInfo*> nets;
+ dict<IdString, CellInfo*> cells;
};
diff --git a/demo.cc b/demo.cc
new file mode 100644
index 00000000..3a5ca0c0
--- /dev/null
+++ b/demo.cc
@@ -0,0 +1,13 @@
+// clang -o demo -Wall -std=c++11 demo.cc database.cc -lstdc++
+
+#include "database.h"
+
+int main()
+{
+ Design design("default");
+
+ for (auto bel : design.chip.getBels())
+ printf("%s\n", design.chip.getObjName(bel).c_str());
+
+ return 0;
+}