aboutsummaryrefslogtreecommitdiffstats
path: root/ecp5
diff options
context:
space:
mode:
authorgatecat <gatecat@ds0.me>2021-03-15 17:00:52 +0000
committerGitHub <noreply@github.com>2021-03-15 17:00:52 +0000
commita8e35062c6a1a21838346dd7536bb2fcc7f820ed (patch)
treec5466a8ed8f9108410561eb8d9d9ff5e2810d297 /ecp5
parent3cf4a336665e07f8d210aa9d3336f3d5b0e82ea7 (diff)
parentfe4608386eb163c70a75ed84beb07516af378b36 (diff)
downloadnextpnr-a8e35062c6a1a21838346dd7536bb2fcc7f820ed.tar.gz
nextpnr-a8e35062c6a1a21838346dd7536bb2fcc7f820ed.tar.bz2
nextpnr-a8e35062c6a1a21838346dd7536bb2fcc7f820ed.zip
Merge pull request #621 from litghost/fix_header_nightmare
Split nextpnr.h to allow for linear inclusion.
Diffstat (limited to 'ecp5')
-rw-r--r--ecp5/arch.h13
-rw-r--r--ecp5/archdefs.h14
-rw-r--r--ecp5/lpf.cc4
3 files changed, 21 insertions, 10 deletions
diff --git a/ecp5/arch.h b/ecp5/arch.h
index f1da870a..063a3df6 100644
--- a/ecp5/arch.h
+++ b/ecp5/arch.h
@@ -18,19 +18,20 @@
*
*/
-#ifndef NEXTPNR_H
-#error Include "arch.h" via "nextpnr.h" only.
-#endif
+#ifndef ECP5_ARCH_H
+#define ECP5_ARCH_H
#include <set>
#include <sstream>
+#include "base_arch.h"
+#include "nextpnr_types.h"
+#include "relptr.h"
+
NEXTPNR_NAMESPACE_BEGIN
/**** Everything in this section must be kept in sync with chipdb.py ****/
-#include "relptr.h"
-
NPNR_PACKED_STRUCT(struct BelWirePOD {
LocationPOD rel_wire_loc;
int32_t wire_index;
@@ -928,3 +929,5 @@ struct Arch : BaseArch<ArchRanges>
};
NEXTPNR_NAMESPACE_END
+
+#endif /* ECP5_ARCH_H */
diff --git a/ecp5/archdefs.h b/ecp5/archdefs.h
index cf6902d3..6a149264 100644
--- a/ecp5/archdefs.h
+++ b/ecp5/archdefs.h
@@ -18,12 +18,14 @@
*
*/
-#ifndef NEXTPNR_H
-#error Include "archdefs.h" via "nextpnr.h" only.
-#endif
+#ifndef ECP5_ARCHDEFS_H
+#define ECP5_ARCHDEFS_H
#include <boost/functional/hash.hpp>
+#include "idstring.h"
+#include "nextpnr_namespaces.h"
+
NEXTPNR_NAMESPACE_BEGIN
typedef int delay_t;
@@ -165,12 +167,12 @@ struct ArchCellInfo
bool is_output_b_registered;
// Which timing information to use for a DP16KD. Depends on registering
// configuration.
- nextpnr_ecp5::IdString regmode_timing_id;
+ IdString regmode_timing_id;
} ramInfo;
struct
{
bool is_clocked;
- nextpnr_ecp5::IdString timing_id;
+ IdString timing_id;
} multInfo;
};
@@ -242,3 +244,5 @@ template <> struct hash<NEXTPNR_NAMESPACE_PREFIX DecalId>
};
} // namespace std
+
+#endif /* ECP5_ARCHDEFS_H */
diff --git a/ecp5/lpf.cc b/ecp5/lpf.cc
index 22859783..6d134e8d 100644
--- a/ecp5/lpf.cc
+++ b/ecp5/lpf.cc
@@ -19,7 +19,11 @@
#include <boost/algorithm/string.hpp>
#include <sstream>
+#include <unordered_set>
+
+#include "arch.h"
#include "log.h"
+#include "nextpnr_namespaces.h"
NEXTPNR_NAMESPACE_BEGIN