From 7f0a70e0d4777a2b9c29d6b17f2385d2d3bc1ced Mon Sep 17 00:00:00 2001 From: Tristan Gingold Date: Fri, 19 Jul 2019 06:41:39 +0200 Subject: synth: add a test for concatenation. --- testsuite/synth/concat01/concat01.vhdl | 12 +++++++++++ testsuite/synth/concat01/tb_concat01.vhdl | 34 +++++++++++++++++++++++++++++++ testsuite/synth/concat01/testsuite.sh | 16 +++++++++++++++ 3 files changed, 62 insertions(+) create mode 100644 testsuite/synth/concat01/concat01.vhdl create mode 100644 testsuite/synth/concat01/tb_concat01.vhdl create mode 100755 testsuite/synth/concat01/testsuite.sh (limited to 'testsuite') diff --git a/testsuite/synth/concat01/concat01.vhdl b/testsuite/synth/concat01/concat01.vhdl new file mode 100644 index 000000000..3fe968616 --- /dev/null +++ b/testsuite/synth/concat01/concat01.vhdl @@ -0,0 +1,12 @@ +library ieee; +use ieee.std_logic_1164.all; + +entity concat01 is + port (a, b : in std_logic; + z : out std_logic_vector(1 downto 0)); +end concat01; + +architecture behav of concat01 is +begin + z <= a & b; +end behav; diff --git a/testsuite/synth/concat01/tb_concat01.vhdl b/testsuite/synth/concat01/tb_concat01.vhdl new file mode 100644 index 000000000..2709328f0 --- /dev/null +++ b/testsuite/synth/concat01/tb_concat01.vhdl @@ -0,0 +1,34 @@ +entity tb_concat01 is +end tb_concat01; + +library ieee; +use ieee.std_logic_1164.all; + +architecture behav of tb_concat01 is + signal a : std_logic; + signal b : std_logic; + signal z : std_logic_vector(1 downto 0); +begin + dut: entity work.concat01 + port map (a, b, z); + + process + begin + a <= '0'; + b <= '1'; + wait for 1 ns; + assert z = "01" severity failure; + + a <= '1'; + b <= '1'; + wait for 1 ns; + assert z = "11" severity failure; + + a <= '1'; + b <= '0'; + wait for 1 ns; + assert z = "10" severity failure; + + wait; + end process; +end behav; diff --git a/testsuite/synth/concat01/testsuite.sh b/testsuite/synth/concat01/testsuite.sh new file mode 100755 index 000000000..083547e63 --- /dev/null +++ b/testsuite/synth/concat01/testsuite.sh @@ -0,0 +1,16 @@ +#! /bin/sh + +. ../../testenv.sh + +for t in concat01; do + analyze $t.vhdl tb_$t.vhdl + elab_simulate tb_$t + clean + + synth $t.vhdl -e $t > syn_$t.vhdl + analyze syn_$t.vhdl tb_$t.vhdl + elab_simulate tb_$t + clean +done + +echo "Test successful" -- cgit v1.2.3