forked from github/verilator
78 lines
1.6 KiB
Systemverilog
78 lines
1.6 KiB
Systemverilog
// DESCRIPTION: Verilator: Verilog Test module
|
|
//
|
|
// This file ONLY is placed under the Creative Commons Public Domain, for
|
|
// any use, without warranty, 2022 by Wilson Snyder.
|
|
// SPDX-License-Identifier: CC0-1.0
|
|
|
|
`define checkd(gotv,expv) do if ((gotv) !== (expv)) begin $write("%%Error: %s:%0d: got=%0d exp=%0d\n", `__FILE__,`__LINE__, (gotv), (expv)); $stop; end while(0);
|
|
|
|
module t(/*AUTOARG*/);
|
|
|
|
int a;
|
|
int b;
|
|
int i;
|
|
|
|
initial begin
|
|
a = 10;
|
|
i = (a = 2);
|
|
`checkd(a, 2); `checkd(i, 2);
|
|
|
|
a = 10;
|
|
i = (a += 2);
|
|
`checkd(a, 12); `checkd(i, 12);
|
|
|
|
a = 10;
|
|
i = (a -= 2);
|
|
`checkd(a, 8); `checkd(i, 8);
|
|
|
|
a = 10;
|
|
i = (a *= 2);
|
|
`checkd(a, 20); `checkd(i, 20);
|
|
|
|
a = 10;
|
|
i = (a /= 2);
|
|
`checkd(a, 5); `checkd(i, 5);
|
|
|
|
a = 11;
|
|
i = (a %= 2);
|
|
`checkd(a, 1); `checkd(i, 1);
|
|
|
|
a = 10;
|
|
i = (a &= 2);
|
|
`checkd(a, 2); `checkd(i, 2);
|
|
|
|
a = 8;
|
|
i = (a |= 2);
|
|
`checkd(a, 10); `checkd(i, 10);
|
|
|
|
a = 10;
|
|
i = (a ^= 2);
|
|
`checkd(a, 8); `checkd(i, 8);
|
|
|
|
a = 10;
|
|
i = (a <<= 2);
|
|
`checkd(a, 40); `checkd(i, 40);
|
|
|
|
a = 10;
|
|
i = (a >>= 2);
|
|
`checkd(a, 2); `checkd(i, 2);
|
|
|
|
a = 10;
|
|
i = (a >>>= 2);
|
|
`checkd(a, 2); `checkd(i, 2);
|
|
|
|
a = 10;
|
|
i = (a = (b = 5));
|
|
`checkd(a, 5); `checkd(i, 5); `checkd(b, 5);
|
|
|
|
a = 10;
|
|
b = 6;
|
|
i = ((a += (b += 1) + 1));
|
|
`checkd(a, 18); `checkd(i, 18); `checkd(b, 7);
|
|
|
|
$write("*-* All Finished *-*\n");
|
|
$finish;
|
|
end
|
|
|
|
endmodule
|