// 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