aboutsummaryrefslogtreecommitdiffstats
path: root/tests
diff options
context:
space:
mode:
authorEddie Hung <eddie@fpgeh.com>2019-09-13 16:41:10 -0700
committerEddie Hung <eddie@fpgeh.com>2019-09-13 16:41:10 -0700
commita2eee9ebefc6e8089c815b4355bc64d1ac3396b5 (patch)
treed650436aab287e58283f7972c83df5c6504ddeea /tests
parent14d72c39c385bba3005085815a0d66989a437eff (diff)
downloadyosys-a2eee9ebefc6e8089c815b4355bc64d1ac3396b5.tar.gz
yosys-a2eee9ebefc6e8089c815b4355bc64d1ac3396b5.tar.bz2
yosys-a2eee9ebefc6e8089c815b4355bc64d1ac3396b5.zip
Add counter-example from @cliffordwolf
Diffstat (limited to 'tests')
-rw-r--r--tests/various/peepopt.ys24
1 files changed, 24 insertions, 0 deletions
diff --git a/tests/various/peepopt.ys b/tests/various/peepopt.ys
index abee9cc0a..7c1c3b5bc 100644
--- a/tests/various/peepopt.ys
+++ b/tests/various/peepopt.ys
@@ -32,6 +32,30 @@ select -assert-count 0 t:$shr t:$mul %% t:* %D
design -reset
read_verilog <<EOT
+module peepopt_shiftmul_2 (input [11:0] D, input [1:0] S, output [11:0] Y);
+ assign Y = D >> (S*3);
+endmodule
+EOT
+
+prep
+design -save gold
+peepopt
+design -stash gate
+
+design -import gold -as gold peepopt_shiftmul_2
+design -import gate -as gate peepopt_shiftmul_2
+
+miter -equiv -make_assert -make_outputs -ignore_gold_x -flatten gold gate miter
+sat -show-public -enable_undef -prove-asserts miter
+select -assert-count 1 t:$shr
+select -assert-count 1 t:$mul
+select -assert-count 0 t:$shr t:$mul %% t:* %D
+exit
+
+####################
+
+design -reset
+read_verilog <<EOT
module peepopt_muldiv_0(input [1:0] i, output [1:0] o);
wire [3:0] t;
assign t = i * 3;