aboutsummaryrefslogtreecommitdiffstats
path: root/tests/various/fib_tern.v
diff options
context:
space:
mode:
authorwhitequark <whitequark@whitequark.org>2021-02-21 20:56:04 +0000
committerGitHub <noreply@github.com>2021-02-21 20:56:04 +0000
commit01ccb80b708b45926b3690949479715ebf5e2853 (patch)
treeaa2f7cf94cd7b1742568d05d744dc6e21b266306 /tests/various/fib_tern.v
parent3fee43cde0ec424e52ea62f78722b061aaac280a (diff)
parent8de2e863af4233aca0a0ca0eef4477d216f7a227 (diff)
downloadyosys-01ccb80b708b45926b3690949479715ebf5e2853.tar.gz
yosys-01ccb80b708b45926b3690949479715ebf5e2853.tar.bz2
yosys-01ccb80b708b45926b3690949479715ebf5e2853.zip
Merge pull request #2586 from zachjs/tern-recurse
verilog: support recursive functions using ternary expressions
Diffstat (limited to 'tests/various/fib_tern.v')
-rw-r--r--tests/various/fib_tern.v70
1 files changed, 70 insertions, 0 deletions
diff --git a/tests/various/fib_tern.v b/tests/various/fib_tern.v
new file mode 100644
index 000000000..fefde74ce
--- /dev/null
+++ b/tests/various/fib_tern.v
@@ -0,0 +1,70 @@
+module gate(
+ off, fib0, fib1, fib2, fib3, fib4, fib5, fib6, fib7, fib8, fib9
+);
+ input wire signed [31:0] off;
+
+ function automatic blah(
+ input x
+ );
+ blah = x;
+ endfunction
+
+ function automatic integer fib(
+ input integer k
+ );
+ fib = k == 0
+ ? 0
+ : k == 1
+ ? 1
+ : fib(k - 1) + fib(k - 2);
+ endfunction
+
+ function automatic integer fib_wrap(
+ input integer k,
+ output integer o
+ );
+ o = off + fib(k);
+ endfunction
+
+ output integer fib0;
+ output integer fib1;
+ output integer fib2;
+ output integer fib3;
+ output integer fib4;
+ output integer fib5;
+ output integer fib6;
+ output integer fib7;
+ output integer fib8;
+ output integer fib9;
+
+ initial begin : blk
+ integer unused;
+ unused = fib_wrap(0, fib0);
+ unused = fib_wrap(1, fib1);
+ unused = fib_wrap(2, fib2);
+ unused = fib_wrap(3, fib3);
+ unused = fib_wrap(4, fib4);
+ unused = fib_wrap(5, fib5);
+ unused = fib_wrap(6, fib6);
+ unused = fib_wrap(7, fib7);
+ unused = fib_wrap(8, fib8);
+ unused = fib_wrap(9, fib9);
+ end
+endmodule
+
+module gold(
+ off, fib0, fib1, fib2, fib3, fib4, fib5, fib6, fib7, fib8, fib9
+);
+ input wire signed [31:0] off;
+
+ output integer fib0 = off + 0;
+ output integer fib1 = off + 1;
+ output integer fib2 = off + 1;
+ output integer fib3 = off + 2;
+ output integer fib4 = off + 3;
+ output integer fib5 = off + 5;
+ output integer fib6 = off + 8;
+ output integer fib7 = off + 13;
+ output integer fib8 = off + 21;
+ output integer fib9 = off + 34;
+endmodule