Adding testbench
This commit is contained in:
3
.gitignore
vendored
Normal file
3
.gitignore
vendored
Normal file
@ -0,0 +1,3 @@
|
|||||||
|
*.vpp
|
||||||
|
*.vcd
|
||||||
|
*.out
|
36
Makefile
Normal file
36
Makefile
Normal file
@ -0,0 +1,36 @@
|
|||||||
|
TESTBENCH = vgasquare_tb.v
|
||||||
|
SRC = vgasquare.v vga640x480.v
|
||||||
|
|
||||||
|
#Tools
|
||||||
|
COMPILER = "C:\System\iverilog\bin\iverilog.exe"
|
||||||
|
SIMULATOR = "C:\System\iverilog\bin\vvp.exe"
|
||||||
|
VIEWER = "C:\System\iverilog\gtkwave\bin\gtkwave.exe"
|
||||||
|
|
||||||
|
TBOUTPUT = vgasquare_tb.vcd #THIS NEEDS TO MATCH THE OUTPUT FILE
|
||||||
|
#FROM YOUR TESTBENCH
|
||||||
|
###############################################################################
|
||||||
|
# BE CAREFUL WHEN CHANGING ITEMS BELOW THIS LINE
|
||||||
|
###############################################################################
|
||||||
|
#TOOL OPTIONS
|
||||||
|
COFLAGS = -o
|
||||||
|
SFLAGS =
|
||||||
|
SOUTPUT = -lxt #SIMULATOR OUTPUT TYPE
|
||||||
|
#TOOL OUTPUT
|
||||||
|
COUTPUT = vgasquare_tb.vpp #COMPILER OUTPUT
|
||||||
|
###############################################################################
|
||||||
|
#MAKE DIRECTIVES
|
||||||
|
check : $(TESTBENCH) $(SRC)
|
||||||
|
$(COMPILER) -v $(SRC)
|
||||||
|
|
||||||
|
simulate: $(COUTPUT)
|
||||||
|
$(SIMULATOR) $(SFLAGS) $(COUTPUT) $(SOUTPUT)
|
||||||
|
|
||||||
|
display: $(TBOUTPUT)
|
||||||
|
$(VIEWER) $(TBOUTPUT)
|
||||||
|
|
||||||
|
#MAKE DEPENDANCIES
|
||||||
|
$(TBOUTPUT): $(COUTPUT)
|
||||||
|
$(SIMULATOR) $(SOPTIONS) $(COUTPUT) $(SOUTPUT)
|
||||||
|
|
||||||
|
$(COUTPUT): $(TESTBENCH) $(SRC)
|
||||||
|
$(COMPILER) $(COFLAGS) $(COUTPUT) $(TESTBENCH) $(SRC)
|
@ -91,7 +91,6 @@
|
|||||||
wire [5:0] box_color = reg_color[5:0];
|
wire [5:0] box_color = reg_color[5:0];
|
||||||
|
|
||||||
vgasquare display (
|
vgasquare display (
|
||||||
.CLK(s00_axi_aclk), // board clock
|
|
||||||
.PIXEL_CLK(I_PIXEL_CLK), // Pixel clock: 25Mhz (or 25.125MHz) for VGA
|
.PIXEL_CLK(I_PIXEL_CLK), // Pixel clock: 25Mhz (or 25.125MHz) for VGA
|
||||||
.RST_BTN(s00_axi_aresetn), // reset button
|
.RST_BTN(s00_axi_aresetn), // reset button
|
||||||
.box_x1(box_x1),
|
.box_x1(box_x1),
|
||||||
|
@ -8,7 +8,6 @@
|
|||||||
`default_nettype none
|
`default_nettype none
|
||||||
|
|
||||||
module vga640x480(
|
module vga640x480(
|
||||||
input wire i_clk, // base clock
|
|
||||||
input wire i_pix_stb, // pixel clock strobe
|
input wire i_pix_stb, // pixel clock strobe
|
||||||
input wire i_rst, // reset: restarts frame
|
input wire i_rst, // reset: restarts frame
|
||||||
output wire o_hs, // horizontal sync
|
output wire o_hs, // horizontal sync
|
||||||
|
@ -6,7 +6,6 @@
|
|||||||
`default_nettype none
|
`default_nettype none
|
||||||
|
|
||||||
module vgasquare(
|
module vgasquare(
|
||||||
input wire CLK, // board clock
|
|
||||||
input wire PIXEL_CLK, // Pixel clock: 25Mhz (or 25.125MHz) for VGA
|
input wire PIXEL_CLK, // Pixel clock: 25Mhz (or 25.125MHz) for VGA
|
||||||
input wire RST_BTN, // reset button
|
input wire RST_BTN, // reset button
|
||||||
input wire [9:0] box_x1,
|
input wire [9:0] box_x1,
|
||||||
@ -28,7 +27,6 @@ module vgasquare(
|
|||||||
wire [8:0] y; // current pixel y position: 9-bit value: 0-511
|
wire [8:0] y; // current pixel y position: 9-bit value: 0-511
|
||||||
|
|
||||||
vga640x480 display (
|
vga640x480 display (
|
||||||
.i_clk(CLK),
|
|
||||||
.i_pix_stb(PIXEL_CLK),
|
.i_pix_stb(PIXEL_CLK),
|
||||||
.i_rst(rst),
|
.i_rst(rst),
|
||||||
.o_active(VGA_ACTIVE),
|
.o_active(VGA_ACTIVE),
|
||||||
|
33
vgasquare_tb.v
Normal file
33
vgasquare_tb.v
Normal file
@ -0,0 +1,33 @@
|
|||||||
|
`timescale 10ns/10ns
|
||||||
|
module vgasquare_tb;
|
||||||
|
|
||||||
|
// Make reset high
|
||||||
|
reg reset = 1;
|
||||||
|
initial begin
|
||||||
|
$dumpfile("vgasquare_tb.vcd");
|
||||||
|
$dumpvars;//(pixel_clk, pixel_clk, O_VGA_ACTIVE,O_VGA_HS, O_VGA_VS);
|
||||||
|
#10000000 $finish;
|
||||||
|
end
|
||||||
|
|
||||||
|
|
||||||
|
//Make our pixel clock
|
||||||
|
reg pixel_clk = 0;
|
||||||
|
always #2 pixel_clk = !pixel_clk;
|
||||||
|
|
||||||
|
wire O_VGA_ACTIVE;
|
||||||
|
wire O_VGA_HS;
|
||||||
|
wire O_VGA_VS;
|
||||||
|
|
||||||
|
vgasquare display (
|
||||||
|
.PIXEL_CLK(pixel_clk), // Pixel clock: 25Mhz (or 25.125MHz) for VGA
|
||||||
|
.RST_BTN(reset), // reset button
|
||||||
|
.box_x1(10'd120),
|
||||||
|
.box_x2(10'd520),
|
||||||
|
.box_y1(9'd120),
|
||||||
|
.box_y2(9'd360),
|
||||||
|
.box_color(6'b111000), //1 bit for each color Foreground and background
|
||||||
|
.VGA_ACTIVE(O_VGA_ACTIVE),
|
||||||
|
.VGA_HS(O_VGA_HS), // horizontal sync output
|
||||||
|
.VGA_VS(O_VGA_VS) // vertical sync output
|
||||||
|
);
|
||||||
|
endmodule // test
|
Reference in New Issue
Block a user