Language/Verilog & SV

[Verilog] Parameter

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

목차

    Parameter

    Verilog HDL의 Parameter는 variable이나 net에 속하지 않습니다. 상수입니다.

    Parameter의 두 가지 타입

    • module parameter, witg localparam
    • specify parameters(specparams)

    parameter : 기본적으로 모듈 내에서 상수값을 특정 문자열에 mapping

    defparam : 모듈밖에서 parameter값을 재정의(혹은 override) 할 때 사용

    localparam : 모듈내에서 localparam으로 선언하면 모듈밖에서 바꿀 수 없음

    Specpara : parameter와 비슷하지만 특정 블록 내에서만 사용됩니다.

    Parameter example

    module vdff 
      	#(parameter size = 5, parameter delay = 1) (
            input [0:size-1] in,
            input clk,
            output reg[0:size-1] out);
    
      	always @(posedge clk) begin
            	#delay out = in;
      	end
    
    endmodule
    
    module top;
            reg  		clk;
            wire [0:4] 	out_c, in_c;
            wire [1:10]     out_a, in_a;
            wire [1:5] 	out_b, in_b;
    
            // create an instance and set parameters
      	vdff #(10,15) mod_a (
            	.out(out_a), 
              	.in(in_a), 
              	.clk(clk));
    
            // create an instance leaving default values
            vdff mod_b(
    		.out(out_b),
    		.in(in_b), 
    		.clk(clk));
    
            // create an instance and set one parameter
            vdff #(.delay(12)) mod_c(
    		.out(out_c),
    		.in(in_c), 
    		.clk(clk));
    
    endmodule
    

    localparam

    • parameter와 비슷하지만 local parameter는 module instance parameter 할당으로 수정할 수 없습니다.
    • local parameter는 defparam 문이나 module instance parameter 할당으로 수정할 수 있는 parameter를 포함하는 상수 표현식을 할당할 수 있습니다.

    Local Parameter example

    module generic_fifo
    	//ANSI-C 2001
            #(parameter MSB=3, LSB=0, DEPTH=4) (
            input [MSB:LSB] in,
            input clk, read, write, reset,
            output [MSB:LSB] out,
            output full, empty );
    
     
            // These parameters are local, and cannot be overridden.
            // They can be affected by altering the public parameters
            // above, that is to change indirectly.
            localparam FIFO_MSB = DEPTH*MSB;
            localparam FIFO_LSB = LSB;
            
    	reg [FIFO_MSB:FIFO_LSB] fifo;
            reg [LOG2(DEPTH):0] depth;
    
            always @(posedge clk or reset) begin
                   casex ({read,write,reset})
                   // implementation of fifo
                   // implementation of fifo
                   endcase	
            end
    
    endmodule
    

    Defparam

    • defparam을 사용하면 parameter의 hierarchical name을 사용하여 설계 전반에 걸쳐 모든 module instance에서 parameter의 값을 변경할 수 있습니다.
    • defparam은 parameter 값 할당을 하나의 module로 그룹화 하는데 특히 유용합니다. 그러나 instance 배열 아래 hierarchical 구조의 값은 변경할 수 없습니다.
    • 단일 parameter에 대해 여러 defparam이 있는 경우 마지막 defparam 문의 값을 사용합니다.
    • defparam이 parameter를 수정할 수 있기에 System Verilog compiler는 모든 설계 파일이 compile 되기 전에 instance의 최종 parameter 값을 확인할 수 없습니다. 그래서 defparam의 사용은 System Verilog에서 추천하지 않습니다.

    Definition Parameter example

    module top;
            reg clk;
            reg [0:4] in1;
            reg [0:9] in2;
            wire [0:4] o1;
            wire [0:9] o2;
    
            vdff m1 (
    	.out(o1), 
    	.in(in1), 
    	.clk(clk));
    
            vdff m2 (
    	.out(o2),
    	.in(in2), 
    	.clk(clk));
    
    endmodule
    
     
    
    module vdff 
            #(parameter size = 1, delay = 1) (
            input [0:size-1] in,
            input clk,
            output reg [0:size-1] out);
            
    	always @(posedge clk) begin
                   # delay out = in;
    	end
    
    endmodule
    
     
    module annotate;
            defparam
            top.m1.size = 5,
            top.m1.delay = 10,
            top.m2.size = 10,
            top.m2.delay = 20;
    
    endmodule
    

    Specparam

    • Specparam 은 매개변수와 비슷하지만 특정 블록 내에서만 사용됩니다.
    • 상수 표현식은 정수, 실수, 지연 또는 인용 문자열일 수 있습니다.
    • specparam은 defparam 을 사용하거나 모듈 인스턴스화에서 #을 사용 하여 재정의할 수 없습니다.

    Specparam example

    specparam parameter_name = constant_expression;
    
    [Example]
    specparam TRise = 1.2;
    specparam T1 = 2:3:4; // min:typ:max 
    
    728x90
    반응형