counter55.v

来自「交通灯控制系统的FPGA设计与实现」· Verilog 代码 · 共 68 行

V
68
字号

module counter55(C_CLK,RST,C_EN,D_OUT1,D_OUT0,C_out);

output C_out;
output [3:0] D_OUT1;
output [3:0] D_OUT0;

input  C_CLK;
input  RST;
input  C_EN;

reg [3:0] D_OUT1;
reg [3:0] D_OUT0;
reg C_out;
reg [3:0] CData1;
reg [3:0] CData0;
reg [7:0] DATA;

always @(posedge C_CLK)
begin
	if(RST==0||C_EN==0)
	  begin 
		C_out <= 1'b0;
		CData1 <= 4'b0000;
		CData0 <= 4'b0000;
	  end
	else
	  begin
	    if(CData0 == 4'b0101 && CData1 == 4'b0101)
		  begin
	    	CData1 <= 4'b0000;
	        CData0 <= 4'b0000;
	        C_out = 1'b1;
	      end		
		else if(CData0 != 4'b1001)
		  begin
			CData0 <= CData0 + 1;
			C_out <= 1'b0;
		  end
		else if(CData0 == 4'b1001 && CData1 != 4'b0110)
		  begin
			CData1 <= CData1 + 1;
			CData0 <= 4'b0000;
			C_out <= 1'b0;
		  end
		else
	      begin
	    	CData1 <= 4'b0000;
	        CData0 <= 4'b0000;
	        C_out = 1'b1;
	      end
	end
end

always
begin
	DATA <= 8'b01010101-((CData1<<4)+CData0);
	if(((DATA>>4)&4'b1111)>4'b0101)
		D_OUT1 <= (DATA>>4)&4'b1111-4'b1111;
	else
		D_OUT1 <= (DATA>>4)&4'b1111;
	if((DATA&4'b1111)>4'b1001)
		D_OUT0 <= (DATA&4'b1111)-4'b0110;
	else
		D_OUT0 <= DATA&4'b1111;
end

endmodule

⌨️ 快捷键说明

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