diff options
author | Tristan Gingold <tgingold@free.fr> | 2020-03-13 05:31:48 +0100 |
---|---|---|
committer | Tristan Gingold <tgingold@free.fr> | 2020-03-13 06:30:32 +0100 |
commit | 97dadc0d773940868305f7241cbd3bf916505a54 (patch) | |
tree | 4f3706c982404bb12e710d2b9cb3a0d382f2a8ed /testsuite | |
parent | 2accd38fa8a5f7b9fd4fdc2eaa42b361b6a7f59d (diff) | |
download | ghdl-97dadc0d773940868305f7241cbd3bf916505a54.tar.gz ghdl-97dadc0d773940868305f7241cbd3bf916505a54.tar.bz2 ghdl-97dadc0d773940868305f7241cbd3bf916505a54.zip |
testsuite/synth: add testcase for previous commit.
Diffstat (limited to 'testsuite')
-rw-r--r-- | testsuite/synth/iassoc01/iassoc11.vhdl | 28 | ||||
-rw-r--r-- | testsuite/synth/iassoc01/tb_iassoc11.vhdl | 29 | ||||
-rwxr-xr-x | testsuite/synth/iassoc01/testsuite.sh | 2 |
3 files changed, 58 insertions, 1 deletions
diff --git a/testsuite/synth/iassoc01/iassoc11.vhdl b/testsuite/synth/iassoc01/iassoc11.vhdl new file mode 100644 index 000000000..f66c0ef59 --- /dev/null +++ b/testsuite/synth/iassoc01/iassoc11.vhdl @@ -0,0 +1,28 @@ +use work.pkg.all; + +entity riassoc11 is + port (v : nat_rec; + res : out natural); +end riassoc11; + +architecture behav of riassoc11 is +begin + res <= v.a + v.b; +end behav; + +entity iassoc11 is + port (a, b : natural; + res : out natural); +end iassoc11; + +use work.pkg.all; + +architecture behav of iassoc11 is + component riassoc11 is + port (v : nat_rec; + res : out natural); + end component; +begin + inst : riassoc11 + port map (v.a => a, v.b => b, res => res); +end behav; diff --git a/testsuite/synth/iassoc01/tb_iassoc11.vhdl b/testsuite/synth/iassoc01/tb_iassoc11.vhdl new file mode 100644 index 000000000..e8bb36289 --- /dev/null +++ b/testsuite/synth/iassoc01/tb_iassoc11.vhdl @@ -0,0 +1,29 @@ +entity tb_iassoc11 is +end tb_iassoc11; + +library ieee; +use ieee.std_logic_1164.all; + +architecture behav of tb_iassoc11 is + signal a : natural; + signal b : natural; + signal res : natural; +begin + dut: entity work.iassoc11 + port map (a, b, res); + + process + begin + a <= 1; + b <= 5; + wait for 1 ns; + assert res = 6 severity failure; + + a <= 197; + b <= 203; + wait for 1 ns; + assert res = 400 severity failure; + + wait; + end process; +end behav; diff --git a/testsuite/synth/iassoc01/testsuite.sh b/testsuite/synth/iassoc01/testsuite.sh index b1ed1293f..d00af5014 100755 --- a/testsuite/synth/iassoc01/testsuite.sh +++ b/testsuite/synth/iassoc01/testsuite.sh @@ -2,7 +2,7 @@ . ../../testenv.sh -for t in iassoc01 iassoc02 iassoc03 iassoc04; do +for t in iassoc01 iassoc02 iassoc03 iassoc04 iassoc11; do analyze pkg.vhdl $t.vhdl tb_$t.vhdl elab_simulate tb_$t clean |