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

📄 _422_receiver_1.v.bak

📁 多功能卡的源代码
💻 BAK
字号:
//同步串口接收模块//原作者:刘通//////		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;wire [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 + Shift + D
显示快捷键 ?
增大字号 Ctrl + =
减小字号 Ctrl + -