2020-06-06 14:06:32 +00:00
|
|
|
// DESCRIPTION: Verilator: Verilog Test module for SystemVerilog 'alias'
|
|
|
|
//
|
|
|
|
// Simple bi-directional alias test.
|
|
|
|
//
|
|
|
|
// This file ONLY is placed under the Creative Commons Public Domain, for
|
|
|
|
// any use, without warranty, 2020 by Wilson Snyder.
|
|
|
|
// SPDX-License-Identifier: CC0-1.0
|
|
|
|
|
|
|
|
typedef class paramed_class_t;
|
|
|
|
typedef class arg_class_t;
|
2022-08-28 14:24:55 +00:00
|
|
|
typedef paramed_class_t#(logic[3:0], 1) paramed_class_logic4_t;
|
2020-06-06 14:06:32 +00:00
|
|
|
|
2020-12-05 16:30:14 +00:00
|
|
|
virtual class vclass #(type CTYPE_t = arg_class_t, int I = 0);
|
2020-06-06 14:06:32 +00:00
|
|
|
pure virtual function void funcname(paramed_class_t #(CTYPE_t) v);
|
|
|
|
endclass
|
|
|
|
|
2022-10-20 01:59:26 +00:00
|
|
|
class paramed_class_t #(type TYPE, int I = 0);
|
2022-08-28 14:24:55 +00:00
|
|
|
TYPE memb;
|
2020-06-06 14:06:32 +00:00
|
|
|
endclass
|
|
|
|
|
|
|
|
class arg_class_t;
|
2022-08-28 14:24:55 +00:00
|
|
|
int ifield;
|
2020-06-06 14:06:32 +00:00
|
|
|
endclass
|
|
|
|
|
|
|
|
module t (/*AUTOARG*/
|
|
|
|
// Inputs
|
|
|
|
clk
|
|
|
|
);
|
|
|
|
input clk;
|
|
|
|
|
2022-08-28 14:24:55 +00:00
|
|
|
vclass vir;
|
|
|
|
paramed_class_t#(arg_class_t) argu;
|
|
|
|
|
|
|
|
initial begin
|
|
|
|
argu = new;
|
|
|
|
argu.memb = new;
|
|
|
|
argu.memb.ifield = 1234;
|
|
|
|
// vir.funcname(argu);
|
|
|
|
if (argu.memb.ifield != 1234) $stop;
|
2020-06-06 14:06:32 +00:00
|
|
|
$write("*-* All Finished *-*\n");
|
|
|
|
$finish;
|
|
|
|
end
|
|
|
|
endmodule
|