2020-04-05 13:30:23 +00:00
|
|
|
// 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
|
|
|
|
|
|
|
|
package Pkg;
|
|
|
|
typedef enum { ENUMP_VAL = 33 } enump_t;
|
|
|
|
endpackage
|
|
|
|
|
|
|
|
module t (/*AUTOARG*/);
|
|
|
|
class Cls;
|
|
|
|
int imembera;
|
|
|
|
int imemberb;
|
|
|
|
typedef enum { ENUM_VAL = 22 } enum_t;
|
|
|
|
endclass : Cls
|
|
|
|
|
|
|
|
Cls c;
|
|
|
|
Cls d;
|
|
|
|
|
2020-11-07 00:51:21 +00:00
|
|
|
Cls::enum_t e;
|
|
|
|
|
2020-04-05 13:30:23 +00:00
|
|
|
initial begin
|
|
|
|
// Alternate between two versions to make sure we don't
|
|
|
|
// constant propagate between them.
|
|
|
|
c = new;
|
|
|
|
d = new;
|
2020-11-07 00:51:21 +00:00
|
|
|
e = Cls::ENUM_VAL;
|
2020-04-05 13:30:23 +00:00
|
|
|
c.imembera = 10;
|
|
|
|
d.imembera = 11;
|
|
|
|
c.imemberb = 20;
|
|
|
|
d.imemberb = 21;
|
|
|
|
if (c.imembera != 10) $stop;
|
|
|
|
if (d.imembera != 11) $stop;
|
|
|
|
if (c.imemberb != 20) $stop;
|
|
|
|
if (d.imemberb != 21) $stop;
|
|
|
|
if (Pkg::ENUMP_VAL != 33) $stop;
|
|
|
|
if (Cls::ENUM_VAL != 22) $stop;
|
|
|
|
if (c.ENUM_VAL != 22) $stop;
|
2020-11-07 00:51:21 +00:00
|
|
|
if (e != Cls::ENUM_VAL) $stop;
|
|
|
|
if (e != 22) $stop;
|
2020-04-05 13:30:23 +00:00
|
|
|
$write("*-* All Finished *-*\n");
|
|
|
|
$finish;
|
|
|
|
end
|
|
|
|
endmodule
|