Cleanups in xilinx examples
authorClifford Wolf <clifford@clifford.at>
Sun, 27 Oct 2013 08:52:00 +0000 (09:52 +0100)
committerClifford Wolf <clifford@clifford.at>
Sun, 27 Oct 2013 08:58:53 +0000 (09:58 +0100)
techlibs/xilinx/example_mojo_counter/example.sh
techlibs/xilinx/example_sim_counter/run_sim.sh [new file with mode: 0644]
techlibs/xilinx/example_sim_counter/run_testbench.sh [deleted file]

index 466fadade7fcf435c036203eb48568673524ad42..74a0c117f5d03eb7c1692c2271fd719902761fa2 100644 (file)
@@ -2,70 +2,17 @@
 
 set -ex
 
-XILINX_DIR=/opt/Xilinx/14.5/ISE_DS/ISE/
+XILINX_DIR=/opt/Xilinx/14.5/ISE_DS/ISE
 XILINX_PART=xc6slx9-2-tqg144
 
-../../../yosys - << EOT
-# read design
-read_verilog example.v
-
-# high-level synthesis
-hierarchy -check -top top
-proc; opt; fsm; opt; techmap; opt
-
-# mapping logic to LUTs using Berkeley ABC
-abc -lut 6; opt
-
-# map internal cells to FPGA cells
-techmap -map ../cells.v; opt
-
-# insert clock buffers
-select -set clocks */t:FDRE %x:+FDRE[C] */t:FDRE %d
-iopadmap -inpad BUFGP O:I @clocks
-
-# insert i/o buffers
-iopadmap -outpad OBUF I:O -inpad IBUF O:I @clocks %n
-
-# write netlist
-write_edif synth.edif
-EOT
-
-cat > bitgen.ut <<- EOT
-       -w
-       -g DebugBitstream:No
-       -g Binary:no
-       -g CRC:Enable
-       -g Reset_on_err:No
-       -g ConfigRate:2
-       -g ProgPin:PullUp
-       -g TckPin:PullUp
-       -g TdiPin:PullUp
-       -g TdoPin:PullUp
-       -g TmsPin:PullUp
-       -g UnusedPin:PullDown
-       -g UserID:0xFFFFFFFF
-       -g ExtMasterCclk_en:No
-       -g SPI_buswidth:1
-       -g TIMER_CFG:0xFFFF
-       -g multipin_wakeup:No
-       -g StartUpClk:CClk
-       -g DONE_cycle:4
-       -g GTS_cycle:5
-       -g GWE_cycle:6
-       -g LCK_cycle:NoWait
-       -g Security:None
-       -g DonePipe:No
-       -g DriveDone:No
-       -g en_sw_gsr:No
-       -g drive_awake:No
-       -g sw_clk:Startupclk
-       -g sw_gwe_cycle:5
-       -g sw_gts_cycle:4
+../../../yosys - <<- EOT
+       read_verilog example.v
+       synth_xilinx -edif synth.edif
 EOT
 
 $XILINX_DIR/bin/lin64/edif2ngd -a synth.edif synth.ngo
 $XILINX_DIR/bin/lin64/ngdbuild -p $XILINX_PART -uc example.ucf synth.ngo synth.ngd
 $XILINX_DIR/bin/lin64/map -p $XILINX_PART -w -o mapped.ncd synth.ngd constraints.pcf
 $XILINX_DIR/bin/lin64/par -w mapped.ncd placed.ncd constraints.pcf
-$XILINX_DIR/bin/lin64/bitgen -f bitgen.ut placed.ncd example.bit constraints.pcf
+$XILINX_DIR/bin/lin64/bitgen -w placed.ncd example.bit constraints.pcf
 
