diff options
author | Tristan Gingold <tgingold@free.fr> | 2023-01-29 08:38:14 +0100 |
---|---|---|
committer | Tristan Gingold <tgingold@free.fr> | 2023-01-29 08:38:14 +0100 |
commit | da2aeae6aad9977218a17013cdd38577aebaeb3d (patch) | |
tree | 95b3257dc69493c41e8c04b37c39eeba52ded406 | |
parent | e6ebb298fcb465f062099c0d10db1d828a339355 (diff) | |
download | ghdl-da2aeae6aad9977218a17013cdd38577aebaeb3d.tar.gz ghdl-da2aeae6aad9977218a17013cdd38577aebaeb3d.tar.bz2 ghdl-da2aeae6aad9977218a17013cdd38577aebaeb3d.zip |
testsuite/gna: add tests for #2328
-rw-r--r-- | testsuite/synth/issue2328/tb_test_tf.vhdl | 67 | ||||
-rw-r--r-- | testsuite/synth/issue2328/test.vhdl | 9 | ||||
-rw-r--r-- | testsuite/synth/issue2328/test_tf.vhdl | 20 | ||||
-rwxr-xr-x | testsuite/synth/issue2328/testsuite.sh | 11 |
4 files changed, 107 insertions, 0 deletions
diff --git a/testsuite/synth/issue2328/tb_test_tf.vhdl b/testsuite/synth/issue2328/tb_test_tf.vhdl new file mode 100644 index 000000000..dd57cc58c --- /dev/null +++ b/testsuite/synth/issue2328/tb_test_tf.vhdl @@ -0,0 +1,67 @@ +entity tb_test_tf is +end tb_test_tf; + +architecture behav of tb_test_tf is + signal a : bit_vector(3 downto 0); + signal red_and : bit; + signal red_nand : bit; + signal red_or : bit; + signal red_nor : bit; + signal red_xor : bit; + signal red_xnor : bit; +begin + dut: entity work.test_tf + port map ( + a => a, + red_and => red_and, + red_nand => red_nand, + red_or => red_or, + red_nor => red_nor, + red_xor => red_xor, + red_xnor => red_xnor); + process + begin + a <= b"0101"; + wait for 1 ns; + + assert red_and = '0' severity error; + assert red_nand = '1' severity error; + assert red_or = '1' severity error; + assert red_nor = '0' severity error; + assert red_xor = '0' severity error; + assert red_xnor = '1' severity error; + + a <= b"1111"; + wait for 1 ns; + + assert red_and = '1' severity error; + assert red_nand = '0' severity error; + assert red_or = '1' severity error; + assert red_nor = '0' severity error; + assert red_xor = '0' severity error; + assert red_xnor = '1' severity error; + + a <= b"0000"; + wait for 1 ns; + + assert red_and = '0' severity error; + assert red_nand = '1' severity error; + assert red_or = '0' severity error; + assert red_nor = '1' severity error; + assert red_xor = '0' severity error; + assert red_xnor = '1' severity error; + + a <= b"0001"; + wait for 1 ns; + + assert red_and = '0' severity error; + assert red_nand = '1' severity error; + assert red_or = '1' severity error; + assert red_nor = '0' severity error; + assert red_xor = '1' severity error; + assert red_xnor = '0' severity error; + + report "done"; + wait; + end process; +end behav; diff --git a/testsuite/synth/issue2328/test.vhdl b/testsuite/synth/issue2328/test.vhdl new file mode 100644 index 000000000..520e2d22f --- /dev/null +++ b/testsuite/synth/issue2328/test.vhdl @@ -0,0 +1,9 @@ +entity test is +end test; + +architecture behavior of test is +signal a: bit_vector(3 downto 0); +signal b: bit; +begin + b <= and a; +end behavior; diff --git a/testsuite/synth/issue2328/test_tf.vhdl b/testsuite/synth/issue2328/test_tf.vhdl new file mode 100644 index 000000000..dbf9f81ef --- /dev/null +++ b/testsuite/synth/issue2328/test_tf.vhdl @@ -0,0 +1,20 @@ +entity test_tf is + port( + a: in bit_vector(3 downto 0); + red_and: out bit; + red_nand: out bit; + red_or: out bit; + red_nor: out bit; + red_xor: out bit; + red_xnor: out bit); +end test_tf; + +architecture behavior of test_tf is +begin + red_and <= and a; + red_nand <= nand a; + red_or <= or a; + red_nor <= nor a; + red_xor <= xor a; + red_xnor <= xnor a; +end behavior; diff --git a/testsuite/synth/issue2328/testsuite.sh b/testsuite/synth/issue2328/testsuite.sh new file mode 100755 index 000000000..bd691904a --- /dev/null +++ b/testsuite/synth/issue2328/testsuite.sh @@ -0,0 +1,11 @@ +#! /bin/sh + +. ../../testenv.sh + +GHDL_STD_FLAGS=--std=08 + +synth_only test + +synth_tb test_tf + +echo "Test successful" |