2018-02-13 19:04:52 -06:00
|
|
|
`include "hvsync_generator.v"
|
|
|
|
`include "lfsr.v"
|
|
|
|
|
2018-02-15 12:31:32 -06:00
|
|
|
module starfield_top(clk, reset, hsync, vsync, rgb);
|
2018-02-13 19:04:52 -06:00
|
|
|
|
|
|
|
input clk, reset;
|
|
|
|
output hsync, vsync;
|
|
|
|
output [2:0] rgb;
|
|
|
|
wire display_on;
|
|
|
|
wire [8:0] hpos;
|
|
|
|
wire [8:0] vpos;
|
|
|
|
wire [15:0] lfsr;
|
|
|
|
|
|
|
|
hvsync_generator hvsync_gen(
|
|
|
|
.clk(clk),
|
|
|
|
.reset(reset),
|
|
|
|
.hsync(hsync),
|
|
|
|
.vsync(vsync),
|
|
|
|
.display_on(display_on),
|
|
|
|
.hpos(hpos),
|
|
|
|
.vpos(vpos)
|
|
|
|
);
|
|
|
|
|
|
|
|
wire star_enable = !hpos[8] & !vpos[8];
|
|
|
|
|
|
|
|
// LFSR with period = 2^16-1 = 256*256-1
|
2018-07-20 20:04:39 -05:00
|
|
|
LFSR #(16'b1000000001011,0) lfsr_gen(
|
2018-02-13 19:04:52 -06:00
|
|
|
.clk(clk),
|
|
|
|
.reset(reset),
|
|
|
|
.enable(star_enable),
|
|
|
|
.lfsr(lfsr));
|
|
|
|
|
|
|
|
wire star_on = &lfsr[15:9];
|
2018-02-17 23:12:09 -06:00
|
|
|
assign rgb = display_on && star_on ? lfsr[2:0] : 0;
|
2018-02-13 19:04:52 -06:00
|
|
|
|
|
|
|
endmodule
|