From 75145fb7f4405448ab2ee31e795d358b9928afaf Mon Sep 17 00:00:00 2001 From: Tristan Gingold Date: Wed, 6 Nov 2019 21:02:50 +0100 Subject: Add testcase for #1011 --- testsuite/synth/issue1011/record_test.vhdl | 29 +++++++++++++++++++++++++++++ testsuite/synth/issue1011/testsuite.sh | 11 +++++++++++ 2 files changed, 40 insertions(+) create mode 100644 testsuite/synth/issue1011/record_test.vhdl create mode 100755 testsuite/synth/issue1011/testsuite.sh (limited to 'testsuite') diff --git a/testsuite/synth/issue1011/record_test.vhdl b/testsuite/synth/issue1011/record_test.vhdl new file mode 100644 index 000000000..3cd66d4fe --- /dev/null +++ b/testsuite/synth/issue1011/record_test.vhdl @@ -0,0 +1,29 @@ +library ieee; + use ieee.std_logic_1164.all; + +entity record_test is + port ( + o : out integer + ); +end record_test; + +architecture rtl of record_test is + type t_record is record + int : integer; + end record t_record; + + function get_constants(choice : std_logic) return t_record is + variable v_const : t_record; + begin + if choice = '0' then + v_const := (int => 27.777 us / 83.333 ns); + elsif choice = '1' then + v_const := (int => 26.316 us / 83.333 ns); + end if; + return v_const; + end function get_constants; + + constant rec_constant : t_record := get_constants('0'); +begin + o <= rec_constant.int; +end rtl; diff --git a/testsuite/synth/issue1011/testsuite.sh b/testsuite/synth/issue1011/testsuite.sh new file mode 100755 index 000000000..8ea172328 --- /dev/null +++ b/testsuite/synth/issue1011/testsuite.sh @@ -0,0 +1,11 @@ +#! /bin/sh + +. ../../testenv.sh + +t=record_test +synth $t.vhdl -e $t > syn_$t.vhdl +analyze syn_$t.vhdl + +clean + +echo "Test successful" -- cgit v1.2.3