📄 _422_receiver_1.v.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 + -