diff options
Diffstat (limited to 'src/ortho')
81 files changed, 1353 insertions, 0 deletions
diff --git a/src/ortho/oread/tests/acc.on b/src/ortho/oread/tests/acc.on new file mode 100644 index 000000000..aa6773325 --- /dev/null +++ b/src/ortho/oread/tests/acc.on @@ -0,0 +1,5 @@ +type __ghdl_file_index is unsigned (32); + +type __ghdl_file_index_ptr is access __ghdl_file_index; + +public var acc1 : __ghdl_file_index_ptr; diff --git a/src/ortho/oread/tests/acc2.on b/src/ortho/oread/tests/acc2.on new file mode 100644 index 000000000..faf786282 --- /dev/null +++ b/src/ortho/oread/tests/acc2.on @@ -0,0 +1,15 @@ +type __ghdl_file_index_ptr is access; + +type __ghdl_file_index is unsigned (32); + +type __ghdl_file_index_ptr is access __ghdl_file_index; + +public var acc1 : __ghdl_file_index_ptr; + +public function Get () return __ghdl_file_index +declare +begin + -- return __ghdl_file_index'[0]; + return acc1.all; +end; + diff --git a/src/ortho/oread/tests/acc3.on b/src/ortho/oread/tests/acc3.on new file mode 100644 index 000000000..00cecad68 --- /dev/null +++ b/src/ortho/oread/tests/acc3.on @@ -0,0 +1,18 @@ +type index_ptr1 is access; + +type index is unsigned (32); + +type index_ptr1 is access index; + +type index_ptr2 is access index; + +public var acc1 : index_ptr1; + +public function Get () return index +declare + local var acc2 : index_ptr2; +begin + acc2 := index_ptr2'conv(acc1); + return acc2.all; +end; + diff --git a/src/ortho/oread/tests/align1.on b/src/ortho/oread/tests/align1.on new file mode 100644 index 000000000..f32039cbc --- /dev/null +++ b/src/ortho/oread/tests/align1.on @@ -0,0 +1,9 @@ +-- internal declarations, part 1 + +type __ghdl_size_type is unsigned (32); + +type __ghdl_index_type is unsigned (32); + +public constant align1 : __ghdl_size_type; + +constant align1 := __ghdl_size_type'alignof (__ghdl_index_type); diff --git a/src/ortho/oread/tests/arg1.on b/src/ortho/oread/tests/arg1.on new file mode 100644 index 000000000..d67c15622 --- /dev/null +++ b/src/ortho/oread/tests/arg1.on @@ -0,0 +1,7 @@ +type __ghdl_integer is signed (32); + +public function test_arg (v : __ghdl_integer) return __ghdl_integer +declare +begin + return v; +end; diff --git a/src/ortho/oread/tests/arr1.on b/src/ortho/oread/tests/arr1.on new file mode 100644 index 000000000..49ea69c53 --- /dev/null +++ b/src/ortho/oread/tests/arr1.on @@ -0,0 +1,5 @@ +type __ghdl_index_type is unsigned (32); + +type __ghdl_char is unsigned (8); + +type __ghdl_chararray is array [__ghdl_index_type] of __ghdl_char; diff --git a/src/ortho/oread/tests/arraggr1.on b/src/ortho/oread/tests/arraggr1.on new file mode 100644 index 000000000..1c1313103 --- /dev/null +++ b/src/ortho/oread/tests/arraggr1.on @@ -0,0 +1,12 @@ +type __ghdl_index_type is unsigned (32); + +type __ghdl_char is unsigned (8); + +type __ghdl_chararray is array [__ghdl_index_type] of __ghdl_char; + +private constant _UI00000000 : subarray __ghdl_chararray[__ghdl_index_type'[10] + ]; + +constant _UI00000000 := {__ghdl_char'[110], __ghdl_char'[101], + __ghdl_char'[115], __ghdl_char'[116], __ghdl_char'[49], __ghdl_char'[46], + __ghdl_char'[118], __ghdl_char'[104], __ghdl_char'[100], __ghdl_char'[0]}; diff --git a/src/ortho/oread/tests/asgn_acc.on b/src/ortho/oread/tests/asgn_acc.on new file mode 100644 index 000000000..01559c081 --- /dev/null +++ b/src/ortho/oread/tests/asgn_acc.on @@ -0,0 +1,13 @@ +TYPE int32 IS SIGNED (32); +TYPE int32_acc IS ACCESS int32; +PRIVATE CONSTANT zero_i32 : int32 := 0; + +PRIVATE PROCEDURE call_arg_addr () +DECLARE +BEGIN +DECLARE + LOCAL VAR ap : int32_acc; +BEGIN + ap := int32_acc'address (zero_i32); +END; +END;
\ No newline at end of file diff --git a/src/ortho/oread/tests/bool.on b/src/ortho/oread/tests/bool.on new file mode 100644 index 000000000..c1f3e424d --- /dev/null +++ b/src/ortho/oread/tests/bool.on @@ -0,0 +1 @@ +type __ghdl_bool_type is boolean {false, true}; diff --git a/src/ortho/oread/tests/bug_mcode1.on b/src/ortho/oread/tests/bug_mcode1.on new file mode 100644 index 000000000..bd9737119 --- /dev/null +++ b/src/ortho/oread/tests/bug_mcode1.on @@ -0,0 +1,41 @@ +TYPE __ghdl_index_type IS UNSIGNED (32); + +-- package std.standard + +TYPE std__standard__integer__BT IS SIGNED (32); + +TYPE std__standard__real__BT IS FLOAT; + +-- package declaration math_real + +EXTERNAL FUNCTION ieee__math_real__ceil (x: std__standard__real__BT) + RETURN std__standard__real__BT; + +--F /Users/gingold/devel/vhdl-testsuite/OSVVM_2014_01/src/CoveragePkg.vhd + +TYPE work__coveragepkg__covptype__covbinbasetemptype IS RECORD + action: std__standard__integer__BT; + action2: std__standard__integer__BT; + count: std__standard__integer__BT; + atleast: std__standard__integer__BT; +END RECORD; + +TYPE work__coveragepkg__covptype__covbintemptype__BASE IS ARRAY [ + __ghdl_index_type] OF work__coveragepkg__covptype__covbinbasetemptype; + +TYPE work__coveragepkg__covptype__covbintemptype__ARR IS SUBARRAY + work__coveragepkg__covptype__covbintemptype__BASE[2]; + +PRIVATE FUNCTION work__coveragepkg__covptype__calcweightO1 () + RETURN std__standard__integer__BT +DECLARE + LOCAL VAR RESULT : std__standard__integer__BT; + LOCAL VAR x : std__standard__real__BT; + LOCAL VAR b : work__coveragepkg__covptype__covbintemptype__ARR; + LOCAL VAR T2_8 : __ghdl_index_type; +BEGIN + RESULT := ( (std__standard__integer__BT + 'conv (ieee__math_real__ceil (x)) -# b[T2_8].count)); + RETURN RESULT; +END; + diff --git a/src/ortho/oread/tests/conv.on b/src/ortho/oread/tests/conv.on new file mode 100644 index 000000000..1b07fc5fe --- /dev/null +++ b/src/ortho/oread/tests/conv.on @@ -0,0 +1,40 @@ +TYPE float64 IS FLOAT; +TYPE int32 IS SIGNED (32); +TYPE int64 IS SIGNED (64); + +PUBLIC FUNCTION to_int32 (a : float64) RETURN int32 +DECLARE +BEGIN + RETURN int32'conv(a); +END; + +PUBLIC FUNCTION fp_to_int32 (a : float64) RETURN int64 +DECLARE +BEGIN + RETURN int64'conv(a); +END; + +PUBLIC FUNCTION to_fp64 (a : int32) RETURN float64 +DECLARE +BEGIN + RETURN float64'conv(a); +END; + +PUBLIC FUNCTION conv2 (a : int32) RETURN int32 +DECLARE +BEGIN + RETURN to_int32 (to_fp64 (a)); +END; + +PUBLIC FUNCTION to_int64 (a : int32) RETURN int64 +DECLARE +BEGIN + RETURN int64'conv(a); +END; + +-- Test spill +PUBLIC FUNCTION spill1 (a : int32) RETURN int64 +DECLARE +BEGIN + RETURN int64'conv(a) +# to_int64 (a); +END; diff --git a/src/ortho/oread/tests/enum1.on b/src/ortho/oread/tests/enum1.on new file mode 100644 index 000000000..87dc75cab --- /dev/null +++ b/src/ortho/oread/tests/enum1.on @@ -0,0 +1,4 @@ +type __ghdl_compare_type is enum {lt = 0, eq = 1, gt = 2}; + +public constant en1 : __ghdl_compare_type; +constant en1 := __ghdl_compare_type'[eq];
\ No newline at end of file diff --git a/src/ortho/oread/tests/fabs.on b/src/ortho/oread/tests/fabs.on new file mode 100644 index 000000000..90f19a36f --- /dev/null +++ b/src/ortho/oread/tests/fabs.on @@ -0,0 +1,38 @@ +TYPE float64 IS FLOAT; + +PUBLIC FUNCTION fadd (a : float64; b : float64) RETURN float64 +DECLARE +BEGIN + RETURN a +# b; +END; + +PUBLIC FUNCTION fsub (a : float64; b : float64) RETURN float64 +DECLARE +BEGIN + RETURN a -# b; +END; + +PUBLIC FUNCTION fmul (a : float64; b : float64) RETURN float64 +DECLARE +BEGIN + RETURN a *# b; +END; + +PUBLIC FUNCTION fdiv (a : float64; b : float64) RETURN float64 +DECLARE +BEGIN + RETURN a /# b; +END; + +PUBLIC FUNCTION fneg (a : float64) RETURN float64 +DECLARE +BEGIN + RETURN -a; +END; + +PUBLIC FUNCTION fabs (a : float64) RETURN float64 +DECLARE +BEGIN + RETURN ABS a; +END; + diff --git a/src/ortho/oread/tests/fdiv.on b/src/ortho/oread/tests/fdiv.on new file mode 100644 index 000000000..197316e65 --- /dev/null +++ b/src/ortho/oread/tests/fdiv.on @@ -0,0 +1,17 @@ +TYPE float64 IS FLOAT; +TYPE int32 IS SIGNED (32); +TYPE int64 IS SIGNED (64); + +PUBLIC FUNCTION fdiv (a : int64; b : int64) RETURN float64 +DECLARE +BEGIN + RETURN float64'conv(a) /# float64'conv (b); +END; + +TYPE char IS UNSIGNED(8); + +PUBLIC FUNCTION add (a : char; b : char) RETURN int32 +DECLARE +BEGIN + RETURN int32'conv(a) +# int32'conv(b); +END; diff --git a/src/ortho/oread/tests/fops.on b/src/ortho/oread/tests/fops.on new file mode 100644 index 000000000..74cd6f2aa --- /dev/null +++ b/src/ortho/oread/tests/fops.on @@ -0,0 +1,104 @@ +TYPE float64 IS FLOAT; +TYPE bool IS BOOLEAN {false, true}; +TYPE int32 IS SIGNED (32); + +PUBLIC FUNCTION fadd (a : float64; b : float64) RETURN float64 +DECLARE +BEGIN + RETURN a +# b; +END; + +PUBLIC FUNCTION fsub (a : float64; b : float64) RETURN float64 +DECLARE +BEGIN + RETURN a -# b; +END; + +PUBLIC FUNCTION fmul (a : float64; b : float64) RETURN float64 +DECLARE +BEGIN + RETURN a *# b; +END; + +PUBLIC FUNCTION fdiv (a : float64; b : float64) RETURN float64 +DECLARE +BEGIN + RETURN a /# b; +END; + +PUBLIC FUNCTION fneg (a : float64) RETURN float64 +DECLARE +BEGIN + RETURN -a; +END; + +PUBLIC FUNCTION fabs (a : float64) RETURN float64 +DECLARE +BEGIN + RETURN ABS a; +END; + +PUBLIC FUNCTION fcall1 (a : float64; b : float64) RETURN float64 +DECLARE +BEGIN + RETURN fadd (fmul (a, b), fneg (b)); +END; + +PUBLIC FUNCTION fgt (a : float64; b : float64) RETURN bool +DECLARE +BEGIN + RETURN bool'(a >= b); +END; + +PUBLIC FUNCTION mainint () RETURN int32 +DECLARE + LOCAL VAR l : int32; + LOCAL VAR r : int32; +BEGIN + l:= 1; + r := 2; + IF bool'(l < r) THEN + RETURN int32'(0); + ELSE + RETURN int32'(1); + END IF; +END; + +PRIVATE CONSTANT fone : float64; +CONSTANT fone := 1.0; + +-- Return 0 in case of error. +PUBLIC FUNCTION main () RETURN int32 +DECLARE + LOCAL VAR lf : float64; + LOCAL VAR rf : float64; +BEGIN + lf := 1.0; + rf := 2.0; + IF bool'(lf >= rf) THEN + RETURN int32'(0); + END IF; + lf := fadd (lf, fone); + IF bool'(lf /= rf) THEN + RETURN int32'(0); + END IF; + + lf := fone; + lf := -lf; + IF bool'(lf > 0.0) THEN + RETURN int32'(0); + END IF; + + lf := ABS lf; + IF bool'(lf /= fone) THEN + RETURN int32'(0); + END IF; + + lf := 2.0; + IF bool'(fdiv (lf, fone) /= lf) THEN + RETURN int32'(0); + END IF; + + RETURN int32'(1); +END; + diff --git a/src/ortho/oread/tests/fp_add.on b/src/ortho/oread/tests/fp_add.on new file mode 100644 index 000000000..949f370de --- /dev/null +++ b/src/ortho/oread/tests/fp_add.on @@ -0,0 +1,13 @@ +TYPE float IS FLOAT; + +PRIVATE FUNCTION add_float (a : float; b : float) RETURN float +DECLARE +BEGIN + RETURN a +# b; +END; + +PRIVATE FUNCTION add3_float (a : float; b : float; c : float) RETURN float +DECLARE +BEGIN + RETURN add_float (a, add_float (b, c)); +END; diff --git a/src/ortho/oread/tests/if1.on b/src/ortho/oread/tests/if1.on new file mode 100644 index 000000000..16d9b9835 --- /dev/null +++ b/src/ortho/oread/tests/if1.on @@ -0,0 +1,12 @@ +type __ghdl_bool_type is boolean {false, true}; +type __ghdl_integer is signed (32); + +public function test_arg (v : __ghdl_bool_type) return __ghdl_integer +declare +begin + if v then + return __ghdl_integer'[1]; + else + return __ghdl_integer'[0]; + end if; +end; diff --git a/src/ortho/oread/tests/if2.on b/src/ortho/oread/tests/if2.on new file mode 100644 index 000000000..0c38be4b6 --- /dev/null +++ b/src/ortho/oread/tests/if2.on @@ -0,0 +1,11 @@ +type __ghdl_bool_type is boolean {false, true}; +type __ghdl_integer is signed (32); + +public function test_arg (v : __ghdl_bool_type) return __ghdl_integer +declare +begin + if v then + return __ghdl_integer'[1]; + end if; + return __ghdl_integer'[0]; +end; diff --git a/src/ortho/oread/tests/if3.on b/src/ortho/oread/tests/if3.on new file mode 100644 index 000000000..95e5149a1 --- /dev/null +++ b/src/ortho/oread/tests/if3.on @@ -0,0 +1,18 @@ +type __ghdl_bool_type is boolean {false, true}; +type __ghdl_integer is signed (32); + +public function test_arg (v : __ghdl_bool_type) return __ghdl_integer +declare + local var r : __ghdl_integer; +begin + r := __ghdl_integer'[0]; + if v then + declare + local var w : __ghdl_integer; + begin + w := __ghdl_integer'[1]; + r := w; + end; + end if; + return r; +end; diff --git a/src/ortho/oread/tests/if4.on b/src/ortho/oread/tests/if4.on new file mode 100644 index 000000000..33857165e --- /dev/null +++ b/src/ortho/oread/tests/if4.on @@ -0,0 +1,39 @@ +type __ghdl_bool_type is boolean {false, true}; +type __ghdl_integer is signed (32); + +public function test_arg (b1 : __ghdl_bool_type; + b2 : __ghdl_bool_type; + b3 : __ghdl_bool_type) return __ghdl_integer +declare + local var r : __ghdl_integer; +begin + r := __ghdl_integer'[0]; + if b1 then + if b2 then + declare + local var w : __ghdl_integer; + begin + w := __ghdl_integer'[1]; + r := w; + end; + else + if b3 then + declare + local var w : __ghdl_integer; + begin + w := __ghdl_integer'[2]; + r := w; + end; + else + end if; + end if; + else + declare + local var w : __ghdl_integer; + begin + w := __ghdl_integer'[3]; + r := w; + end; + end if; + return r; +end; diff --git a/src/ortho/oread/tests/local1.on b/src/ortho/oread/tests/local1.on new file mode 100644 index 000000000..1c985a2a5 --- /dev/null +++ b/src/ortho/oread/tests/local1.on @@ -0,0 +1,9 @@ +type __ghdl_integer is signed (32); + +public function test_arg (v : __ghdl_integer) return __ghdl_integer +declare + local var w : __ghdl_integer; +begin + w := v; + return w; +end; diff --git a/src/ortho/oread/tests/local2.on b/src/ortho/oread/tests/local2.on new file mode 100644 index 000000000..e06cdb8ea --- /dev/null +++ b/src/ortho/oread/tests/local2.on @@ -0,0 +1,15 @@ +type __ghdl_integer is signed (32); + +public function test_arg (v : __ghdl_integer) return __ghdl_integer +declare + local var w : __ghdl_integer; +begin + w := v; + declare + local var z : __ghdl_integer; + begin + z := v +# w; + w := z; + end; + return w; +end; diff --git a/src/ortho/oread/tests/local3.on b/src/ortho/oread/tests/local3.on new file mode 100644 index 000000000..034bd1846 --- /dev/null +++ b/src/ortho/oread/tests/local3.on @@ -0,0 +1,33 @@ +type __ghdl_integer is signed (32); + +public function test_arg (v : __ghdl_integer) return __ghdl_integer +declare + local var w : __ghdl_integer; +begin + w := v; + declare + local var b1 : __ghdl_integer; + begin + b1 := w; + w := b1; + declare + local var b2 : __ghdl_integer; + begin + b2 := w; + w := b2; + end; + declare + local var b3 : __ghdl_integer; + begin + b3 := w; + w := b3; + end; + end; + declare + local var b4 : __ghdl_integer; + begin + b4 := w; + w := b4; + end; + return w; +end; diff --git a/src/ortho/oread/tests/ra1.on b/src/ortho/oread/tests/ra1.on new file mode 100644 index 000000000..0f5300e66 --- /dev/null +++ b/src/ortho/oread/tests/ra1.on @@ -0,0 +1,8 @@ +TYPE int32 IS SIGNED (32); +TYPE char IS UNSIGNED(8); + +PUBLIC FUNCTION add (a : char; b : char) RETURN int32 +DECLARE +BEGIN + RETURN int32'conv(a) +# int32'conv(b); +END; diff --git a/src/ortho/oread/tests/ra2.on b/src/ortho/oread/tests/ra2.on new file mode 100644 index 000000000..57c6a631a --- /dev/null +++ b/src/ortho/oread/tests/ra2.on @@ -0,0 +1,16 @@ +TYPE float64 IS FLOAT; +TYPE int32 IS SIGNED (32); +TYPE int64 IS SIGNED (64); + +PUBLIC FUNCTION to_int64 (a : int32) RETURN int64 +DECLARE +BEGIN + RETURN int64'conv(a); +END; + +-- Test spill +PUBLIC FUNCTION spill1 (a : int32) RETURN int64 +DECLARE +BEGIN + RETURN int64'conv(a) +# to_int64 (a); +END; diff --git a/src/ortho/oread/tests/ra3.on b/src/ortho/oread/tests/ra3.on new file mode 100644 index 000000000..e135bc83a --- /dev/null +++ b/src/ortho/oread/tests/ra3.on @@ -0,0 +1,9 @@ +TYPE float64 IS FLOAT; +TYPE int32 IS SIGNED (32); +TYPE int64 IS SIGNED (64); + +PUBLIC FUNCTION div (a : int32; b : int32) RETURN float64 +DECLARE +BEGIN + RETURN float64'conv (a /# int32'(1)) /# float64'conv (b /# int32'(1)); +END; diff --git a/src/ortho/oread/tests/repro1.on b/src/ortho/oread/tests/repro1.on new file mode 100644 index 000000000..a26bd387f --- /dev/null +++ b/src/ortho/oread/tests/repro1.on @@ -0,0 +1,21 @@ +TYPE int32 IS SIGNED (32); +TYPE uns32 IS UNSIGNED (32); +TYPE char8 IS UNSIGNED (8); + +TYPE string8 IS ARRAY [uns32] OF char8; +TYPE string_acc IS ACCESS string8; + +TYPE bool IS BOOLEAN {false, true}; + +PRIVATE PROCEDURE puts (s : string_acc); + +PRIVATE PROCEDURE puti32 (n : int32) +DECLARE + TYPE str8x11 IS SUBARRAY string8[11]; + LOCAL VAR s : str8x11; + LOCAL VAR i : uns32; +BEGIN + i := 9; + s[10] := 0; + puts(string_acc'address(s[i...])); +END; diff --git a/src/ortho/oread/tests/ret1.on b/src/ortho/oread/tests/ret1.on new file mode 100644 index 000000000..02137048c --- /dev/null +++ b/src/ortho/oread/tests/ret1.on @@ -0,0 +1,7 @@ +type __ghdl_integer is signed (32); + +public function test_assign () return __ghdl_integer +declare +begin + return __ghdl_integer'[5]; +end; diff --git a/src/ortho/oread/tests/ret2.on b/src/ortho/oread/tests/ret2.on new file mode 100644 index 000000000..5850b5537 --- /dev/null +++ b/src/ortho/oread/tests/ret2.on @@ -0,0 +1,7 @@ +type __ghdl_index_type is unsigned (32); + +public procedure test_ret () +declare +begin + return; +end; diff --git a/src/ortho/oread/tests/ret3.on b/src/ortho/oread/tests/ret3.on new file mode 100644 index 000000000..1a415b086 --- /dev/null +++ b/src/ortho/oread/tests/ret3.on @@ -0,0 +1,8 @@ +type __ghdl_index_type is unsigned (32); + +public procedure test_ret () +declare +begin + return; + return; +end; diff --git a/src/ortho/oread/tests/ret4.on b/src/ortho/oread/tests/ret4.on new file mode 100644 index 000000000..267511479 --- /dev/null +++ b/src/ortho/oread/tests/ret4.on @@ -0,0 +1,8 @@ +type __ghdl_integer is signed (32); + +public function test_assign () return __ghdl_integer +declare +begin + return __ghdl_integer'[5]; + return __ghdl_integer'[4]; +end; diff --git a/src/ortho/oread/tests/run_case1.on b/src/ortho/oread/tests/run_case1.on new file mode 100644 index 000000000..d457e59ba --- /dev/null +++ b/src/ortho/oread/tests/run_case1.on @@ -0,0 +1,13 @@ +type __ghdl_index_type is unsigned (32); +type __ghdl_bool_type is boolean {false, true}; + +public function main (a : __ghdl_index_type) return __ghdl_index_type +declare +begin + case a is + when 1 => + return 2; + when default => + return 0; + end case; +end; diff --git a/src/ortho/oread/tests/run_case2.on b/src/ortho/oread/tests/run_case2.on new file mode 100644 index 000000000..6707f4f96 --- /dev/null +++ b/src/ortho/oread/tests/run_case2.on @@ -0,0 +1,15 @@ +type __ghdl_index_type is unsigned (32); +type __ghdl_bool_type is boolean {false, true}; + +public function main (a : __ghdl_index_type) return __ghdl_index_type +declare +begin + case a is + when 1 => + return 2; + when 3 ... 5 => + return 1; + when default => + return 0; + end case; +end; diff --git a/src/ortho/oread/tests/run_case3.on b/src/ortho/oread/tests/run_case3.on new file mode 100644 index 000000000..ff5d5beee --- /dev/null +++ b/src/ortho/oread/tests/run_case3.on @@ -0,0 +1,15 @@ +type __ghdl_index_type is unsigned (32); +type __ghdl_bool_type is boolean {false, true}; + +public function main (a : __ghdl_index_type) return __ghdl_index_type +declare +begin + case a is + when 1, 2, 7 => + return 2; + when 3 ... 5 => + return 1; + when default => + return 0; + end case; +end; diff --git a/src/ortho/oread/tests/run_case4.on b/src/ortho/oread/tests/run_case4.on new file mode 100644 index 000000000..ea19b62a5 --- /dev/null +++ b/src/ortho/oread/tests/run_case4.on @@ -0,0 +1,15 @@ +type __ghdl_index_type is unsigned (32); +type __ghdl_bool_type is boolean {false, true}; + +public function main (a : __ghdl_index_type) return __ghdl_index_type +declare +begin + case a is + when 1, 2, 7 => + when 3 ... 5 => + return 1; + when default => + return 0; + end case; + return 4; +end; diff --git a/src/ortho/oread/tests/run_case5.on b/src/ortho/oread/tests/run_case5.on new file mode 100644 index 000000000..6391bb315 --- /dev/null +++ b/src/ortho/oread/tests/run_case5.on @@ -0,0 +1,13 @@ +type __ghdl_index_type is unsigned (32); +type __ghdl_bool_type is boolean {false, true}; + +public function main (a : __ghdl_index_type) return __ghdl_index_type +declare +begin + case __ghdl_bool_type'(a > 10) is + when __ghdl_bool_type'[true] => + when __ghdl_bool_type'[false] => + return 1; + end case; + return 4; +end; diff --git a/src/ortho/oread/tests/run_case6.on b/src/ortho/oread/tests/run_case6.on new file mode 100644 index 000000000..3e33ff6f4 --- /dev/null +++ b/src/ortho/oread/tests/run_case6.on @@ -0,0 +1,19 @@ +type __ghdl_index_type is unsigned (32); +type __ghdl_bool_type is boolean {false, true}; + +public function main (a : __ghdl_index_type) return __ghdl_index_type +declare + local var b : __ghdl_index_type; +begin + case a is + when 10 ... 15 => + case __ghdl_bool_type'(a > 10) is + when __ghdl_bool_type'[true] => + b := 5; + when __ghdl_bool_type'[false] => + end case; + when default => + return 4; + end case; + return 5; +end; diff --git a/src/ortho/oread/tests/run_case7.on b/src/ortho/oread/tests/run_case7.on new file mode 100644 index 000000000..708029c22 --- /dev/null +++ b/src/ortho/oread/tests/run_case7.on @@ -0,0 +1,14 @@ +type __ghdl_index_type is unsigned (32); +type __ghdl_bool_type is boolean {false, true}; + +public function main (a : __ghdl_index_type) return __ghdl_index_type +declare + local var b : __ghdl_index_type; +begin + case __ghdl_bool_type'(a > 10) is + when __ghdl_bool_type'[true] => + b := 5; + when __ghdl_bool_type'[false] => + end case; + return 5; +end; diff --git a/src/ortho/oread/tests/run_declare.on b/src/ortho/oread/tests/run_declare.on new file mode 100644 index 000000000..b0af18c9f --- /dev/null +++ b/src/ortho/oread/tests/run_declare.on @@ -0,0 +1,16 @@ +type __ghdl_int is unsigned (32); + +public function main (a : __ghdl_int) return __ghdl_int +declare + local var b : __ghdl_int; + local var z : __ghdl_int; +begin + b := a; + declare + local var c : __ghdl_int; + begin + c := b; + z := c; + end; + return z +# 1; +end; diff --git a/src/ortho/oread/tests/run_declare2.on b/src/ortho/oread/tests/run_declare2.on new file mode 100644 index 000000000..ae38b660d --- /dev/null +++ b/src/ortho/oread/tests/run_declare2.on @@ -0,0 +1,21 @@ +type __ghdl_int is unsigned (32); + +public function main (a : __ghdl_int) return __ghdl_int +declare + local var b : __ghdl_int; + local var z : __ghdl_int; +begin + b := a; + declare + local var c : __ghdl_int; + begin + c := b; + end; + declare + local var d : __ghdl_int; + begin + d := b; + z := d; + end; + return z +# 1; +end; diff --git a/src/ortho/oread/tests/run_declare3.c b/src/ortho/oread/tests/run_declare3.c new file mode 100644 index 000000000..cccfdb7cb --- /dev/null +++ b/src/ortho/oread/tests/run_declare3.c @@ -0,0 +1,17 @@ +int main1 (int a) +{ + int b; + int z; + + b = a; + + { + int g; + int c; + + c = b; + g = c; + z = g + c; + } + return z + 1; +} diff --git a/src/ortho/oread/tests/run_declare3.on b/src/ortho/oread/tests/run_declare3.on new file mode 100644 index 000000000..85684a249 --- /dev/null +++ b/src/ortho/oread/tests/run_declare3.on @@ -0,0 +1,18 @@ +type __ghdl_int is unsigned (32); + +public function main (a : __ghdl_int) return __ghdl_int +declare + local var b : __ghdl_int; + local var z : __ghdl_int; +begin + b := a; + declare + local var g : __ghdl_int; + local var c : __ghdl_int; + begin + c := b; + g := c; + z := g +# c; + end; + return z +# 1; +end; diff --git a/src/ortho/oread/tests/run_func1.on b/src/ortho/oread/tests/run_func1.on new file mode 100644 index 000000000..d0ea4e876 --- /dev/null +++ b/src/ortho/oread/tests/run_func1.on @@ -0,0 +1,16 @@ +TYPE __ghdl_index_type IS UNSIGNED (32); + +PUBLIC FUNCTION inc (a : __ghdl_index_type) RETURN __ghdl_index_type; + +PUBLIC FUNCTION inc (a : __ghdl_index_type) RETURN __ghdl_index_type +DECLARE +BEGIN + RETURN a +# 1; +END; + +PUBLIC FUNCTION main (a : __ghdl_index_type) RETURN __ghdl_index_type +DECLARE +BEGIN + RETURN inc (a); +END; + diff --git a/src/ortho/oread/tests/run_gvar.on b/src/ortho/oread/tests/run_gvar.on new file mode 100644 index 000000000..4efa46bca --- /dev/null +++ b/src/ortho/oread/tests/run_gvar.on @@ -0,0 +1,10 @@ +TYPE __ghdl_index_type IS UNSIGNED (32); + +PUBLIC VAR v : __ghdl_index_type; + +PUBLIC FUNCTION main (a : __ghdl_index_type) RETURN __ghdl_index_type +DECLARE +BEGIN + v := a; + RETURN v +# 1; +END; diff --git a/src/ortho/oread/tests/run_id.on b/src/ortho/oread/tests/run_id.on new file mode 100644 index 000000000..81581bf3a --- /dev/null +++ b/src/ortho/oread/tests/run_id.on @@ -0,0 +1,7 @@ +TYPE __ghdl_index_type IS UNSIGNED (32); + +PUBLIC FUNCTION main (a : __ghdl_index_type) RETURN __ghdl_index_type +DECLARE +BEGIN + RETURN a; +END; diff --git a/src/ortho/oread/tests/run_idx.on b/src/ortho/oread/tests/run_idx.on new file mode 100644 index 000000000..9e12acbd7 --- /dev/null +++ b/src/ortho/oread/tests/run_idx.on @@ -0,0 +1,17 @@ +type __ghdl_index_type is unsigned (32); +type __ghdl_bool_type is boolean {false, true}; + +type __ghdl_char is unsigned (8); + +type __ghdl_chararray is array [__ghdl_index_type] of __ghdl_index_type; + +private constant TAB : subarray __ghdl_chararray[__ghdl_index_type'[10] + ]; + +constant TAB := {65, 66, 67, 68, 69, 48, 49, 50, 51, 52 }; + +public function main (a : __ghdl_index_type) return __ghdl_index_type +declare +begin + return TAB[a]; +end; diff --git a/src/ortho/oread/tests/run_if.on b/src/ortho/oread/tests/run_if.on new file mode 100644 index 000000000..d9ea8484a --- /dev/null +++ b/src/ortho/oread/tests/run_if.on @@ -0,0 +1,12 @@ +type __ghdl_index_type is unsigned (32); +type __ghdl_bool_type is boolean {false, true}; + +public function main (a : __ghdl_index_type) return __ghdl_index_type +declare +begin + if __ghdl_bool_type'(a > 5) then + return a +# 1; + else + return a -# 1; + end if; +end; diff --git a/src/ortho/oread/tests/run_neg.on b/src/ortho/oread/tests/run_neg.on new file mode 100644 index 000000000..d7ec2dcc0 --- /dev/null +++ b/src/ortho/oread/tests/run_neg.on @@ -0,0 +1,7 @@ +type __ghdl_index_type is signed (32); + +public function main (a : __ghdl_index_type) return __ghdl_index_type +declare +begin + return -a; +end; diff --git a/src/ortho/oread/tests/run_not.on b/src/ortho/oread/tests/run_not.on new file mode 100644 index 000000000..61480c362 --- /dev/null +++ b/src/ortho/oread/tests/run_not.on @@ -0,0 +1,7 @@ +TYPE __ghdl_index_type IS UNSIGNED (32); + +PUBLIC FUNCTION main (a : __ghdl_index_type) RETURN __ghdl_index_type +DECLARE +BEGIN + RETURN NOT a; +END; diff --git a/src/ortho/oread/tests/run_plus.on b/src/ortho/oread/tests/run_plus.on new file mode 100644 index 000000000..0465df200 --- /dev/null +++ b/src/ortho/oread/tests/run_plus.on @@ -0,0 +1,7 @@ +TYPE __ghdl_index_type IS UNSIGNED (32); + +PUBLIC FUNCTION main (a : __ghdl_index_type) RETURN __ghdl_index_type +DECLARE +BEGIN + RETURN a +# 1; +END; diff --git a/src/ortho/oread/tests/run_plus64.on b/src/ortho/oread/tests/run_plus64.on new file mode 100644 index 000000000..beea5a932 --- /dev/null +++ b/src/ortho/oread/tests/run_plus64.on @@ -0,0 +1,7 @@ +TYPE __ghdl_index_type IS UNSIGNED (64); + +PUBLIC FUNCTION main (a : __ghdl_index_type) RETURN __ghdl_index_type +DECLARE +BEGIN + RETURN a +# 1; +END; diff --git a/src/ortho/oread/tests/size1.on b/src/ortho/oread/tests/size1.on new file mode 100644 index 000000000..8ac5aeca1 --- /dev/null +++ b/src/ortho/oread/tests/size1.on @@ -0,0 +1,9 @@ +-- internal declarations, part 1 + +type __ghdl_size_type is unsigned (32); + +type __ghdl_index_type is unsigned (32); + +public constant size1 : __ghdl_size_type; + +constant size1 := __ghdl_size_type'sizeof (__ghdl_index_type); diff --git a/src/ortho/oread/tests/smod.on b/src/ortho/oread/tests/smod.on new file mode 100644 index 000000000..152f69c73 --- /dev/null +++ b/src/ortho/oread/tests/smod.on @@ -0,0 +1,32 @@ +type int is signed (32); + +public function smod (a : int; b : int) return int +declare +begin + return a mod# b; +end; + +public function do_m3_m3 () return int +declare +begin + return -3 mod# -3; +end; + +public function do_m3_m2 () return int +declare +begin + return -3 mod# -2; +end; + +public function do_11_5 () return int +declare +begin + return 11 mod# 5; +end; + +public function do_m11_5 () return int +declare +begin + return -11 mod# 5; +end; + diff --git a/src/ortho/oread/tests/struct1.on b/src/ortho/oread/tests/struct1.on new file mode 100644 index 000000000..f6a0ad86b --- /dev/null +++ b/src/ortho/oread/tests/struct1.on @@ -0,0 +1,16 @@ +TYPE __ghdl_index_type IS UNSIGNED (32); + +TYPE __ghdl_char IS UNSIGNED (8); + +TYPE __ghdl_chararray IS ARRAY [__ghdl_index_type] OF __ghdl_char; + +TYPE __ghdl_char_ptr IS ACCESS __ghdl_chararray; + +TYPE __ghdl_char_ptr_array IS ARRAY [__ghdl_index_type] OF __ghdl_char_ptr; + +TYPE __ghdl_str_len IS RECORD + len: __ghdl_index_type; + str: __ghdl_char_ptr; +END RECORD; + +PUBLIC VAR var1 : __ghdl_str_len; diff --git a/src/ortho/oread/tests/struct2.on b/src/ortho/oread/tests/struct2.on new file mode 100644 index 000000000..70200cd12 --- /dev/null +++ b/src/ortho/oread/tests/struct2.on @@ -0,0 +1,25 @@ +type __ghdl_rti_u8 is unsigned (8); + +type __ghdl_rti_common is record + mode: __ghdl_rti_u8; +end record; + +type __ghdl_rti_access is access __ghdl_rti_common; + +type __ghdl_component_link_type is record; + +type __ghdl_component_link_acc is access __ghdl_component_link_type; + +type __ghdl_entity_link_type is record + rti: __ghdl_rti_access; + parent: __ghdl_component_link_acc; +end record; + +type __ghdl_entity_link_acc is access __ghdl_entity_link_type; + +type __ghdl_component_link_type is record + stmt: __ghdl_rti_access; +end record; + +public var var1 : __ghdl_component_link_type; +public var var2 : __ghdl_component_link_acc; diff --git a/src/ortho/oread/tests/struct3.on b/src/ortho/oread/tests/struct3.on new file mode 100644 index 000000000..b4dc6586d --- /dev/null +++ b/src/ortho/oread/tests/struct3.on @@ -0,0 +1,41 @@ +type __ghdl_rtik is enum {__ghdl_rtik_top = 0, __ghdl_rtik_library = 1, + __ghdl_rtik_package = 2, __ghdl_rtik_package_body = 3, + __ghdl_rtik_entity = 4, __ghdl_rtik_architecture = 5, + __ghdl_rtik_process = 6, __ghdl_rtik_block = 7, + __ghdl_rtik_if_generate = 8, __ghdl_rtik_for_generate = 9, + __ghdl_rtik_instance = 10, __ghdl_rtik_constant = 11, + __ghdl_rtik_iterator = 12, __ghdl_rtik_variable = 13, + __ghdl_rtik_signal = 14, __ghdl_rtik_file = 15, __ghdl_rtik_port = 16, + __ghdl_rtik_generic = 17, __ghdl_rtik_alias = 18, __ghdl_rtik_guard = 19, + __ghdl_rtik_component = 20, __ghdl_rtik_attribute = 21, + __ghdl_rtik_type_b2 = 22, __ghdl_rtik_type_e8 = 23, + __ghdl_rtik_type_e32 = 24, __ghdl_rtik_type_i32 = 25, + __ghdl_rtik_type_i64 = 26, __ghdl_rtik_type_f64 = 27, + __ghdl_rtik_type_p32 = 28, __ghdl_rtik_type_p64 = 29, + __ghdl_rtik_type_access = 30, __ghdl_rtik_type_array = 31, + __ghdl_rtik_type_record = 32, __ghdl_rtik_type_file = 33, + __ghdl_rtik_subtype_scalar = 34, __ghdl_rtik_subtype_array = 35, + __ghdl_rtik_subtype_unconstrained_array = 36, + __ghdl_rtik_subtype_record = 37, __ghdl_rtik_subtype_access = 38, + __ghdl_rtik_type_protected = 39, __ghdl_rtik_element = 40, + __ghdl_rtik_unit64 = 41, __ghdl_rtik_unitptr = 42, + __ghdl_rtik_attribute_transaction = 43, __ghdl_rtik_attribute_quiet = 44, + __ghdl_rtik_attribute_stable = 45, __ghdl_rtik_psl_assert = 46, + __ghdl_rtik_error = 47}; + +type __ghdl_rti_depth is unsigned (8); + +type __ghdl_rti_u8 is unsigned (8); + +type __ghdl_rti_common is record + kind: __ghdl_rtik; + depth: __ghdl_rti_depth; + mode: __ghdl_rti_u8; + max_depth: __ghdl_rti_depth; +end record; + +type __ghdl_rti_access is access __ghdl_rti_common; + +public var st3p : __ghdl_rti_access; + +public var st3 : __ghdl_rti_common; diff --git a/src/ortho/oread/tests/struct4.on b/src/ortho/oread/tests/struct4.on new file mode 100644 index 000000000..6b027185d --- /dev/null +++ b/src/ortho/oread/tests/struct4.on @@ -0,0 +1,10 @@ +TYPE __ghdl_index_type IS UNSIGNED (32); + +TYPE __ghdl_char IS UNSIGNED (8); + +TYPE struct4 IS RECORD + i: __ghdl_index_type; + c : __ghdl_char; +END RECORD; + +PUBLIC VAR var1 : struct4; diff --git a/src/ortho/oread/tests/struct5.on b/src/ortho/oread/tests/struct5.on new file mode 100644 index 000000000..31661d368 --- /dev/null +++ b/src/ortho/oread/tests/struct5.on @@ -0,0 +1,10 @@ +TYPE __ghdl_index_type IS UNSIGNED (32); + +TYPE __ghdl_char IS UNSIGNED (8); + +TYPE struct5 IS RECORD + c : __ghdl_char; + i: __ghdl_index_type; +END RECORD; + +PUBLIC VAR var1 : struct5; diff --git a/src/ortho/oread/tests/struct6.on b/src/ortho/oread/tests/struct6.on new file mode 100644 index 000000000..7cb5e4619 --- /dev/null +++ b/src/ortho/oread/tests/struct6.on @@ -0,0 +1,18 @@ +TYPE float IS FLOAT; + +TYPE __ghdl_index_type IS UNSIGNED (32); + +TYPE __ghdl_char IS UNSIGNED (8); + +TYPE struct6 IS RECORD + f : float; + i: __ghdl_char; +END RECORD; + +PUBLIC VAR var1 : struct6; + +TYPE struct6_arr IS ARRAY [__ghdl_index_type] OF struct6; + +TYPE struct6x2 IS SUBARRAY struct6_arr[2]; + +PUBLIC VAR var2 : struct6x2;
\ No newline at end of file diff --git a/src/ortho/oread/tests/struct7.on b/src/ortho/oread/tests/struct7.on new file mode 100644 index 000000000..9654bc755 --- /dev/null +++ b/src/ortho/oread/tests/struct7.on @@ -0,0 +1,14 @@ +TYPE float IS FLOAT; + +TYPE __ghdl_index_type IS UNSIGNED (32); + +TYPE __ghdl_char IS UNSIGNED (8); +TYPE string IS ARRAY [__ghdl_index_type] OF __ghdl_char; +TYPE str7 IS SUBARRAY string[7]; + +TYPE struct7 IS RECORD + f : float; + s : str7; +END RECORD; + +PUBLIC VAR var1 : struct7; diff --git a/src/ortho/oread/tests/structref1.on b/src/ortho/oread/tests/structref1.on new file mode 100644 index 000000000..dfa903abe --- /dev/null +++ b/src/ortho/oread/tests/structref1.on @@ -0,0 +1,22 @@ +type __ghdl_index_type is unsigned (32); + +type __ghdl_char is unsigned (8); + +type __ghdl_chararray is array [__ghdl_index_type] of __ghdl_char; + +type __ghdl_char_ptr is access __ghdl_chararray; + +type __ghdl_char_ptr_array is array [__ghdl_index_type] of __ghdl_char_ptr; + +type __ghdl_str_len is record + len: __ghdl_index_type; + str: __ghdl_char_ptr; +end record; + +public var var1 : __ghdl_str_len; + +public function get_len () return __ghdl_index_type +declare +begin + return var1.len; +end; diff --git a/src/ortho/oread/tests/structref2.on b/src/ortho/oread/tests/structref2.on new file mode 100644 index 000000000..1090fe799 --- /dev/null +++ b/src/ortho/oread/tests/structref2.on @@ -0,0 +1,22 @@ +type __ghdl_index_type is unsigned (32); + +type __ghdl_char is unsigned (8); + +type __ghdl_chararray is array [__ghdl_index_type] of __ghdl_char; + +type __ghdl_char_ptr is access __ghdl_chararray; + +type __ghdl_char_ptr_array is array [__ghdl_index_type] of __ghdl_char_ptr; + +type __ghdl_str_len is record + str: __ghdl_char_ptr; + len: __ghdl_index_type; +end record; + +public var var1 : __ghdl_str_len; + +public function get_len () return __ghdl_index_type +declare +begin + return var1.len; +end; diff --git a/src/ortho/oread/tests/test_alloca.on b/src/ortho/oread/tests/test_alloca.on new file mode 100644 index 000000000..1b402c07c --- /dev/null +++ b/src/ortho/oread/tests/test_alloca.on @@ -0,0 +1,22 @@ +type __ghdl_size_type is unsigned (32); + +type __ghdl_index_type is unsigned (32); + +type __ghdl_integer is signed (32); + +type integer_array is array[__ghdl_index_type] of __ghdl_integer; +type integer_arr_ptr is access integer_array; + +public procedure test_alloca () +declare + local var len : __ghdl_size_type; +begin + len := __ghdl_size_type'[16]; + declare + local var ptr : integer_arr_ptr; + begin + ptr := integer_arr_ptr'alloca (len); + end; + len := __ghdl_size_type'[0]; +end; + diff --git a/src/ortho/oread/tests/test_alloca1.on b/src/ortho/oread/tests/test_alloca1.on new file mode 100644 index 000000000..06d4a2d71 --- /dev/null +++ b/src/ortho/oread/tests/test_alloca1.on @@ -0,0 +1,20 @@ +type __ghdl_size_type is unsigned (32); + +type __ghdl_index_type is unsigned (32); + +type __ghdl_integer is signed (32); + +type integer_array is array[__ghdl_index_type] of __ghdl_integer; +type integer_arr_ptr is access integer_array; + +public procedure test_alloca () +declare + local var len : __ghdl_size_type; + local var ptr : integer_arr_ptr; +begin + len := __ghdl_size_type'[16]; + ptr := integer_arr_ptr'alloca (len); + len := __ghdl_size_type'[0]; + return; +end; + diff --git a/src/ortho/oread/tests/test_assign.on b/src/ortho/oread/tests/test_assign.on new file mode 100644 index 000000000..f52091e53 --- /dev/null +++ b/src/ortho/oread/tests/test_assign.on @@ -0,0 +1,19 @@ +TYPE __ghdl_size_type IS UNSIGNED (32); + +TYPE __ghdl_index_type IS UNSIGNED (32); + +TYPE __ghdl_integer IS SIGNED (32); + +PUBLIC VAR gbl : __ghdl_integer; + +PUBLIC PROCEDURE test_assign () +DECLARE +BEGIN + gbl := __ghdl_integer'[5]; +END; + +PUBLIC PROCEDURE main () +DECLARE +BEGIN + test_assign (); +END; diff --git a/src/ortho/oread/tests/test_assign64.on b/src/ortho/oread/tests/test_assign64.on new file mode 100644 index 000000000..89e3c3996 --- /dev/null +++ b/src/ortho/oread/tests/test_assign64.on @@ -0,0 +1,22 @@ +TYPE __ghdl_integer IS SIGNED (64); + +PUBLIC VAR gbl : __ghdl_integer; + +PUBLIC PROCEDURE test_assign (v : __ghdl_integer) +DECLARE +BEGIN + gbl := __ghdl_integer'[123456] -# v; +END; + +PUBLIC PROCEDURE test_assign2 (v : __ghdl_integer) +DECLARE +BEGIN + gbl := __ghdl_integer'[891234567890] +# v; +END; + +PUBLIC PROCEDURE main () +DECLARE +BEGIN + test_assign (12); + test_assign (5); +END; diff --git a/src/ortho/oread/tests/test_dup.on b/src/ortho/oread/tests/test_dup.on new file mode 100644 index 000000000..82a85f8a2 --- /dev/null +++ b/src/ortho/oread/tests/test_dup.on @@ -0,0 +1,19 @@ +type __ghdl_size_type is unsigned (32); + +type __ghdl_index_type is unsigned (32); + +type __ghdl_integer is signed (32); + +type integer_array is array[__ghdl_index_type] of __ghdl_integer; +type integer_arr_ptr is access integer_array; + +public procedure test_alloca () +declare +begin +end; + +public procedure test_alloca () +declare +begin +end; + diff --git a/src/ortho/oread/tests/test_incomp.on b/src/ortho/oread/tests/test_incomp.on new file mode 100644 index 000000000..3cd631562 --- /dev/null +++ b/src/ortho/oread/tests/test_incomp.on @@ -0,0 +1,17 @@ +type int is signed (32); +type bool is boolean { false, true }; + +type incomp_ptr is access; +type rec is record + nxt : incomp_ptr; + val : int; +end record; + +type incomp_ptr is access rec; + +public function eq (l : incomp_ptr; r : incomp_ptr) return bool +declare +begin + return bool'(l.all.val = r.all.val); +end; + diff --git a/src/ortho/oread/tests/test_init.on b/src/ortho/oread/tests/test_init.on new file mode 100644 index 000000000..b631e16e5 --- /dev/null +++ b/src/ortho/oread/tests/test_init.on @@ -0,0 +1,36 @@ +TYPE __ghdl_size_type IS UNSIGNED (32); + +TYPE __ghdl_index_type IS UNSIGNED (32); + +TYPE __ghdl_char IS UNSIGNED (8); + +TYPE __ghdl_chararray IS ARRAY [__ghdl_index_type] OF __ghdl_char; + +TYPE __ghdl_char_ptr IS ACCESS __ghdl_chararray; + +TYPE __ghdl_str_len IS RECORD + len: __ghdl_index_type; + str: __ghdl_char_ptr; +END RECORD; + +PRIVATE VAR c : __ghdl_str_len; + +CONSTANT c := __ghdl_str_len'[DEFAULT]; + +PUBLIC VAR c2 : __ghdl_str_len; + +CONSTANT c2 := { __ghdl_index_type'[1], __ghdl_char_ptr'[DEFAULT]}; + + + +TYPE rec1_type IS RECORD; + +TYPE rec1_acc IS ACCESS rec1_type; + +TYPE rec1_type IS RECORD + len: __ghdl_index_type; +END RECORD; + +PRIVATE VAR c3 : rec1_type; + +CONSTANT c3 := rec1_type'[DEFAULT]; diff --git a/src/ortho/oread/tests/test_init2.on b/src/ortho/oread/tests/test_init2.on new file mode 100644 index 000000000..cb80c7a92 --- /dev/null +++ b/src/ortho/oread/tests/test_init2.on @@ -0,0 +1,18 @@ +TYPE std__standard__bit IS BOOLEAN {C_0, C_1}; + +--F /Users/gingold/devel/ghdl-updates.git/testsuite/gna/simple1/simple1.vhdl + +-- architecture behav + +TYPE work__simple1__ARCH__behav__INSTTYPE IS RECORD; + +TYPE work__simple1__ARCH__behav__INSTPTR IS ACCESS + work__simple1__ARCH__behav__INSTTYPE; + +TYPE work__simple1__ARCH__behav__INSTTYPE IS RECORD + s_VAL: std__standard__bit; +END RECORD; + +PRIVATE CONSTANT INST000001 : work__simple1__ARCH__behav__INSTTYPE; + +-- CONSTANT INST000001 := { std__standard__bit'[C_0]}; diff --git a/src/ortho/oread/tests/test_init3.on b/src/ortho/oread/tests/test_init3.on new file mode 100644 index 000000000..40bf75782 --- /dev/null +++ b/src/ortho/oread/tests/test_init3.on @@ -0,0 +1,24 @@ +TYPE std__standard__bit IS BOOLEAN {C_0, C_1}; + +--F /Users/gingold/devel/ghdl-updates.git/testsuite/gna/simple1/simple1.vhdl + +-- architecture behav + +TYPE work__simple1__ARCH__behav__INSTTYPE IS RECORD; + +TYPE work__simple1__ARCH__behav__INSTPTR IS ACCESS + work__simple1__ARCH__behav__INSTTYPE; + +PRIVATE VAR v_acc : work__simple1__ARCH__behav__INSTPTR; + +TYPE work__simple1__ARCH__behav__INSTTYPE IS RECORD + s_VAL: std__standard__bit; +END RECORD; +-- f : work__simple1__ARCH__behav__INSTPTR; + + +PRIVATE VAR v_inst : work__simple1__ARCH__behav__INSTTYPE; + +PRIVATE CONSTANT INST000001 : work__simple1__ARCH__behav__INSTTYPE; + +CONSTANT INST000001 := { std__standard__bit'[C_0]}; diff --git a/src/ortho/oread/tests/test_varglb.on b/src/ortho/oread/tests/test_varglb.on new file mode 100644 index 000000000..50d97b739 --- /dev/null +++ b/src/ortho/oread/tests/test_varglb.on @@ -0,0 +1,7 @@ +type __ghdl_size_type is unsigned (32); + +type __ghdl_index_type is unsigned (32); + +type __ghdl_integer is signed (32); + +public var gbl : __ghdl_integer; diff --git a/src/ortho/oread/tests/type1.on b/src/ortho/oread/tests/type1.on new file mode 100644 index 000000000..9e6732665 --- /dev/null +++ b/src/ortho/oread/tests/type1.on @@ -0,0 +1,5 @@ +-- internal declarations, part 1 + +type __ghdl_size_type is unsigned (32); + +type __ghdl_index_type is unsigned (32); diff --git a/src/ortho/oread/tests/unaggr1.on b/src/ortho/oread/tests/unaggr1.on new file mode 100644 index 000000000..ab14f53d4 --- /dev/null +++ b/src/ortho/oread/tests/unaggr1.on @@ -0,0 +1,16 @@ +type __ghdl_index_type is unsigned (32); + +type __ghdl_char is unsigned (8); + +type __ghdl_ptr is access __ghdl_char; + +type __ghdl_rti_loc is union + offset: __ghdl_char; + address: __ghdl_ptr; +end union; + +public constant var1 : __ghdl_rti_loc; +constant var1 := {.address = __ghdl_ptr'[null]}; + +public constant var2 : __ghdl_rti_loc; +constant var2 := {.offset = __ghdl_char'[0]}; diff --git a/src/ortho/oread/tests/union1.on b/src/ortho/oread/tests/union1.on new file mode 100644 index 000000000..a01d42758 --- /dev/null +++ b/src/ortho/oread/tests/union1.on @@ -0,0 +1,12 @@ +TYPE __ghdl_index_type IS UNSIGNED (32); + +TYPE __ghdl_char IS UNSIGNED (8); + +TYPE __ghdl_ptr IS ACCESS __ghdl_char; + +TYPE __ghdl_rti_loc IS UNION + offset: __ghdl_char; + address: __ghdl_ptr; +END UNION; + +PUBLIC VAR var1 : __ghdl_rti_loc; diff --git a/src/ortho/oread/tests/union2.on b/src/ortho/oread/tests/union2.on new file mode 100644 index 000000000..6c8177987 --- /dev/null +++ b/src/ortho/oread/tests/union2.on @@ -0,0 +1,14 @@ +TYPE __ghdl_index_type IS UNSIGNED (32); + +TYPE __ghdl_char IS UNSIGNED (8); + +TYPE __ghdl_ptr IS ACCESS __ghdl_char; + +TYPE __ghdl_rti_loc IS UNION + S0: RECORD + offset: __ghdl_char; + address: __ghdl_ptr; + END RECORD; +END UNION; + +PUBLIC VAR var1 : __ghdl_rti_loc; diff --git a/src/ortho/oread/tests/union3.on b/src/ortho/oread/tests/union3.on new file mode 100644 index 000000000..afad26d27 --- /dev/null +++ b/src/ortho/oread/tests/union3.on @@ -0,0 +1,27 @@ +TYPE __ghdl_index_type IS UNSIGNED (32); + +TYPE __ghdl_char IS UNSIGNED (8); + +TYPE __ghdl_ptr IS ACCESS __ghdl_char; + +TYPE __ghdl_rti_loc IS UNION + offset: __ghdl_char; + address: __ghdl_ptr; +END UNION; + +TYPE rec1 IS RECORD + f1: __ghdl_char; + f2: __ghdl_rti_loc; + f3: __ghdl_index_type; +END RECORD; + +PUBLIC VAR var1 : rec1; + +PUBLIC FUNCTION main (a : __ghdl_index_type) RETURN __ghdl_index_type +DECLARE +BEGIN + var1.f3 := 3; + var1.f1 := 1; + var1.f2.offset := 2; + RETURN 0; +END; diff --git a/src/ortho/oread/tests/var1.on b/src/ortho/oread/tests/var1.on new file mode 100644 index 000000000..7f3e9fc18 --- /dev/null +++ b/src/ortho/oread/tests/var1.on @@ -0,0 +1,8 @@ +-- internal declarations, part 1 + +TYPE __ghdl_size_type IS UNSIGNED (32); + +TYPE __ghdl_index_type IS UNSIGNED (32); + +PUBLIC CONSTANT size1 : __ghdl_size_type; +CONSTANT size1 := __ghdl_size_type'[2];
\ No newline at end of file diff --git a/src/ortho/oread/tests/var2.on b/src/ortho/oread/tests/var2.on new file mode 100644 index 000000000..b82073a63 --- /dev/null +++ b/src/ortho/oread/tests/var2.on @@ -0,0 +1,5 @@ +-- internal declarations, part 1 + +TYPE __ghdl_size_type IS UNSIGNED (32); + +PUBLIC VAR size1 : __ghdl_size_type; diff --git a/src/ortho/oread/tests/var_signed.on b/src/ortho/oread/tests/var_signed.on new file mode 100644 index 000000000..2acca3af6 --- /dev/null +++ b/src/ortho/oread/tests/var_signed.on @@ -0,0 +1,5 @@ +-- internal declarations, part 1 + +TYPE integer IS SIGNED (32); + +PUBLIC VAR v1 : integer; diff --git a/src/ortho/oread/tests/vla.on b/src/ortho/oread/tests/vla.on new file mode 100644 index 000000000..eb516f218 --- /dev/null +++ b/src/ortho/oread/tests/vla.on @@ -0,0 +1,9 @@ +type __ghdl_int is signed (32); + +public function vla (a : __ghdl_int) return __ghdl_int +declare + local var b : __ghdl_int; +begin + b := a; + return b; +end; |