⭐ 欢迎来到虫虫下载站! | 📦 资源下载 📁 资源专辑 ℹ️ 关于我们
⭐ 虫虫下载站

📄 vga_vtim.v.bak

📁 用来实现VGA发生时序
💻 BAK
字号:
/////////////////////////////////////////////////////////////////////////                                                             ////////  WISHBONE rev.B2 compliant VGA/LCD Core; Timing Generator   ////////  Video Timing Generator                                     ////////                                                             ////////  Author: Richard Herveille                                  ////////          richard@asics.ws                                   ////////          www.asics.ws                                       ////////                                                             ////////  Downloaded from: http://www.opencores.org/projects/vga_lcd ////////                                                             /////////////////////////////////////////////////////////////////////////////                                                             //////// Copyright (C) 2001 Richard Herveille                        ////////                    richard@asics.ws                         ////////                                                             //////// This source file may be used and distributed without        //////// restriction provided that this copyright statement is not   //////// removed from the file and that any derivative work contains //////// the original copyright notice and the associated disclaimer.////////                                                             ////////     THIS SOFTWARE IS PROVIDED ``AS IS'' AND WITHOUT ANY     //////// EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED   //////// TO, THE IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS   //////// FOR A PARTICULAR PURPOSE. IN NO EVENT SHALL THE AUTHOR      //////// OR CONTRIBUTORS BE LIABLE FOR ANY DIRECT, INDIRECT,         //////// INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES    //////// (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE   //////// GOODS OR SERVICES; LOSS OF USE, DATA, OR PROFITS; OR        //////// BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON ANY THEORY OF  //////// LIABILITY, WHETHER IN  CONTRACT, STRICT LIABILITY, OR TORT  //////// (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT  //////// OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE         //////// POSSIBILITY OF SUCH DAMAGE.                                 ////////                                                             ///////////////////////////////////////////////////////////////////////////  CVS Log////  $Id: vga_vtim.v,v 1.8 2003/05/07 09:48:54 rherveille Exp $////  $Date: 2003/05/07 09:48:54 $//  $Revision: 1.8 $//  $Author: rherveille $//  $Locker:  $//  $State: Exp $//// Change History://               $Log: vga_vtim.v,v $//               Revision 1.8  2003/05/07 09:48:54  rherveille//               Fixed some Wishbone RevB.3 related bugs.//               Changed layout of the core. Blocks are located more logically now.//               Started work on a dual clocked/double edge 12bit output. Commonly used by external devices like DVI transmitters.////               Revision 1.7  2003/03/19 12:50:45  rherveille//               Changed timing generator; made it smaller and easier.////               Revision 1.6  2002/04/20 10:02:39  rherveille//               Changed video timing generator.//               Changed wishbone master vertical gate count code.//               Fixed a potential bug in the wishbone slave (cursor color register readout).////               Revision 1.5  2002/01/28 03:47:16  rherveille//               Changed counter-library.//               Changed vga-core.//               Added 32bpp mode.////synopsys translate_off`include "timescale.v"//synopsys translate_onmodule vga_vtim(clk, ena, rst,// 	Tsync, Tgdel, Tgate, Tlen, 	Sync, Gate, Done);	// inputs & outputs	input clk; // master clock	input ena; // count enable	input rst; // synchronous active high reset/*	input [ 7:0] Tsync; // sync duration	input [ 7:0] Tgdel; // gate delay	input [15:0] Tgate; // gate length	input [15:0] Tlen;  // line time / frame time*/	output Sync; // synchronization pulse	output Gate; // gate	output Done; // done with line/frame	reg Sync;	reg Gate;	reg Done;	//	// module body	//	// generate timing statemachine	reg  [15:0] cnt, cnt_len;	wire [16:0] cnt_nxt, cnt_len_nxt;	wire        cnt_done, cnt_len_done;	assign cnt_nxt = {1'b0, cnt} -17'h1;	assign cnt_done = cnt_nxt[16];	assign cnt_len_nxt = {1'b0, cnt_len} -17'h1;	assign cnt_len_done = cnt_len_nxt[16];	reg [4:0] state;		parameter [ 7:0] Tsync = 8'h0; // sync duration	parameter [ 7:0] Tgdel = 8'h0; // gate delay	parameter [15:0] Tgate = 16'h0; // gate length	parameter [15:0] Tlen  = 16'h0;  // line time / frame time		parameter [4:0] idle_state = 5'b00001;	parameter [4:0] sync_state = 5'b00010;	parameter [4:0] gdel_state = 5'b00100;	parameter [4:0] gate_state = 5'b01000;	parameter [4:0] len_state  = 5'b10000;	always @(posedge clk)	  if (rst)	    begin	        state   <= #1 idle_state;	        cnt     <= #1 16'h0;	        cnt_len <= #1 16'b0;	        Sync    <= #1 1'b0;	        Gate    <= #1 1'b0;	        Done    <= #1 1'b0;	    end	  else if (ena)	    begin	        cnt     <= #1 cnt_nxt[15:0];	        cnt_len <= #1 cnt_len_nxt[15:0];	        Done    <= #1 1'b0;	        case (state) // synopsys full_case parallel_case	          idle_state:	            begin	                state   <= #1 sync_state;	                cnt     <= #1 Tsync;	                cnt_len <= #1 Tlen;	                Sync    <= #1 1'b1;	            end	          sync_state:	            if (cnt_done)	              begin	                  state <= #1 gdel_state;	                  cnt   <= #1 Tgdel;	                  Sync  <= #1 1'b0;	              end	          gdel_state:	            if (cnt_done)	              begin	                  state <= #1 gate_state;	                  cnt   <= #1 Tgate;	                  Gate  <= #1 1'b1;	              end	          gate_state:	            if (cnt_done)	              begin	                  state <= #1 len_state;	                  Gate  <= #1 1'b0;	              end	          len_state:	            if (cnt_len_done)	              begin	                  state   <= #1 sync_state;	                  cnt     <= #1 Tsync;	                  cnt_len <= #1 Tlen;	                  Sync    <= #1 1'b1;	                  Done    <= #1 1'b1;	              end	        endcase	    endendmodule

⌨️ 快捷键说明

复制代码 Ctrl + C
搜索代码 Ctrl + F
全屏模式 F11
切换主题 Ctrl + Shift + D
显示快捷键 ?
增大字号 Ctrl + =
减小字号 Ctrl + -