aboutsummaryrefslogtreecommitdiffstats
path: root/src
diff options
context:
space:
mode:
authorTristan Gingold <tgingold@free.fr>2019-06-29 20:18:02 +0200
committerTristan Gingold <tgingold@free.fr>2019-06-29 20:18:02 +0200
commit3bdf273275a89d60e765989b19c36e558b8825c8 (patch)
tree3bcc5ac92aeba58a2e290a31513ca38d88af47eb /src
parent71cd14f43e9741a4a62a8dc3be6e3d55d3940db8 (diff)
downloadghdl-3bdf273275a89d60e765989b19c36e558b8825c8.tar.gz
ghdl-3bdf273275a89d60e765989b19c36e558b8825c8.tar.bz2
ghdl-3bdf273275a89d60e765989b19c36e558b8825c8.zip
vhdl: recognize std_logic_unsigned
Diffstat (limited to 'src')
-rw-r--r--src/vhdl/vhdl-ieee-std_logic_unsigned.adb124
-rw-r--r--src/vhdl/vhdl-ieee-std_logic_unsigned.ads22
-rw-r--r--src/vhdl/vhdl-nodes.ads7
-rw-r--r--src/vhdl/vhdl-post_sems.adb3
4 files changed, 155 insertions, 1 deletions
diff --git a/src/vhdl/vhdl-ieee-std_logic_unsigned.adb b/src/vhdl/vhdl-ieee-std_logic_unsigned.adb
new file mode 100644
index 000000000..643c75ddd
--- /dev/null
+++ b/src/vhdl/vhdl-ieee-std_logic_unsigned.adb
@@ -0,0 +1,124 @@
+-- Nodes recognizer for ieee.numeric_std and ieee.numeric_bit.
+-- Copyright (C) 2016 Tristan Gingold
+--
+-- GHDL is free software; you can redistribute it and/or modify it under
+-- the terms of the GNU General Public License as published by the Free
+-- Software Foundation; either version 2, or (at your option) any later
+-- version.
+--
+-- GHDL is distributed in the hope that it will be useful, but WITHOUT ANY
+-- WARRANTY; without even the implied warranty of MERCHANTABILITY or
+-- FITNESS FOR A PARTICULAR PURPOSE. See the GNU General Public License
+-- for more details.
+--
+-- You should have received a copy of the GNU General Public License
+-- along with GHDL; see the file COPYING. If not, write to the Free
+-- Software Foundation, 59 Temple Place - Suite 330, Boston, MA
+-- 02111-1307, USA.
+
+with Vhdl.Std_Package;
+with Std_Names; use Std_Names;
+with Vhdl.Ieee.Std_Logic_1164;
+
+package body Vhdl.Ieee.Std_Logic_Unsigned is
+ type Arg_Kind is (Arg_Slv, Arg_Int, Arg_Sl);
+ type Args_Kind is (Arg_Slv_Slv, Arg_Slv_Int, Arg_Int_Slv,
+ Arg_Slv_Sl, Arg_Sl_Slv);
+
+ type Binary_Pattern_Type is array (Args_Kind) of Iir_Predefined_Functions;
+
+ Eq_Patterns : constant Binary_Pattern_Type :=
+ (Arg_Slv_Slv => Iir_Predefined_Ieee_Std_Logic_Unsigned_Eq_Slv_Slv,
+ Arg_Slv_Int => Iir_Predefined_Ieee_Std_Logic_Unsigned_Eq_Slv_Int,
+ Arg_Int_Slv => Iir_Predefined_Ieee_Std_Logic_Unsigned_Eq_Int_Slv,
+ others => Iir_Predefined_None);
+
+ Error : exception;
+
+ procedure Extract_Declarations (Pkg : Iir_Package_Declaration)
+ is
+ procedure Classify_Arg (Arg : Iir; Kind : out Arg_Kind)
+ is
+ Arg_Type : constant Iir := Get_Type (Arg);
+ begin
+ if Arg_Type = Vhdl.Std_Package.Integer_Subtype_Definition then
+ Kind := Arg_Int;
+ elsif Arg_Type = Ieee.Std_Logic_1164.Std_Logic_Type then
+ Kind := Arg_Sl;
+ elsif Arg_Type = Ieee.Std_Logic_1164.Std_Logic_Vector_Type then
+ Kind := Arg_Slv;
+ else
+ raise Error;
+ end if;
+ end Classify_Arg;
+
+ Decl : Iir;
+
+ Arg1, Arg2 : Iir;
+ Arg1_Kind, Arg2_Kind : Arg_Kind;
+
+ procedure Handle_Binary (Pats : Binary_Pattern_Type)
+ is
+ Kind : Args_Kind;
+ begin
+ case Arg1_Kind is
+ when Arg_Slv =>
+ case Arg2_Kind is
+ when Arg_Slv => Kind := Arg_Slv_Slv;
+ when Arg_Sl => Kind := Arg_Slv_Sl;
+ when Arg_Int => Kind := Arg_Slv_Int;
+ end case;
+ when Arg_Int =>
+ case Arg2_Kind is
+ when Arg_Slv => Kind := Arg_Int_Slv;
+ when Arg_Sl
+ | Arg_Int => raise Error;
+ end case;
+ when Arg_Sl =>
+ case Arg2_Kind is
+ when Arg_Slv => Kind := Arg_Sl_Slv;
+ when Arg_Sl
+ | Arg_Int => raise Error;
+ end case;
+ end case;
+
+ Set_Implicit_Definition (Decl, Pats (Kind));
+ end Handle_Binary;
+ begin
+ Decl := Get_Declaration_Chain (Pkg);
+
+ -- Handle functions.
+ while Is_Valid (Decl) loop
+ if Get_Kind (Decl) /= Iir_Kind_Function_Declaration then
+ raise Error;
+ end if;
+
+ Arg1 := Get_Interface_Declaration_Chain (Decl);
+ if Is_Null (Arg1) then
+ raise Error;
+ end if;
+
+ Classify_Arg (Arg1, Arg1_Kind);
+ Arg2 := Get_Chain (Arg1);
+ if Is_Valid (Arg2) then
+ -- Dyadic function.
+ Classify_Arg (Arg2, Arg2_Kind);
+
+ case Get_Identifier (Decl) is
+ when Name_Op_Equality =>
+ Handle_Binary (Eq_Patterns);
+ when others =>
+ null;
+ end case;
+ else
+ -- Monadic function.
+ case Get_Identifier (Decl) is
+ when others =>
+ null;
+ end case;
+ end if;
+ Decl := Get_Chain (Decl);
+ end loop;
+ end Extract_Declarations;
+
+end Vhdl.Ieee.Std_Logic_Unsigned;
diff --git a/src/vhdl/vhdl-ieee-std_logic_unsigned.ads b/src/vhdl/vhdl-ieee-std_logic_unsigned.ads
new file mode 100644
index 000000000..8ad54fd05
--- /dev/null
+++ b/src/vhdl/vhdl-ieee-std_logic_unsigned.ads
@@ -0,0 +1,22 @@
+-- Nodes recognizer for ieee.std_logic_unsigned
+-- Copyright (C) 2019 Tristan Gingold
+--
+-- GHDL is free software; you can redistribute it and/or modify it under
+-- the terms of the GNU General Public License as published by the Free
+-- Software Foundation; either version 2, or (at your option) any later
+-- version.
+--
+-- GHDL is distributed in the hope that it will be useful, but WITHOUT ANY
+-- WARRANTY; without even the implied warranty of MERCHANTABILITY or
+-- FITNESS FOR A PARTICULAR PURPOSE. See the GNU General Public License
+-- for more details.
+--
+-- You should have received a copy of the GNU General Public License
+-- along with GHDL; see the file COPYING. If not, write to the Free
+-- Software Foundation, 59 Temple Place - Suite 330, Boston, MA
+-- 02111-1307, USA.
+
+package Vhdl.Ieee.Std_Logic_Unsigned is
+ -- Extract declarations from PKG .
+ procedure Extract_Declarations (Pkg : Iir_Package_Declaration);
+end Vhdl.Ieee.Std_Logic_Unsigned;
diff --git a/src/vhdl/vhdl-nodes.ads b/src/vhdl/vhdl-nodes.ads
index aa151c4d8..84d8a7525 100644
--- a/src/vhdl/vhdl-nodes.ads
+++ b/src/vhdl/vhdl-nodes.ads
@@ -4877,7 +4877,12 @@ package Vhdl.Nodes is
-- Math_Real
Iir_Predefined_Ieee_Math_Real_Ceil,
- Iir_Predefined_Ieee_Math_Real_Log2
+ Iir_Predefined_Ieee_Math_Real_Log2,
+
+ -- Std_Logic_Unsigned (synopsys extension).
+ Iir_Predefined_Ieee_Std_Logic_Unsigned_Eq_Slv_Slv,
+ Iir_Predefined_Ieee_Std_Logic_Unsigned_Eq_Slv_Int,
+ Iir_Predefined_Ieee_Std_Logic_Unsigned_Eq_Int_Slv
);
-- Return TRUE iff FUNC is a short-cut predefined function.
diff --git a/src/vhdl/vhdl-post_sems.adb b/src/vhdl/vhdl-post_sems.adb
index bcee6c47b..c477ce813 100644
--- a/src/vhdl/vhdl-post_sems.adb
+++ b/src/vhdl/vhdl-post_sems.adb
@@ -22,6 +22,7 @@ with Vhdl.Ieee.Std_Logic_1164;
with Vhdl.Ieee.Vital_Timing;
with Vhdl.Ieee.Numeric;
with Vhdl.Ieee.Math_Real;
+with Vhdl.Ieee.Std_Logic_Unsigned;
with Flags; use Flags;
package body Vhdl.Post_Sems is
@@ -59,6 +60,8 @@ package body Vhdl.Post_Sems is
Vhdl.Ieee.Numeric.Extract_Std_Declarations (Lib_Unit);
when Name_Math_Real =>
Vhdl.Ieee.Math_Real.Extract_Declarations (Lib_Unit);
+ when Name_Std_Logic_Unsigned =>
+ Vhdl.Ieee.Std_Logic_Unsigned.Extract_Declarations (Lib_Unit);
when others =>
null;
end case;