mirror of
https://github.com/verilator/verilator.git
synced 2025-01-14 18:44:02 +00:00
73 lines
1.5 KiB
Systemverilog
73 lines
1.5 KiB
Systemverilog
// DESCRIPTION: Verilator: Verilog Test module
|
|
//
|
|
// 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
|
|
|
|
class Cls;
|
|
typedef enum {A = 10, B = 20, C = 30} en_t;
|
|
|
|
int m_pub = 1;
|
|
local int m_loc = 2;
|
|
protected int m_prot = B;
|
|
task f_pub; endtask
|
|
local task f_loc; endtask
|
|
protected task f_prot; endtask
|
|
static task s_pub; endtask
|
|
static local task s_loc; endtask
|
|
static protected task s_prot; endtask
|
|
task check;
|
|
Cls o;
|
|
if (m_pub != 1) $stop;
|
|
if (m_loc != 2) $stop;
|
|
if (m_prot != 20) $stop;
|
|
f_pub(); // Ok
|
|
f_loc(); // Ok
|
|
f_prot(); // Ok
|
|
s_pub(); // Ok
|
|
s_loc(); // Ok
|
|
s_prot(); // Ok
|
|
Cls::s_pub(); // Ok
|
|
Cls::s_loc(); // Ok
|
|
Cls::s_prot(); // Ok
|
|
endtask
|
|
endclass
|
|
|
|
class Ext extends Cls;
|
|
task check;
|
|
if (m_pub != 1) $stop;
|
|
if (m_prot != 20) $stop;
|
|
f_pub(); // Ok
|
|
f_prot(); // Ok
|
|
s_pub(); // Ok
|
|
s_prot(); // Ok
|
|
Cls::s_pub(); // Ok
|
|
Cls::s_prot(); // Ok
|
|
endtask
|
|
endclass
|
|
|
|
module t (/*AUTOARG*/);
|
|
const Cls mod_c = new;
|
|
|
|
initial begin
|
|
Cls c;
|
|
Ext e;
|
|
if (c.A != 10) $stop;
|
|
c = new;
|
|
e = new;
|
|
if (c.m_pub != 1) $stop;
|
|
//
|
|
if (mod_c.A != 10) $stop;
|
|
//
|
|
c.check();
|
|
e.check();
|
|
//
|
|
Cls::s_pub(); // Ok
|
|
c.s_pub(); // Ok
|
|
e.s_pub(); // Ok
|
|
//
|
|
$write("*-* All Finished *-*\n");
|
|
$finish;
|
|
end
|
|
endmodule
|