Language/Verilog & SV

[Verilog] Blocking(=) vs Nonblocking(<=)

VIR&US 2023. 7. 19. 20:44
반응형

목차


    Blocking assignments (BA)

    always 블록 내에서 실행 순서를 제어하기 위해 사용합니다.

    • 현재 명령문이 실행될 때까지 다음 명령문의 실행을 차단합니다.
    • 앞선 명령문이 실행되고 나서 뒷선 명령문들이 차례대로 실행됩니다.
    assume a = b = 0 initially;
    a = 1; //executed first
    b = a; //executed second
    

     

    a = 1, b = 1
    

    Nonblocking assignments (NBA)

    always 블록 내에서 실행 순서를 제어하기 위해 사용합니다.

    • 모든 문장의 RHS가 먼저 결정된 다음 LHS가 함께 할당됩니다.
    • NBA는 동시 또는 병렬로 명령문을 실행합니다.
    assume a = b = 0 initially;
    a ​<= 1; //executed first
    b <= a; //executed second
    

     

    a = 1, b = 0
    

    Example

    module non_block1;
            reg a, b, c, d, e, f;
            //blocking assignments
    
            initial begin
                   a = #10 1; // a will be 1 at time 10
                   b = #2 0; // b will be 0 at time 12
                   c = #4 1; // c will be 1 at time 16
            end
    
            //non-blocking assignments. Runs concurrently
            initial begin
                   d <= #10 1; // d will be 1 at time 10
                   e <= #2 0; // e will be 0 at time 2
                   f <= #4 1; // f will be 1 at time 4
            end
    
    endmodule
    

    Guideline

    • Sequential logic를 모델링할 때 Nonblocking 할당을 사용하세요.
    • latch를 모델링할 때 Nonblocking 할당을 사용하세요.
    • Combinational logic를 모델링할 때 항상 Blocking 할당을 사용하세요.
    • 동일한 always 블록 내에서 Sequential 및 Combinational logic를 모두 모델링할 때 Nonblocking 할당을 사용하세요.
    • 동일한 always 블록에서 Blocking 및 Nonblocking 할당을 혼합하지 마세요.
    • 두 개 이상의 always 블록에서 동일한 변수에 할당하지 마세요.
    • Nonblocking 할당을 사용하여 할당된 값을 표시하려면 $strobe를 사용하세요.
    • #0 지연을 사용하여 할당하지 마세요. 합성불가능합니다. (non-synthesizable)
    728x90
    반응형