Using a generate with for loop in verilog

后端 未结 2 1666
北恋
北恋 2021-01-11 23:31

I\'m trying to understand why we use generate in verilog along with a for loop.

Using a generate and for loop together:

reg [3:0] temp;
genvar i;
gen         


        
2条回答
  •  礼貌的吻别
    2021-01-11 23:43

    In the example without the generate, i should be a genvar not integer. Otherwise, both are valid depending on the version of the IEEE Std 1364 supported by your tool set. The generate construct was added in in IEEE Std 1364-2001 where the generate/endgenerate keywords are explicitly required. In IEEE Std 1364-2005 it became optional with the only requirement that if generate is used it must have a matching endgenerate.

    When using IEEE Std 1364-2005 or SystemVerilog (IEEE Std 1800), it is a matter for coding style preference of implicit vs explicit declaration. Explicit does have the advantage of being backward comparability.


    Generate blocks are useful when change the physical structure of then module via parameters. For example choosing negedge or posedge clock and only enabling one:

    if ( param_use_pos == 1) begin : use_pos
      always @(posedge sysclk) begin
        ...
      end
    end
    else begin : use_neg
      always @(negedge sysclk) begin
         ...
      end
    end
    

    If you are not changing the physical structure, it is typically better to use for loops and if-else statements inside the always block. Both approaches can synthesize the same but when running RTL simulation the non-generate block approach will typically simulate faster. This is because simulators normally can process a single N-bit operation faster than N 1-bit operations. Again synthesis is the same result

    // faster :: 1 always block, simulator can optimize the for loop
    always @(posedge sysclk) begin 
      for (i = 0; i < 3 ; i = i + 1) begin
        temp[i] <= 1'b0;
      end
    end
    
    // slower :: creates 4 always blocks, harder for the simulator to optimize
    genvar i;
    generate // optional if > *-2001
    for (i = 0; i < 3 ; i = i + 1) begin 
        always @(posedge sysclk) begin
            temp[i] <= 1'b0;
        end
    end
    endgenerate // match generate 
    

提交回复
热议问题