mirror of https://github.com/YosysHQ/yosys.git
[EXAMPLES] Ported the mojo counter example to Zynq ZED board.
Will be adding a tutorial on this to verilog.james.walms.co.uk in a few days.
This commit is contained in:
parent
f39c0c9928
commit
40b3551b45
|
@ -0,0 +1,10 @@
|
||||||
|
|
||||||
|
This is a simple example for Yosys synthesis targeting the ZED FPGA
|
||||||
|
development board [1, 2]. Simple script for xst-based synthesis (incl.
|
||||||
|
generation of reference edif files) and uploading to the board can be
|
||||||
|
found here [3].
|
||||||
|
|
||||||
|
[1] http://www.zedboard.org/
|
||||||
|
[2] https://www.xilinx.com/zynq/
|
||||||
|
[3] http://verilog.james.walms.co.uk/
|
||||||
|
|
|
@ -0,0 +1,18 @@
|
||||||
|
#!/bin/bash
|
||||||
|
|
||||||
|
set -ex
|
||||||
|
|
||||||
|
XILINX_DIR=/opt/Xilinx/14.7/ISE_DS/ISE
|
||||||
|
XILINX_PART=xc7z020clg484-1
|
||||||
|
|
||||||
|
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 -w placed.ncd example.bit constraints.pcf
|
||||||
|
$XILINX_DIR/bin/lin64/promgen -w -b -p bin -o example.bin -u 0 example.bit -data_width 32
|
|
@ -0,0 +1,14 @@
|
||||||
|
NET "clk" TNM_NET = clk;
|
||||||
|
TIMESPEC TS_clk = PERIOD "clk" 50 MHz HIGH 50%;
|
||||||
|
|
||||||
|
NET "clk" LOC = Y9 | IOSTANDARD=LVCMOS33; # "GCLK"
|
||||||
|
NET "ctrl" LOC = P16 | IOSTANDARD=LVCMOS18; # "BTNC"
|
||||||
|
|
||||||
|
NET "led_0" LOC = T22 | IOSTANDARD=LVCMOS33; # "LD0"
|
||||||
|
NET "led_1" LOC = T21 | IOSTANDARD=LVCMOS33; # "LD0"
|
||||||
|
NET "led_2" LOC = U22 | IOSTANDARD=LVCMOS33; # "LD0"
|
||||||
|
NET "led_3" LOC = U21 | IOSTANDARD=LVCMOS33; # "LD0"
|
||||||
|
NET "led_4" LOC = V22 | IOSTANDARD=LVCMOS33; # "LD0"
|
||||||
|
NET "led_5" LOC = W22 | IOSTANDARD=LVCMOS33; # "LD0"
|
||||||
|
NET "led_6" LOC = U19 | IOSTANDARD=LVCMOS33; # "LD0"
|
||||||
|
NET "led_7" LOC = U14 | IOSTANDARD=LVCMOS33; # "LD0"
|
|
@ -0,0 +1,14 @@
|
||||||
|
module top(clk, ctrl, led_7, led_6, led_5, led_4, led_3, led_2, led_1, led_0);
|
||||||
|
|
||||||
|
input clk, ctrl;
|
||||||
|
output led_7, led_6, led_5, led_4;
|
||||||
|
output led_3, led_2, led_1, led_0;
|
||||||
|
|
||||||
|
reg [31:0] counter;
|
||||||
|
|
||||||
|
always @(posedge clk)
|
||||||
|
counter <= counter + (ctrl ? 4 : 1);
|
||||||
|
|
||||||
|
assign {led_7, led_6, led_5, led_4, led_3, led_2, led_1, led_0} = counter >> 24;
|
||||||
|
|
||||||
|
endmodule
|
Loading…
Reference in New Issue