diff --git a/techlibs/xilinx/example_sim_counter/run_sim.sh b/techlibs/xilinx/example_sim_counter/run_sim.sh
new file mode 100644 (file)
index 0000000..e26d00d
--- /dev/null
@@ -0,0 +1,23 @@
+#!/bin/bash
+
+set -ex
+
+XILINX_DIR=/opt/Xilinx/14.5/ISE_DS/ISE
+
+../../../yosys -p 'synth_xilinx -top counter; write_verilog -noattr testbench_synth.v' counter.v
+
+iverilog -o testbench_gold counter_tb.v counter.v
+iverilog -o testbench_gate counter_tb.v testbench_synth.v \
+       $XILINX_DIR/verilog/src/{glbl,unisims/{FDRE,LUT1,LUT2,LUT3,LUT4,LUT5,LUT6}}.v
+
+./testbench_gold > testbench_gold.txt
+./testbench_gate > testbench_gate.txt
+
+if diff -u testbench_gold.txt testbench_gate.txt; then
+       set +x; echo; echo; banner "  PASS  "
+else
+       exit 1
+fi
+
+rm -f testbench_{synth,gold,gate,mapped}*
+
diff --git a/techlibs/xilinx/example_sim_counter/run_testbench.sh b/techlibs/xilinx/example_sim_counter/run_testbench.sh
deleted file mode 100644 (file)
index b4251f4..0000000
+++ /dev/null
@@ -1,86 +0,0 @@
-#!/bin/bash
-
-set -ex
-
-XILINX_DIR=/opt/Xilinx/14.2/ISE_DS/ISE/
-
-../../yosys - <<- EOT
-       # read design
-       read_verilog counter.v
-
-       # high-level synthesis
-       hierarchy -check -top counter
-       proc; opt; fsm; opt; techmap; opt
-
-       # mapping logic to LUTs using Berkeley ABC
-       abc -lut 6; opt
-
-       # map internal cells to FPGA cells
-       techmap -map cells.v; opt
-
-       # write netlist
-       write_verilog -noattr testbench_synth.v
-       write_edif testbench_synth.edif
-EOT
-
-iverilog -o testbench_gold counter_tb.v counter.v
-iverilog -o testbench_gate counter_tb.v testbench_synth.v \
-       $XILINX_DIR/verilog/src/{glbl,unisims/{FDRE,LUT1,LUT2,LUT3,LUT4,LUT5,LUT6}}.v
-
-./testbench_gold > testbench_gold.txt
-./testbench_gate > testbench_gate.txt
-
-if diff -u testbench_gold.txt testbench_gate.txt; then
-       set +x; echo; echo; banner "  PASS  "
-else
-       exit 1
-fi
-
-if [ "$*" = "-map" ]; then
-       set -x
-
-       cat > testbench_synth.ut <<- EOT
-               -w
-               -g DebugBitstream:No
-               -g Binary:no
-               -g CRC:Enable
-               -g Reset_on_err:No
-               -g ConfigRate:2
-               -g ProgPin:PullUp
-               -g TckPin:PullUp
-               -g TdiPin:PullUp
-               -g TdoPin:PullUp
-               -g TmsPin:PullUp
-               -g UnusedPin:PullDown
-               -g UserID:0xFFFFFFFF
-               -g ExtMasterCclk_en:No
-               -g SPI_buswidth:1
-               -g TIMER_CFG:0xFFFF
-               -g multipin_wakeup:No
-               -g StartUpClk:CClk
-               -g DONE_cycle:4
-               -g GTS_cycle:5
-               -g GWE_cycle:6
-               -g LCK_cycle:NoWait
-               -g Security:None
-               -g DonePipe:No
-               -g DriveDone:No
-               -g en_sw_gsr:No
-               -g drive_awake:No
-               -g sw_clk:Startupclk
-               -g sw_gwe_cycle:5
-               -g sw_gts_cycle:4
-       EOT
-
-       $XILINX_DIR/bin/lin64/edif2ngd testbench_synth.edif
-       $XILINX_DIR/bin/lin64/ngdbuild -p xc7k70t testbench_synth
-       $XILINX_DIR/bin/lin64/map -p xc7k70t-fbg676-1 -w -o testbench_mapped.ncd testbench_synth prffile.pcf
-       $XILINX_DIR/bin/lin64/par -w testbench_mapped.ncd testbench_synth.ncd prffile.pcf
-       $XILINX_DIR/bin/lin64/bitgen -f testbench_synth.ut testbench_synth.ncd
-fi
-
-if [ "$*" = "-clean" ]; then
-       rm -rf netlist.lst _xmsgs/ prffile.pcf
-       rm -f testbench_{synth,gold,gate,mapped}*
-fi
-