Verilog If语句-似乎在条件

时间:2020-04-01 07:13:26

标签: verilog fpga ice40

为什么r_D <= 8'h40根据以下代码和波形在w_Rx_DV == 1'b1之前执行?在R_D变高之前,不应为w_Rx_DV分配任何值。

谢谢您的任何评论

  module main(

  input           i_Clock,
  input           i_Rx_Serial, 
  output          o_PWM
                   );

  reg              r_Load ;         
  reg [7:0]        r_D =0;
  wire             w_Rx_DV;
  wire [7:0]       w_RX_Byte;
  reg [7:0]        r_RX_Byte;        


  PWM PWM(
     .i_Clock(i_Clock),
     .i_Load(r_Load),   
     .i_D (r_D),         
     .o_PWM(o_PWM)   

  );

  rx rx(
     .i_Clock (i_Clock),
     .i_Rx_Serial (i_Rx_Serial),
     .o_Rx_DV (w_Rx_DV),
     .o_Rx_Byte (w_RX_Byte)
   );


always @ (posedge i_Clock)
  begin
    r_Load <= 0;
    if(w_Rx_DV == 1'b1) ;
      begin
        r_RX_Byte <= w_RX_Byte;
          if(r_RX_Byte ==8'h0)
            begin
                r_D <= 0;
                r_Load <= 1;
            end
          if(r_RX_Byte == 8'h3F)        
            begin
                 r_D <= 8'h40;
                 r_Load <= 1;
            end
     else
        begin
        r_Load <= 0;
        end
     end
     end


endmodule

waveform

1 个答案:

答案 0 :(得分:2)

为什么r_D <= 8'h40在w_Rx_DV == 1'b1之前执行

因为此处if后有分号:

if(w_Rx_DV == 1'b1) ;
                 // ^ End of if statement.