2018-08-13 18:17:36 -04:00
|
|
|
|
2017-11-18 14:51:25 -05:00
|
|
|
`ifndef HVSYNC_GENERATOR_H
|
|
|
|
`define HVSYNC_GENERATOR_H
|
2017-11-11 14:45:32 -05:00
|
|
|
|
2018-10-01 12:30:47 -04:00
|
|
|
/*
|
|
|
|
Video sync generator, used to drive a simulated CRT.
|
|
|
|
To use:
|
|
|
|
- Wire the hsync and vsync signals to top level outputs
|
|
|
|
- Add a 3-bit (or more) "rgb" output to the top level
|
|
|
|
*/
|
|
|
|
|
2018-02-06 18:07:40 -06:00
|
|
|
module hvsync_generator(clk, reset, hsync, vsync, display_on, hpos, vpos);
|
|
|
|
|
|
|
|
input clk;
|
|
|
|
input reset;
|
2018-02-18 18:19:20 -06:00
|
|
|
output reg hsync, vsync;
|
2018-02-06 18:07:40 -06:00
|
|
|
output display_on;
|
2018-02-18 18:19:20 -06:00
|
|
|
output reg [8:0] hpos;
|
|
|
|
output reg [8:0] vpos;
|
2017-11-11 14:45:32 -05:00
|
|
|
|
2018-07-31 14:41:27 -04:00
|
|
|
// declarations for TV-simulator sync parameters
|
|
|
|
// horizontal constants
|
2018-02-15 12:31:32 -06:00
|
|
|
parameter H_DISPLAY = 256; // horizontal display width
|
|
|
|
parameter H_BACK = 23; // horizontal left border (back porch)
|
|
|
|
parameter H_FRONT = 7; // horizontal right border (front porch)
|
|
|
|
parameter H_SYNC = 23; // horizontal sync width
|
2018-07-31 14:41:27 -04:00
|
|
|
// vertical constants
|
2018-02-15 12:31:32 -06:00
|
|
|
parameter V_DISPLAY = 240; // vertical display height
|
|
|
|
parameter V_TOP = 5; // vertical top border
|
|
|
|
parameter V_BOTTOM = 14; // vertical bottom border
|
|
|
|
parameter V_SYNC = 3; // vertical sync # lines
|
2018-07-31 14:41:27 -04:00
|
|
|
// derived constants
|
2018-02-15 12:31:32 -06:00
|
|
|
parameter H_SYNC_START = H_DISPLAY + H_FRONT;
|
|
|
|
parameter H_SYNC_END = H_DISPLAY + H_FRONT + H_SYNC - 1;
|
|
|
|
parameter H_MAX = H_DISPLAY + H_BACK + H_FRONT + H_SYNC - 1;
|
|
|
|
parameter V_SYNC_START = V_DISPLAY + V_BOTTOM;
|
|
|
|
parameter V_SYNC_END = V_DISPLAY + V_BOTTOM + V_SYNC - 1;
|
|
|
|
parameter V_MAX = V_DISPLAY + V_TOP + V_BOTTOM + V_SYNC - 1;
|
|
|
|
|
2018-07-31 14:41:27 -04:00
|
|
|
wire hmaxxed = (hpos == H_MAX) || reset; // set when hpos is maximum
|
|
|
|
wire vmaxxed = (vpos == V_MAX) || reset; // set when vpos is maximum
|
2017-11-28 20:48:27 -05:00
|
|
|
|
2018-02-09 10:59:52 -06:00
|
|
|
// horizontal position counter
|
2017-11-28 20:48:27 -05:00
|
|
|
always @(posedge clk)
|
2018-01-13 14:48:58 -06:00
|
|
|
begin
|
2018-02-09 10:59:52 -06:00
|
|
|
hsync <= (hpos>=H_SYNC_START && hpos<=H_SYNC_END);
|
2017-11-17 16:01:07 -05:00
|
|
|
if(hmaxxed)
|
|
|
|
hpos <= 0;
|
2017-11-11 14:45:32 -05:00
|
|
|
else
|
2017-11-17 16:01:07 -05:00
|
|
|
hpos <= hpos + 1;
|
2018-02-03 14:20:56 -06:00
|
|
|
end
|
2017-11-11 14:45:32 -05:00
|
|
|
|
2018-02-09 10:59:52 -06:00
|
|
|
// vertical position counter
|
2017-11-11 14:45:32 -05:00
|
|
|
always @(posedge clk)
|
2018-01-13 14:48:58 -06:00
|
|
|
begin
|
2018-02-09 10:59:52 -06:00
|
|
|
vsync <= (vpos>=V_SYNC_START && vpos<=V_SYNC_END);
|
2017-11-17 16:01:07 -05:00
|
|
|
if(hmaxxed)
|
2018-02-09 10:59:52 -06:00
|
|
|
if (vmaxxed)
|
2017-11-17 16:01:07 -05:00
|
|
|
vpos <= 0;
|
2018-02-09 10:59:52 -06:00
|
|
|
else
|
|
|
|
vpos <= vpos + 1;
|
2018-02-03 14:20:56 -06:00
|
|
|
end
|
2018-01-13 14:48:58 -06:00
|
|
|
|
2018-07-31 14:41:27 -04:00
|
|
|
// display_on is set when beam is in "safe" visible frame
|
2018-02-09 10:59:52 -06:00
|
|
|
assign display_on = (hpos<H_DISPLAY) && (vpos<V_DISPLAY);
|
2017-11-11 14:45:32 -05:00
|
|
|
|
|
|
|
endmodule
|
2017-11-18 14:51:25 -05:00
|
|
|
|
|
|
|
`endif
|