1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21
module top( input clk, input rst, input [2:0] a, output [1:0] b ); reg [2:0] b_reg; initial begin b_reg <= 3'b0; end assign b = b_reg[1:0]; always @(posedge clk or posedge rst) begin if(rst) begin b_reg <= 3'b0; end else begin b_reg <= a; end end endmodule