mirror of
https://github.com/YosysHQ/yosys
synced 2025-07-24 13:18:56 +00:00
Renamed techlibs/xilinx7 to techlibs/xilinx
This commit is contained in:
parent
4007b41d40
commit
d635f8adaa
8 changed files with 0 additions and 0 deletions
53
techlibs/xilinx/cells.v
Normal file
53
techlibs/xilinx/cells.v
Normal file
|
@ -0,0 +1,53 @@
|
|||
module \$_DFF_P_ (D, C, Q);
|
||||
|
||||
input D, C;
|
||||
output Q;
|
||||
|
||||
FDRE fpga_dff (
|
||||
.D(D), .Q(Q), .C(C),
|
||||
.CE(1'b1), .R(1'b0)
|
||||
);
|
||||
|
||||
endmodule
|
||||
|
||||
module \$lut (I, O);
|
||||
|
||||
parameter WIDTH = 0;
|
||||
parameter LUT = 0;
|
||||
|
||||
input [WIDTH-1:0] I;
|
||||
output O;
|
||||
|
||||
generate
|
||||
if (WIDTH == 1) begin:lut1
|
||||
LUT1 #(.INIT(LUT)) fpga_lut (.O(O),
|
||||
.I0(I[0]));
|
||||
end else
|
||||
if (WIDTH == 2) begin:lut2
|
||||
LUT2 #(.INIT(LUT)) fpga_lut (.O(O),
|
||||
.I0(I[0]), .I1(I[1]));
|
||||
end else
|
||||
if (WIDTH == 3) begin:lut3
|
||||
LUT3 #(.INIT(LUT)) fpga_lut (.O(O),
|
||||
.I0(I[0]), .I1(I[1]), .I2(I[2]));
|
||||
end else
|
||||
if (WIDTH == 4) begin:lut4
|
||||
LUT4 #(.INIT(LUT)) fpga_lut (.O(O),
|
||||
.I0(I[0]), .I1(I[1]), .I2(I[2]),
|
||||
.I3(I[3]));
|
||||
end else
|
||||
if (WIDTH == 5) begin:lut5
|
||||
LUT5 #(.INIT(LUT)) fpga_lut (.O(O),
|
||||
.I0(I[0]), .I1(I[1]), .I2(I[2]),
|
||||
.I3(I[3]), .I4(I[4]));
|
||||
end else
|
||||
if (WIDTH == 6) begin:lut6
|
||||
LUT6 #(.INIT(LUT)) fpga_lut (.O(O),
|
||||
.I0(I[0]), .I1(I[1]), .I2(I[2]),
|
||||
.I3(I[3]), .I4(I[4]), .I5(I[5]));
|
||||
end else begin:error
|
||||
wire TECHMAP_FAIL;
|
||||
end
|
||||
endgenerate
|
||||
|
||||
endmodule
|
12
techlibs/xilinx/counter.v
Normal file
12
techlibs/xilinx/counter.v
Normal file
|
@ -0,0 +1,12 @@
|
|||
module counter (clk, rst, en, count);
|
||||
|
||||
input clk, rst, en;
|
||||
output reg [3:0] count;
|
||||
|
||||
always @(posedge clk)
|
||||
if (rst)
|
||||
count <= 4'd0;
|
||||
else if (en)
|
||||
count <= count + 4'd1;
|
||||
|
||||
endmodule
|
61
techlibs/xilinx/counter_tb.v
Normal file
61
techlibs/xilinx/counter_tb.v
Normal file
|
@ -0,0 +1,61 @@
|
|||
`timescale 1 ns / 1 ps
|
||||
|
||||
module testbench;
|
||||
|
||||
reg clk, en, rst;
|
||||
wire [3:0] count;
|
||||
|
||||
counter uut_counter(
|
||||
.clk(clk),
|
||||
.count(count),
|
||||
.en(en),
|
||||
.rst(rst)
|
||||
);
|
||||
|
||||
initial begin
|
||||
clk <= 0;
|
||||
forever begin
|
||||
#50;
|
||||
clk <= ~clk;
|
||||
end
|
||||
end
|
||||
|
||||
initial begin
|
||||
@(posedge clk);
|
||||
forever begin
|
||||
@(posedge clk);
|
||||
$display("%d", count);
|
||||
end
|
||||
end
|
||||
|
||||
initial begin
|
||||
rst <= 1; en <= 0; @(posedge clk);
|
||||
rst <= 1; en <= 0; @(posedge clk);
|
||||
rst <= 0; en <= 0; @(posedge clk);
|
||||
rst <= 0; en <= 1; @(posedge clk);
|
||||
rst <= 0; en <= 1; @(posedge clk);
|
||||
rst <= 0; en <= 1; @(posedge clk);
|
||||
rst <= 0; en <= 0; @(posedge clk);
|
||||
rst <= 0; en <= 1; @(posedge clk);
|
||||
rst <= 0; en <= 1; @(posedge clk);
|
||||
rst <= 0; en <= 1; @(posedge clk);
|
||||
rst <= 1; en <= 1; @(posedge clk);
|
||||
rst <= 0; en <= 0; @(posedge clk);
|
||||
rst <= 0; en <= 1; @(posedge clk);
|
||||
rst <= 0; en <= 1; @(posedge clk);
|
||||
rst <= 0; en <= 0; @(posedge clk);
|
||||
rst <= 0; en <= 1; @(posedge clk);
|
||||
rst <= 0; en <= 1; @(posedge clk);
|
||||
rst <= 0; en <= 0; @(posedge clk);
|
||||
rst <= 1; en <= 0; @(posedge clk);
|
||||
rst <= 0; en <= 1; @(posedge clk);
|
||||
rst <= 0; en <= 0; @(posedge clk);
|
||||
rst <= 0; en <= 1; @(posedge clk);
|
||||
rst <= 0; en <= 1; @(posedge clk);
|
||||
rst <= 0; en <= 0; @(posedge clk);
|
||||
rst <= 0; en <= 1; @(posedge clk);
|
||||
rst <= 0; en <= 0; @(posedge clk);
|
||||
$finish;
|
||||
end
|
||||
|
||||
endmodule
|
10
techlibs/xilinx/example_mojo_counter/README
Normal file
10
techlibs/xilinx/example_mojo_counter/README
Normal file
|
@ -0,0 +1,10 @@
|
|||
|
||||
This is a simple example for Yosys synthesis targeting the Mojo 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://embeddedmicro.com/tutorials/mojo
|
||||
[2] https://www.sparkfun.com/products/11953
|
||||
[3] http://svn.clifford.at/handicraft/2013/mojo/
|
||||
|
67
techlibs/xilinx/example_mojo_counter/example.sh
Normal file
67
techlibs/xilinx/example_mojo_counter/example.sh
Normal file
|
@ -0,0 +1,67 @@
|
|||
#!/bin/bash
|
||||
|
||||
set -ex
|
||||
|
||||
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 i/o buffers
|
||||
iopadmap -outpad OBUF I:O -inpad BUFGP O:I
|
||||
|
||||
# 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
|
||||
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
|
||||
|
13
techlibs/xilinx/example_mojo_counter/example.ucf
Normal file
13
techlibs/xilinx/example_mojo_counter/example.ucf
Normal file
|
@ -0,0 +1,13 @@
|
|||
NET "clk" TNM_NET = clk;
|
||||
TIMESPEC TS_clk = PERIOD "clk" 50 MHz HIGH 50%;
|
||||
|
||||
NET "clk" LOC = P56;
|
||||
|
||||
NET "led_0" LOC = P134;
|
||||
NET "led_1" LOC = P133;
|
||||
NET "led_2" LOC = P132;
|
||||
NET "led_3" LOC = P131;
|
||||
NET "led_4" LOC = P127;
|
||||
NET "led_5" LOC = P126;
|
||||
NET "led_6" LOC = P124;
|
||||
NET "led_7" LOC = P123;
|
14
techlibs/xilinx/example_mojo_counter/example.v
Normal file
14
techlibs/xilinx/example_mojo_counter/example.v
Normal file
|
@ -0,0 +1,14 @@
|
|||
module top(clk, led_7, led_6, led_5, led_4, led_3, led_2, led_1, led_0);
|
||||
|
||||
input clk;
|
||||
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 <= 32'b_1010_1010_1010_1010_1010_1010_1010_1010; // counter + 1;
|
||||
|
||||
assign {led_7, led_6, led_5, led_4, led_3, led_2, led_1, led_0} = counter >> 24;
|
||||
|
||||
endmodule
|
86
techlibs/xilinx/run_testbench.sh
Normal file
86
techlibs/xilinx/run_testbench.sh
Normal file
|
@ -0,0 +1,86 @@
|
|||
#!/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
|
||||
|
Loading…
Add table
Add a link
Reference in a new issue