diff options
author | Tristan Gingold <tgingold@free.fr> | 2017-05-13 18:19:26 +0200 |
---|---|---|
committer | Tristan Gingold <tgingold@free.fr> | 2017-05-17 07:19:50 +0200 |
commit | 8d71ed4eb2e0e4fb4081ff8f5f220fdd44a741e2 (patch) | |
tree | 80f5d9d9203f95400b19445fa21262bb28575ef2 | |
parent | f664558a3cc4c97dbd7837afe34375a1e52323ba (diff) | |
download | ghdl-8d71ed4eb2e0e4fb4081ff8f5f220fdd44a741e2.tar.gz ghdl-8d71ed4eb2e0e4fb4081ff8f5f220fdd44a741e2.tar.bz2 ghdl-8d71ed4eb2e0e4fb4081ff8f5f220fdd44a741e2.zip |
Add testcase to compile doc example.
-rw-r--r-- | testsuite/gna/bug073/adder.vhdl | 14 | ||||
-rw-r--r-- | testsuite/gna/bug073/adder_tb.vhdl | 57 | ||||
-rw-r--r-- | testsuite/gna/bug073/adder_tb2.vhdl | 57 | ||||
-rwxr-xr-x | testsuite/gna/bug073/testsuite.sh | 13 |
4 files changed, 141 insertions, 0 deletions
diff --git a/testsuite/gna/bug073/adder.vhdl b/testsuite/gna/bug073/adder.vhdl new file mode 100644 index 000000000..3e355607a --- /dev/null +++ b/testsuite/gna/bug073/adder.vhdl @@ -0,0 +1,14 @@ +entity adder is + -- `i0`, `i1` and the carry-in `ci` are inputs of the adder. + -- `s` is the sum output, `co` is the carry-out. + port (i0, i1 : in bit; ci : in bit; s : out bit; co : out bit); +end adder; + +architecture rtl of adder is +begin + -- This full-adder architecture contains two concurrent assignment. + -- Compute the sum. + s <= i0 xor i1 xor ci; + -- Compute the carry. + co <= (i0 and i1) or (i0 and ci) or (i1 and ci); +end rtl; diff --git a/testsuite/gna/bug073/adder_tb.vhdl b/testsuite/gna/bug073/adder_tb.vhdl new file mode 100644 index 000000000..a746de475 --- /dev/null +++ b/testsuite/gna/bug073/adder_tb.vhdl @@ -0,0 +1,57 @@ +-- A testbench has no ports. +entity adder_tb is +end adder_tb; + +architecture behav of adder_tb is + -- Declaration of the component that will be instantiated. + component adder + port (i0, i1 : in bit; ci : in bit; s : out bit; co : out bit); + end component; + + -- Specifies which entity is bound with the component. + for adder_0: adder use entity work.adder; + signal i0, i1, ci, s, co : bit; +begin + -- Component instantiation. + adder_0: adder port map (i0 => i0, i1 => i1, ci => ci, + s => s, co => co); + + -- This process does the real job. + process + type pattern_type is record + -- The inputs of the adder. + i0, i1, ci : bit; + -- The expected outputs of the adder. + s, co : bit; + end record; + -- The patterns to apply. + type pattern_array is array (natural range <>) of pattern_type; + constant patterns : pattern_array := + (('0', '0', '0', '0', '0'), + ('0', '0', '1', '1', '0'), + ('0', '1', '0', '1', '0'), + ('0', '1', '1', '0', '1'), + ('1', '0', '0', '1', '0'), + ('1', '0', '1', '0', '1'), + ('1', '1', '0', '0', '1'), + ('1', '1', '1', '1', '1')); + begin + -- Check each pattern. + for i in patterns'range loop + -- Set the inputs. + i0 <= patterns(i).i0; + i1 <= patterns(i).i1; + ci <= patterns(i).ci; + -- Wait for the results. + wait for 1 ns; + -- Check the outputs. + assert s = patterns(i).s + report "bad sum value" severity error; + assert co = patterns(i).co + report "bad carry out value" severity error; + end loop; + assert false report "end of test" severity note; + -- Wait forever; this will finish the simulation. + wait; + end process; +end behav; diff --git a/testsuite/gna/bug073/adder_tb2.vhdl b/testsuite/gna/bug073/adder_tb2.vhdl new file mode 100644 index 000000000..e20a33868 --- /dev/null +++ b/testsuite/gna/bug073/adder_tb2.vhdl @@ -0,0 +1,57 @@ +-- A testbench has no ports. +entity adder_tb2 is +end adder_tb2; + +architecture behav of adder_tb2 is + -- Declaration of the component that will be instantiated. + component adder + port (i0, i1 : in bit; ci : in bit; s : out bit; co : out bit); + end component; + + -- Specifies which entity is bound with the component. + for adder_0: adder use entity work.adder; + signal i0, i1, ci, s, co : bit; +begin + -- Component instantiation. + adder_0: entity work.adder port map (i0 => i0, i1 => i1, ci => ci, + s => s, co => co); + + -- This process does the real job. + process + type pattern_type is record + -- The inputs of the adder. + i0, i1, ci : bit; + -- The expected outputs of the adder. + s, co : bit; + end record; + -- The patterns to apply. + type pattern_array is array (natural range <>) of pattern_type; + constant patterns : pattern_array := + (('0', '0', '0', '0', '0'), + ('0', '0', '1', '1', '0'), + ('0', '1', '0', '1', '0'), + ('0', '1', '1', '0', '1'), + ('1', '0', '0', '1', '0'), + ('1', '0', '1', '0', '1'), + ('1', '1', '0', '0', '1'), + ('1', '1', '1', '1', '1')); + begin + -- Check each pattern. + for i in patterns'range loop + -- Set the inputs. + i0 <= patterns(i).i0; + i1 <= patterns(i).i1; + ci <= patterns(i).ci; + -- Wait for the results. + wait for 1 ns; + -- Check the outputs. + assert s = patterns(i).s + report "bad sum value" severity error; + assert co = patterns(i).co + report "bad carry out value" severity error; + end loop; + assert false report "end of test" severity note; + -- Wait forever; this will finish the simulation. + wait; + end process; +end behav; diff --git a/testsuite/gna/bug073/testsuite.sh b/testsuite/gna/bug073/testsuite.sh new file mode 100755 index 000000000..58b7c13e3 --- /dev/null +++ b/testsuite/gna/bug073/testsuite.sh @@ -0,0 +1,13 @@ +#! /bin/sh + +. ../../testenv.sh + +analyze adder.vhdl +analyze adder_tb.vhdl +elab_simulate adder_tb + +analyze_failure adder_tb2.vhdl + +clean + +echo "Test successful" |