aboutsummaryrefslogtreecommitdiffstats
path: root/icefuzz/pinloc/pinloc-4k-cm225.sh
blob: 0cc2ca1d65e17a2070200f2a029c668a5454d68a (plain)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
#!/bin/bash

mkdir -p pinloc-4k-cm225
cd pinloc-4k-cm225

pins="
	A1 A2 A5 A6 A7 A8 A9 A11 A15
	B2 B3 B4 B5 B6 B7 B8 B9 B10 B11 B12 B13 B14 B15
	C1 C3 C4 C5 C6 C7 C8 C9 C10 C11 C12 C13 C14
	D1 D2 D3 D4 D5 D6 D7 D8 D9 D10 D11 D13 D14 D15
	E2 E3 E4 E5 E6 E9 E10 E11 E13 E14
	F1 F2 F3 F4 F5 F7 F9 F11 F12 F13 F14 F15
	G2 G4 G5 G10 G11 G12 G13 G14 G15
	H1 H2 H3 H4 H5 H6 H11 H12 H13 H14
	J1 J2 J3 J4 J5 J10 J11 J12 J14 J15
	K1 K4 K5 K9 K11 K12 K13 K15
	L3 L4 L5 L6 L7 L9 L10 L11 L12 L13
	M1 M2 M3 M4 M5 M6 M7 M8 M9 M11 M12 M13 M15
	N2 N3 N4 N5 N6 N7 N9 N10 N12
	P1 P2 P4 P5 P6 P7 P8 P9 P10 P11 P12 P13 P14 P15
	R1 R2 R3 R4 R5 R6 R9 R10 R11 R12 R14 R15
"

if [ $(echo $pins | wc -w) -ne 167 ]; then
	echo "Incorrect number of pins:" $(echo $pins | wc -w)
	exit 1
fi

{
	echo -n "all:"
	for pin in $pins; do
		id="pinloc-4k-cm225_${pin}"
		echo -n " ${id}.exp"
	done
	echo

	for pin in $pins; do
		id="pinloc-4k-cm225_${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=lp4k-cm225 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-4k-cm225.mk

set -ex
make -f pinloc-4k-cm225.mk -j4
python3 ../pinlocdb.py pinloc-4k-cm225_*.exp > ../pinloc-4k-cm225.txt