aboutsummaryrefslogtreecommitdiffstats
path: root/tests/simple
diff options
context:
space:
mode:
authorClifford Wolf <clifford@clifford.at>2016-11-15 13:35:19 +0100
committerClifford Wolf <clifford@clifford.at>2016-11-15 13:35:19 +0100
commit70d7a02cae7ef38eb4f3afcf325979b80e87518e (patch)
tree431ec96bb8b4e8d4749cac8fd2bde537b070f354 /tests/simple
parenta926a6afc2cf6ab7aed2c18950c6cd38d21f2a51 (diff)
downloadyosys-70d7a02cae7ef38eb4f3afcf325979b80e87518e.tar.gz
yosys-70d7a02cae7ef38eb4f3afcf325979b80e87518e.tar.bz2
yosys-70d7a02cae7ef38eb4f3afcf325979b80e87518e.zip
Added support for hierarchical defparams
Diffstat (limited to 'tests/simple')
-rw-r--r--tests/simple/hierdefparam.v23
1 files changed, 23 insertions, 0 deletions
diff --git a/tests/simple/hierdefparam.v b/tests/simple/hierdefparam.v
new file mode 100644
index 000000000..ff92c38bd
--- /dev/null
+++ b/tests/simple/hierdefparam.v
@@ -0,0 +1,23 @@
+module hierdefparam_top(input [7:0] A, output [7:0] Y);
+ generate begin:foo
+ hierdefparam_a mod_a(.A(A), .Y(Y));
+ end endgenerate
+ defparam foo.mod_a.bar[0].mod_b.addvalue = 42;
+ defparam foo.mod_a.bar[1].mod_b.addvalue = 43;
+endmodule
+
+module hierdefparam_a(input [7:0] A, output [7:0] Y);
+ genvar i;
+ generate
+ for (i = 0; i < 2; i=i+1) begin:bar
+ wire [7:0] a, y;
+ hierdefparam_b mod_b(.A(a), .Y(y));
+ end
+ endgenerate
+ assign bar[0].a = A, bar[1].a = bar[0].y, Y = bar[1].y;
+endmodule
+
+module hierdefparam_b(input [7:0] A, output [7:0] Y);
+ parameter [7:0] addvalue = 44;
+ assign Y = A + addvalue;
+endmodule