mirror of https://github.com/zachjs/sv2v.git
31 lines
824 B
Systemverilog
31 lines
824 B
Systemverilog
|
|
// TODO Add support for parameters without default values.
|
||
|
|
module Module #(parameter type T, parameter N = 1);
|
||
|
|
T t;
|
||
|
|
type(t.a) x;
|
||
|
|
type(t.b) y;
|
||
|
|
initial begin
|
||
|
|
$display("$bits(T)=", $bits(T));
|
||
|
|
$display("$bits(t)=", $bits(t));
|
||
|
|
$display("$bits(t.a)=", $bits(t.a));
|
||
|
|
$display("$bits(t.b)=", $bits(t.b));
|
||
|
|
$display("$bits(x)=", $bits(x));
|
||
|
|
$display("$bits(y)=", $bits(y));
|
||
|
|
$display("$bits(N)=", $bits(N));
|
||
|
|
$display("N=", N);
|
||
|
|
end
|
||
|
|
endmodule
|
||
|
|
module top;
|
||
|
|
typedef struct packed {
|
||
|
|
logic a;
|
||
|
|
logic [2] b;
|
||
|
|
} Struct1;
|
||
|
|
typedef struct packed {
|
||
|
|
logic [5] a;
|
||
|
|
Struct1 b;
|
||
|
|
logic [2] c;
|
||
|
|
logic d;
|
||
|
|
} Struct2;
|
||
|
|
Module #(Struct1, $bits(Struct1)) m1();
|
||
|
|
Module #(Struct2, $bits(Struct2)) m2();
|
||
|
|
endmodule
|