aboutsummaryrefslogtreecommitdiffstats
diff options
context:
space:
mode:
authorEddie Hung <eddie@fpgeh.com>2019-06-06 12:03:44 -0700
committerEddie Hung <eddie@fpgeh.com>2019-06-06 12:03:44 -0700
commitb8620f7b3dde4460e5a8ed3ea7fd7aef54aa7da1 (patch)
treea468b8c444a79f71d3e149aa61495b461f08e107
parent5d4eca5a298d2f98de220cfd0efe5452ab4052d8 (diff)
downloadyosys-b8620f7b3dde4460e5a8ed3ea7fd7aef54aa7da1.tar.gz
yosys-b8620f7b3dde4460e5a8ed3ea7fd7aef54aa7da1.tar.bz2
yosys-b8620f7b3dde4460e5a8ed3ea7fd7aef54aa7da1.zip
One more and tidy up
-rw-r--r--tests/various/muxpack.v18
-rw-r--r--tests/various/muxpack.ys16
2 files changed, 28 insertions, 6 deletions
diff --git a/tests/various/muxpack.v b/tests/various/muxpack.v
index 333908fcb..c2c2537a0 100644
--- a/tests/various/muxpack.v
+++ b/tests/various/muxpack.v
@@ -5,7 +5,6 @@ always @*
else if (s == 2) o <= i[2*W+:W];
else if (s == 3) o <= i[3*W+:W];
else o <= {W{1'bx}};
-
endmodule
module mux_if_unbal_5_3 #(parameter N=5, parameter W=3) (input [N*W-1:0] i, input [$clog2(N)-1:0] s, output reg [W-1:0] o);
@@ -17,7 +16,6 @@ always @* begin
if (s == 3) o <= i[3*W+:W];
if (s == 4) o <= i[4*W+:W];
end
-
endmodule
module mux_if_unbal_5_3_invert #(parameter N=5, parameter W=3) (input [N*W-1:0] i, input [$clog2(N)-1:0] s, output reg [W-1:0] o);
@@ -32,7 +30,6 @@ always @*
else o <= i[2*W+:W];
else o <= i[1*W+:W];
else o <= {W{1'bx}};
-
endmodule
module mux_if_unbal_5_3_width_mismatch #(parameter N=5, parameter W=3) (input [N*W-1:0] i, input [$clog2(N)-1:0] s, output reg [W-1:0] o);
@@ -44,10 +41,9 @@ always @* begin
if (s == 3) o <= i[3*W+:W];
if (s == 4) o <= i[4*W+:W];
end
-
endmodule
-module mux_if_unbal_5_3_missing #(parameter N=5, parameter W=3) (input [N*W-1:0] i, input [$clog2(N)-1:0] s, output reg [W-1:0] o);
+module mux_if_unbal_4_1_missing #(parameter N=5, parameter W=3) (input [N*W-1:0] i, input [$clog2(N)-1:0] s, output reg [W-1:0] o);
always @* begin
if (s == 0) o <= i[0*W+:W];
// else if (s == 1) o <= i[1*W+:W];
@@ -55,5 +51,17 @@ always @* begin
else if (s == 3) o <= i[3*W+:W];
else o <= {W{1'bx}};
end
+endmodule
+module mux_if_unbal_5_3_order #(parameter N=5, parameter W=3) (input [N*W-1:0] i, input [$clog2(N)-1:0] s, output reg [W-1:0] o);
+always @* begin
+ o <= {W{1'bx}};
+ if (s == 3) o <= i[3*W+:W];
+ if (s == 2) o <= i[2*W+:W];
+ if (s == 1) o <= i[1*W+:W];
+ if (s == 4) o <= i[4*W+:W];
+ if (s == 0) o <= i[0*W+:W];
+end
endmodule
+
+
diff --git a/tests/various/muxpack.ys b/tests/various/muxpack.ys
index 174eea74b..a967ddfef 100644
--- a/tests/various/muxpack.ys
+++ b/tests/various/muxpack.ys
@@ -56,7 +56,21 @@ miter -equiv -flatten -make_assert -make_outputs gold gate miter
sat -verify -prove-asserts -show-ports miter
design -load read
-hierarchy -top mux_if_unbal_5_3_missing
+hierarchy -top mux_if_unbal_4_1_missing
+prep
+design -save gold
+muxpack
+opt
+stat
+select -assert-count 1 t:$pmux
+design -stash gate
+design -import gold -as gold
+design -import gate -as gate
+miter -equiv -flatten -make_assert -make_outputs gold gate miter
+sat -verify -prove-asserts -show-ports miter
+
+design -load read
+hierarchy -top mux_if_unbal_5_3_order
prep
design -save gold
muxpack