aboutsummaryrefslogtreecommitdiffstats
path: root/tests
diff options
context:
space:
mode:
authorClifford Wolf <clifford@clifford.at>2013-08-12 14:47:50 +0200
committerClifford Wolf <clifford@clifford.at>2013-08-12 14:47:50 +0200
commit759852914df00609f8797315c6cec76f1c8a3981 (patch)
treebac67cdfc87d57a7f3e12e41aad71424d0d29ea9 /tests
parentccf36cb7d81a9513db15b8a36c240d2c7ec9f5b5 (diff)
downloadyosys-759852914df00609f8797315c6cec76f1c8a3981.tar.gz
yosys-759852914df00609f8797315c6cec76f1c8a3981.tar.bz2
yosys-759852914df00609f8797315c6cec76f1c8a3981.zip
Added support for "2**n" shifter encoding
Diffstat (limited to 'tests')
-rw-r--r--tests/simple/operators.v53
1 files changed, 29 insertions, 24 deletions
diff --git a/tests/simple/operators.v b/tests/simple/operators.v
index 6ca6ca7a8..7439101c8 100644
--- a/tests/simple/operators.v
+++ b/tests/simple/operators.v
@@ -86,30 +86,35 @@ always @(posedge clk) begin
58: y <= s1 % u2;
59: y <= s1 % s2;
- 60: y <= +u1;
- 61: y <= -u1;
- 62: y <= ~u1;
- 63: y <= !u1;
-
- 64: y <= +s1;
- 65: y <= -s1;
- 66: y <= ~s1;
- 67: y <= !s1;
-
- 68: y <= { &u1, ~&u1, |u1, ~|u1, ^u1, ~^u1, ^~u1 };
- 69: y <= { &s1, ~&s1, |s1, ~|s1, ^s1, ~^s1, ^~s1 };
- 70: y <= { &u1[1:0], ~&u1[1:0], |u1[1:0], ~|u1[1:0], ^u1[1:0], ~^u1[1:0], ^~u1[1:0] };
- 71: y <= { &s1[1:0], ~&s1[1:0], |s1[1:0], ~|s1[1:0], ^s1[1:0], ~^s1[1:0], ^~s1[1:0] };
-
- 72: y <= { u1[1:0] && u2[1:0], u1[1:0] && u2[1:0], !u1[1:0] };
- 73: y <= {4{u1[1:0]}};
- 74: y <= {u1, u2} ^ {s1, s2};
- 75: y <= {u1, u2} & {s1, s2};
-
- 76: y <= u1[0] ? u1 : u2;
- 77: y <= u1[0] ? u1 : s2;
- 78: y <= u1[0] ? s1 : u2;
- 79: y <= u1[0] ? s1 : s2;
+ 60: y <= 4'd2 ** u1;
+ 61: y <= 4'd2 ** s1;
+ 62: y <= 4'sd2 ** u1;
+ 63: y <= 4'sd2 ** s1;
+
+ 64: y <= +u1;
+ 65: y <= -u1;
+ 66: y <= ~u1;
+ 67: y <= !u1;
+
+ 68: y <= +s1;
+ 69: y <= -s1;
+ 70: y <= ~s1;
+ 71: y <= !s1;
+
+ 72: y <= { &u1, ~&u1, |u1, ~|u1, ^u1, ~^u1, ^~u1 };
+ 73: y <= { &s1, ~&s1, |s1, ~|s1, ^s1, ~^s1, ^~s1 };
+ 74: y <= { &u1[1:0], ~&u1[1:0], |u1[1:0], ~|u1[1:0], ^u1[1:0], ~^u1[1:0], ^~u1[1:0] };
+ 75: y <= { &s1[1:0], ~&s1[1:0], |s1[1:0], ~|s1[1:0], ^s1[1:0], ~^s1[1:0], ^~s1[1:0] };
+
+ 76: y <= { u1[1:0] && u2[1:0], u1[1:0] && u2[1:0], !u1[1:0] };
+ 77: y <= {4{u1[1:0]}};
+ 78: y <= {u1, u2} ^ {s1, s2};
+ 79: y <= {u1, u2} & {s1, s2};
+
+ 80: y <= u1[0] ? u1 : u2;
+ 81: y <= u1[0] ? u1 : s2;
+ 82: y <= u1[0] ? s1 : u2;
+ 83: y <= u1[0] ? s1 : s2;
endcase
end