_422_receiver_1.v

来自「多功能卡的源代码」· Verilog 代码 · 共 106 行

V
106
字号
//同步串口接收模块//原作者:刘通//////		module _422_receiver_1(reset,sdin,sys_clock,sclk,r_enable						,dout,wrn						//,bit_counter_2						//,state					);input reset,sdin,sys_clock,sclk,r_enable;output wrn;output [7:0]dout;//output bit_counter_2;//output [1:0]state;//-------------------------------------wire bit_counter_2;reg wrn;reg [7:0]dout;reg [7:0]data;reg [2:0]bit_counter;reg data_receive_begin;reg [1:0]state;wire bit_counter_or;reg bit_counter_or_reg;reg data_receive_begin_reg;///////////////////////////////////////////////////////////assign bit_counter_2=bit_counter[2];//assign dout=data;assign bit_counter_or=|bit_counter;//////////////////////////////////////////////////////////////////////////////////////////////////////////////////////always @(negedge sclk or negedge reset)begin	if (!reset)			data<=8'b0;		else if(r_enable)		data[7:0]<={sdin,data[7:1]};	else 		data<=8'b0;	end/////////////////////////////////////////////////////////always @(negedge sclk or negedge reset)begin	if (!reset)			bit_counter<=3'd0;		else if(r_enable)		bit_counter<=bit_counter+3'd1;	else 		bit_counter<=3'd0;end/////////////////////////////////////////////////////////always @(negedge sclk or negedge reset)begin	if (!reset)			data_receive_begin<=1'b0;		else if(r_enable)		data_receive_begin<=1'b1;	else 		data_receive_begin<=1'b0;end/////////////////////////////////////////////////////////always @(posedge sys_clock)begin	bit_counter_or_reg<=bit_counter_or;	data_receive_begin_reg<=data_receive_begin;endalways @(posedge sys_clock or negedge reset)begin	if(!reset)		begin		dout<=8'd0;		wrn<=1'b0;		state<=2'b00;	end	else if((bit_counter_or_reg==1'b0)&&(data_receive_begin_reg==1'b1))		case(state)			2'b00:				begin					dout<=data;				wrn<=1'b1;				state<=2'b01;			end			2'b01: 				begin					wrn<=1'b0;				state<=2'b11;				end			default:				begin					state<=state;				wrn<=1'b0;			end		endcase	else		begin		dout<=8'd0;//更改了此句话后,写错的数据就变成了00H(原来写错的数为没错之前的一个数)。		wrn<=1'b0;		state<=2'b00;	endend//-------------------------------------------------------////////////////////////////////////////////////////////endmodule 	

⌨️ 快捷键说明

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