diff options
author | Tristan Gingold <tgingold@free.fr> | 2020-03-13 06:21:06 +0100 |
---|---|---|
committer | Tristan Gingold <tgingold@free.fr> | 2020-03-13 06:30:36 +0100 |
commit | a704fa44c74d939650673bbf26de67d8e27e7bda (patch) | |
tree | 2a5ab36948d14bf36e7c9d311044fb563cec4fc0 /testsuite/synth/issue1157 | |
parent | 1fe0246646e2876c0d78d2a0ee16979658d79ac7 (diff) | |
download | ghdl-a704fa44c74d939650673bbf26de67d8e27e7bda.tar.gz ghdl-a704fa44c74d939650673bbf26de67d8e27e7bda.tar.bz2 ghdl-a704fa44c74d939650673bbf26de67d8e27e7bda.zip |
testsuite/synth: add test for #1157
Diffstat (limited to 'testsuite/synth/issue1157')
-rw-r--r-- | testsuite/synth/issue1157/ent.vhdl | 79 | ||||
-rwxr-xr-x | testsuite/synth/issue1157/testsuite.sh | 8 |
2 files changed, 87 insertions, 0 deletions
diff --git a/testsuite/synth/issue1157/ent.vhdl b/testsuite/synth/issue1157/ent.vhdl new file mode 100644 index 000000000..86d89e7de --- /dev/null +++ b/testsuite/synth/issue1157/ent.vhdl @@ -0,0 +1,79 @@ +library ieee; +use ieee.std_logic_1164.all; +use ieee.numeric_std.all; + +entity ent is + port ( + sgn : signed(7 downto 0) := x"f8"; + uns : unsigned(7 downto 0) := x"07"; + nat : natural := 15; + int : integer := -3; + + mul_int_int : out integer; + mul_uns_uns : out unsigned(15 downto 0); + mul_uns_nat : out unsigned(15 downto 0); + mul_nat_uns : out unsigned(15 downto 0); + mul_sgn_sgn : out signed(15 downto 0); + mul_sgn_int : out signed(15 downto 0); + mul_int_sgn : out signed(15 downto 0); + + div_int_int : out integer; + div_uns_uns : out unsigned(7 downto 0); + div_uns_nat : out unsigned(7 downto 0); + div_nat_uns : out unsigned(7 downto 0); + div_sgn_sgn : out signed(7 downto 0); + div_sgn_int : out signed(7 downto 0); + div_int_sgn : out signed(7 downto 0); + + rem_int_int : out integer; + rem_uns_uns : out unsigned(7 downto 0); + rem_uns_nat : out unsigned(7 downto 0); + rem_nat_uns : out unsigned(7 downto 0); + rem_sgn_sgn : out signed(7 downto 0); + rem_sgn_int : out signed(7 downto 0); + rem_int_sgn : out signed(7 downto 0); + + mod_int_int : out integer; + mod_uns_uns : out unsigned(7 downto 0); + mod_uns_nat : out unsigned(7 downto 0); + mod_nat_uns : out unsigned(7 downto 0); + mod_sgn_sgn : out signed(7 downto 0); + mod_sgn_int : out signed(7 downto 0); + mod_int_sgn : out signed(7 downto 0) + ); +end; + +architecture a of ent is +begin + mul_int_int <= int * int; + mul_uns_uns <= uns * uns; + mul_uns_nat <= uns * nat; + mul_nat_uns <= nat * uns; + mul_sgn_sgn <= sgn * sgn; + mul_sgn_int <= sgn * int; + mul_int_sgn <= int * sgn; + + div_int_int <= int / int; + div_uns_uns <= uns / uns; + div_uns_nat <= uns / nat; + div_nat_uns <= nat / uns; + div_sgn_sgn <= sgn / sgn; + div_sgn_int <= sgn / int; + div_int_sgn <= int / sgn; + + rem_int_int <= int rem int; + rem_uns_uns <= uns rem uns; + rem_uns_nat <= uns rem nat; + rem_nat_uns <= nat rem uns; + rem_sgn_sgn <= sgn rem sgn; + rem_sgn_int <= sgn rem int; + rem_int_sgn <= int rem sgn; + + mod_int_int <= int mod int; + mod_uns_uns <= uns mod uns; + mod_uns_nat <= uns mod nat; + mod_nat_uns <= nat mod uns; + mod_sgn_sgn <= sgn mod sgn; + mod_sgn_int <= sgn mod int; + mod_int_sgn <= int mod sgn; +end; diff --git a/testsuite/synth/issue1157/testsuite.sh b/testsuite/synth/issue1157/testsuite.sh new file mode 100755 index 000000000..c666942d3 --- /dev/null +++ b/testsuite/synth/issue1157/testsuite.sh @@ -0,0 +1,8 @@ +#! /bin/sh + +. ../../testenv.sh + +synth_analyze ent +clean + +echo "Test successful" |