aboutsummaryrefslogtreecommitdiffstats
diff options
context:
space:
mode:
authorClifford Wolf <clifford@clifford.at>2016-02-06 13:52:14 +0100
committerClifford Wolf <clifford@clifford.at>2016-02-06 13:52:14 +0100
commit8ca5e89a4f7b5e9506ff8c63de2c0d2bcac6635e (patch)
tree626bb674e385eddcf968559c9bd2a574e37ae4f7
parentc06f34e0e41307f36d6800bf7ce07d3dfc03145d (diff)
downloadicestorm-8ca5e89a4f7b5e9506ff8c63de2c0d2bcac6635e.tar.gz
icestorm-8ca5e89a4f7b5e9506ff8c63de2c0d2bcac6635e.tar.bz2
icestorm-8ca5e89a4f7b5e9506ff8c63de2c0d2bcac6635e.zip
Added lp1k-cm121 package
-rw-r--r--icebox/icebox.py97
-rw-r--r--icefuzz/icecube.sh4
-rw-r--r--icefuzz/pinloc/pinloc-1k-cm121.sh49
3 files changed, 150 insertions, 0 deletions
diff --git a/icebox/icebox.py b/icebox/icebox.py
index 2153b4f..5886728 100644
--- a/icebox/icebox.py
+++ b/icebox/icebox.py
@@ -1850,6 +1850,103 @@ pinloc_db = {
( "J8", 13, 1, 0),
( "J9", 13, 1, 1),
],
+ "1k-cm121": [
+ ( "A1", 0, 14, 0),
+ ( "A2", 2, 17, 1),
+ ( "A3", 3, 17, 0),
+ ( "A5", 5, 17, 1),
+ ( "A7", 8, 17, 0),
+ ( "A8", 10, 17, 1),
+ ( "A9", 11, 17, 0),
+ ("A10", 12, 17, 0),
+ ("A11", 13, 15, 0),
+ ( "B1", 0, 13, 0),
+ ( "B2", 1, 17, 1),
+ ( "B3", 2, 17, 0),
+ ( "B4", 3, 17, 1),
+ ( "B5", 4, 17, 1),
+ ( "B7", 9, 17, 0),
+ ( "B8", 11, 17, 1),
+ ( "B9", 12, 17, 1),
+ ("B10", 13, 15, 1),
+ ("B11", 13, 14, 1),
+ ( "C1", 0, 12, 0),
+ ( "C2", 0, 13, 1),
+ ( "C3", 0, 14, 1),
+ ( "C4", 1, 17, 0),
+ ( "C5", 4, 17, 0),
+ ( "C6", 7, 17, 1),
+ ( "C7", 8, 17, 1),
+ ( "C8", 9, 17, 1),
+ ( "C9", 10, 17, 0),
+ ("C10", 13, 14, 0),
+ ("C11", 13, 13, 1),
+ ( "D1", 0, 11, 0),
+ ( "D2", 0, 12, 1),
+ ( "D3", 0, 11, 1),
+ ( "D4", 0, 10, 1),
+ ( "D5", 6, 17, 1),
+ ( "D6", 7, 17, 0),
+ ("D10", 13, 12, 1),
+ ("D11", 13, 11, 1),
+ ( "E2", 0, 10, 0),
+ ( "E3", 0, 9, 1),
+ ( "E4", 0, 9, 0),
+ ( "E6", 5, 17, 0),
+ ( "E7", 13, 12, 0),
+ ( "E8", 13, 13, 0),
+ ( "E9", 13, 9, 0),
+ ("E10", 13, 9, 1),
+ ( "F2", 0, 6, 0),
+ ( "F3", 0, 5, 0),
+ ( "F4", 0, 8, 1),
+ ( "F5", 0, 8, 0),
+ ( "F6", 6, 17, 0),
+ ( "F8", 13, 11, 0),
+ ( "F9", 13, 8, 1),
+ ("F11", 13, 7, 1),
+ ( "G2", 0, 5, 1),
+ ( "G4", 0, 3, 0),
+ ( "G8", 12, 0, 1),
+ ( "G9", 13, 8, 0),
+ ("G11", 13, 7, 0),
+ ( "H1", 0, 6, 1),
+ ( "H2", 0, 4, 1),
+ ( "H4", 0, 2, 0),
+ ( "H5", 6, 0, 0),
+ ( "H6", 10, 0, 0),
+ ( "H7", 11, 0, 0),
+ ( "H8", 12, 0, 0),
+ ( "H9", 13, 6, 1),
+ ("H10", 13, 2, 1),
+ ("H11", 13, 4, 1),
+ ( "J1", 0, 4, 0),
+ ( "J2", 1, 0, 1),
+ ( "J5", 6, 0, 1),
+ ( "J6", 10, 0, 1),
+ ( "J8", 11, 0, 1),
+ ("J10", 13, 2, 0),
+ ("J11", 13, 6, 0),
+ ( "K1", 0, 3, 1),
+ ( "K2", 2, 0, 0),
+ ( "K3", 2, 0, 1),
+ ( "K4", 4, 0, 0),
+ ( "K5", 5, 0, 0),
+ ( "K7", 7, 0, 1),
+ ( "K8", 9, 0, 0),
+ ( "K9", 13, 1, 0),
+ ("K10", 13, 1, 1),
+ ("K11", 13, 3, 1),
+ ( "L1", 0, 2, 1),
+ ( "L2", 3, 0, 0),
+ ( "L3", 3, 0, 1),
+ ( "L4", 4, 0, 1),
+ ( "L5", 7, 0, 0),
+ ( "L7", 8, 0, 0),
+ ( "L9", 8, 0, 1),
+ ("L10", 9, 0, 1),
+ ("L11", 13, 4, 0),
+ ],
"1k-cb81": [
( "A2", 2, 17, 1),
( "A3", 3, 17, 1),
diff --git a/icefuzz/icecube.sh b/icefuzz/icecube.sh
index 5b5f9ce..cba804a 100644
--- a/icefuzz/icecube.sh
+++ b/icefuzz/icecube.sh
@@ -103,6 +103,10 @@ case "${ICEDEV:-hx1k-tq144}" in
iCEPACKAGE="CM81"
iCE40DEV="iCE40LP1K"
;;
+ lp1k-cm121)
+ iCEPACKAGE="CM121"
+ iCE40DEV="iCE40LP1K"
+ ;;
lp1k-qn84)
iCEPACKAGE="QN84"
iCE40DEV="iCE40LP1K"
diff --git a/icefuzz/pinloc/pinloc-1k-cm121.sh b/icefuzz/pinloc/pinloc-1k-cm121.sh
new file mode 100644
index 0000000..77f61d6
--- /dev/null
+++ b/icefuzz/pinloc/pinloc-1k-cm121.sh
@@ -0,0 +1,49 @@
+#!/bin/bash
+
+mkdir -p pinloc-1k-cm121
+cd pinloc-1k-cm121
+
+pins="
+ A1 A2 A3 A5 A7 A8 A9 A10 A11
+ B1 B2 B3 B4 B5 B7 B8 B9 B10 B11
+ C1 C2 C3 C4 C5 C6 C7 C8 C9 C10 C11
+ D1 D2 D3 D4 D5 D6 D10 D11
+ E2 E3 E4 E6 E7 E8 E9 E10
+ F2 F3 F4 F5 F6 F8 F9 F11
+ G2 G4 G8 G9 G11
+ H1 H2 H4 H5 H6 H7 H8 H9 H10 H11
+ J1 J2 J5 J6 J8 J10 J11
+ K1 K2 K3 K4 K5 K7 K8 K9 K10 K11
+ L1 L2 L3 L4 L5 L7 L9 L10 L11
+"
+
+if [ $(echo $pins | wc -w) -ne 95 ]; then
+ echo "Incorrect number of pins:" $(echo $pins | wc -w)
+ exit 1
+fi
+
+{
+ echo -n "all:"
+ for pin in $pins; do
+ id="pinloc-1k-cm121_${pin}"
+ echo -n " ${id}.exp"
+ done
+ echo
+
+ for pin in $pins; do
+ id="pinloc-1k-cm121_${pin}"
+ echo "module top(output y); assign y = 0; endmodule" > ${id}.v
+ echo "set_io y ${pin}" >> ${id}.pcf
+ echo; echo "${id}.exp:"
+ echo " ICEDEV=lp1k-cm121 bash ../../icecube.sh ${id} > ${id}.log 2>&1"
+ echo " ../../../icebox/icebox_explain.py ${id}.asc > ${id}.exp.new"
+ echo " ! grep '^Warning: pin' ${id}.log"
+ echo " rm -rf ${id}.tmp"
+ echo " mv ${id}.exp.new ${id}.exp"
+ done
+} > pinloc-1k-cm121.mk
+
+set -ex
+make -f pinloc-1k-cm121.mk -j4
+python3 ../pinlocdb.py pinloc-1k-cm121_*.exp > ../pinloc-1k-cm121.txt
+