aboutsummaryrefslogtreecommitdiffstats
path: root/techlibs/ice40
diff options
context:
space:
mode:
authorEddie Hung <eddie@fpgeh.com>2019-04-17 15:19:02 -0700
committerEddie Hung <eddie@fpgeh.com>2019-04-17 15:19:02 -0700
commitc795e14d25b42ae28bd4b8f7e259e969442437b3 (patch)
tree622891f15e8a5a3ef7bca4b263c4889294ad0481 /techlibs/ice40
parentabcd3103ffa8965160e2d489c81e0a61c9a937bd (diff)
downloadyosys-c795e14d25b42ae28bd4b8f7e259e969442437b3.tar.gz
yosys-c795e14d25b42ae28bd4b8f7e259e969442437b3.tar.bz2
yosys-c795e14d25b42ae28bd4b8f7e259e969442437b3.zip
Reduce to three devices: hx, lp, u
Diffstat (limited to 'techlibs/ice40')
-rw-r--r--techlibs/ice40/hx.box (renamed from techlibs/ice40/hx8k.box)0
-rw-r--r--techlibs/ice40/hx.lut (renamed from techlibs/ice40/hx8k.lut)0
-rw-r--r--techlibs/ice40/lp.box13
-rw-r--r--techlibs/ice40/lp.lut6
-rw-r--r--techlibs/ice40/synth_ice40.cc8
-rw-r--r--techlibs/ice40/u.box (renamed from techlibs/ice40/up5k.box)0
-rw-r--r--techlibs/ice40/u.lut (renamed from techlibs/ice40/up5k.lut)0
7 files changed, 23 insertions, 4 deletions
diff --git a/techlibs/ice40/hx8k.box b/techlibs/ice40/hx.box
index c31f7bf39..c31f7bf39 100644
--- a/techlibs/ice40/hx8k.box
+++ b/techlibs/ice40/hx.box
diff --git a/techlibs/ice40/hx8k.lut b/techlibs/ice40/hx.lut
index 3b3bb11e2..3b3bb11e2 100644
--- a/techlibs/ice40/hx8k.lut
+++ b/techlibs/ice40/hx.lut
diff --git a/techlibs/ice40/lp.box b/techlibs/ice40/lp.box
new file mode 100644
index 000000000..7eb8e86e0
--- /dev/null
+++ b/techlibs/ice40/lp.box
@@ -0,0 +1,13 @@
+# From https://github.com/cliffordwolf/icestorm/blob/be0bca0/icefuzz/timings_lp8k.txt
+
+# NB: Inputs/Outputs must be ordered alphabetically
+
+# Inputs: CI I0 I1
+# Outputs: CO
+SB_CARRY 1 1 3 1
+186 675 609
+
+# Inputs: I0 I1 I2 I3
+# Outputs: O
+SB_LUT4 2 1 4 1
+465 558 589 661
diff --git a/techlibs/ice40/lp.lut b/techlibs/ice40/lp.lut
new file mode 100644
index 000000000..e72f760a2
--- /dev/null
+++ b/techlibs/ice40/lp.lut
@@ -0,0 +1,6 @@
+# From https://github.com/cliffordwolf/icestorm/blob/be0bca0/icefuzz/timings_lp8k.txt
+# I3 I2 I1 I0
+1 1 465
+2 1 465 558
+3 1 465 558 589
+4 1 465 558 589 661
diff --git a/techlibs/ice40/synth_ice40.cc b/techlibs/ice40/synth_ice40.cc
index 62589ad87..7c95588e4 100644
--- a/techlibs/ice40/synth_ice40.cc
+++ b/techlibs/ice40/synth_ice40.cc
@@ -37,9 +37,9 @@ struct SynthIce40Pass : public ScriptPass
log("\n");
log("This command runs synthesis for iCE40 FPGAs.\n");
log("\n");
- log(" -device < hx1k | lp384 | lp1k | lp8k | hx8k | u4k | up5k >\n");
+ log(" -device < hx | lp | u >\n");
log(" optimise the synthesis netlist for the specified device.\n");
- log(" HX1K is the default target if no device argument specified.\n");
+ log(" HX is the default target if no device argument specified.\n");
log("\n");
log(" -top <module>\n");
log(" use the specified module as top module\n");
@@ -128,7 +128,7 @@ struct SynthIce40Pass : public ScriptPass
abc2 = false;
vpr = false;
abc = "abc";
- device_opt = "hx1k";
+ device_opt = "hx";
}
void execute(std::vector<std::string> args, RTLIL::Design *design) YS_OVERRIDE
@@ -225,7 +225,7 @@ struct SynthIce40Pass : public ScriptPass
if (!design->full_selection())
log_cmd_error("This command only operates on fully selected designs!\n");
- if (device_opt != "hx1k" && device_opt !="lp384" && device_opt != "lp1k" && device_opt !="lp8k" && device_opt !="hx8k" && device_opt != "u4k" && device_opt != "up5k")
+ if (device_opt != "hx" && device_opt != "lp" && device_opt !="u")
log_cmd_error("Invalid or no device specified: '%s'\n", device_opt.c_str());
log_header(design, "Executing SYNTH_ICE40 pass.\n");
diff --git a/techlibs/ice40/up5k.box b/techlibs/ice40/u.box
index 94df1df8f..94df1df8f 100644
--- a/techlibs/ice40/up5k.box
+++ b/techlibs/ice40/u.box
diff --git a/techlibs/ice40/up5k.lut b/techlibs/ice40/u.lut
index 1e4fcadb6..1e4fcadb6 100644
--- a/techlibs/ice40/up5k.lut
+++ b/techlibs/ice40/u.lut