diff options
| author | Tristan Gingold <tgingold@free.fr> | 2014-10-29 20:36:29 +0100 | 
|---|---|---|
| committer | Tristan Gingold <tgingold@free.fr> | 2014-10-29 20:36:29 +0100 | 
| commit | e5071f1a02f16a369c504944934042fbfb09e5dc (patch) | |
| tree | 1b891a41c024a308274c380c8189e3213085a7e8 | |
| parent | 236a876a8448b89061bb71869c36a68aea0199c3 (diff) | |
| download | ghdl-e5071f1a02f16a369c504944934042fbfb09e5dc.tar.gz ghdl-e5071f1a02f16a369c504944934042fbfb09e5dc.tar.bz2 ghdl-e5071f1a02f16a369c504944934042fbfb09e5dc.zip | |
Add support for package interface.
| -rw-r--r-- | canon.adb | 62 | ||||
| -rw-r--r-- | disp_vhdl.adb | 32 | ||||
| -rw-r--r-- | errorout.adb | 13 | ||||
| -rw-r--r-- | evaluation.adb | 27 | ||||
| -rw-r--r-- | ieee-vital_timing.adb | 36 | ||||
| -rw-r--r-- | iirs.adb | 40 | ||||
| -rw-r--r-- | iirs.ads | 127 | ||||
| -rw-r--r-- | iirs_utils.adb | 67 | ||||
| -rw-r--r-- | iirs_utils.ads | 7 | ||||
| -rw-r--r-- | libraries/Makefile.inc | 6 | ||||
| -rw-r--r-- | libraries/ieee2008/float_generic_pkg-body.vhdl | 10 | ||||
| -rw-r--r-- | nodes.ads | 527 | ||||
| -rw-r--r-- | nodes_gc.adb | 2 | ||||
| -rw-r--r-- | nodes_meta.adb | 701 | ||||
| -rw-r--r-- | nodes_meta.ads | 6 | ||||
| -rw-r--r-- | parse.adb | 606 | ||||
| -rw-r--r-- | sem.adb | 138 | ||||
| -rw-r--r-- | sem.ads | 5 | ||||
| -rw-r--r-- | sem_assocs.adb | 418 | ||||
| -rw-r--r-- | sem_assocs.ads | 9 | ||||
| -rw-r--r-- | sem_decls.adb | 498 | ||||
| -rw-r--r-- | sem_decls.ads | 6 | ||||
| -rw-r--r-- | sem_expr.adb | 25 | ||||
| -rw-r--r-- | sem_inst.adb | 219 | ||||
| -rw-r--r-- | sem_names.adb | 43 | ||||
| -rw-r--r-- | sem_scopes.adb | 17 | ||||
| -rw-r--r-- | sem_specs.adb | 10 | ||||
| -rw-r--r-- | sem_stmts.adb | 14 | ||||
| -rw-r--r-- | sem_types.adb | 22 | ||||
| -rw-r--r-- | std_package.adb | 12 | ||||
| -rw-r--r-- | translate/ghdldrv/ghdlprint.adb | 4 | ||||
| -rw-r--r-- | translate/trans_analyzes.adb | 4 | ||||
| -rw-r--r-- | translate/translation.adb | 384 | ||||
| -rwxr-xr-x | xtools/pnodes.py | 78 | 
34 files changed, 2336 insertions, 1839 deletions
| @@ -211,7 +211,7 @@ package body Canon is           when Iir_Kind_Last_Value_Attribute =>              null; -         when Iir_Kind_Signal_Interface_Declaration +         when Iir_Kind_Interface_Signal_Declaration             | Iir_Kind_Signal_Declaration             | Iir_Kind_Guard_Signal_Declaration             | Iir_Kind_Stable_Attribute @@ -235,10 +235,10 @@ package body Canon is                (Get_Name (Expr), Sensitivity_List, Is_Target);           when Iir_Kind_Constant_Declaration -           | Iir_Kind_Constant_Interface_Declaration +           | Iir_Kind_Interface_Constant_Declaration             | Iir_Kind_Iterator_Declaration             | Iir_Kind_Variable_Declaration -           | Iir_Kind_Variable_Interface_Declaration +           | Iir_Kind_Interface_Variable_Declaration             | Iir_Kind_File_Declaration =>              null; @@ -459,6 +459,7 @@ package body Canon is       (Callees_List : Iir_List; Sensitivity_List : Iir_List)     is        Callee : Iir; +      Bod : Iir;     begin        --  LRM08 11.3        --  Moreover, for each subprogram for which the process is a parent @@ -477,14 +478,20 @@ package body Canon is              Set_Seen_Flag (Callee, True);              case Get_All_Sensitized_State (Callee) is                 when Read_Signal => +                  Bod := Get_Subprogram_Body (Callee); + +                  --  Extract sensitivity from signals read in the body. +                  --  FIXME: what about signals read during in declarations ?                    Canon_Extract_Sequential_Statement_Chain_Sensitivity -                    (Get_Sequential_Statement_Chain -                       (Get_Subprogram_Body (Callee)), -                     Sensitivity_List); +                    (Get_Sequential_Statement_Chain (Bod), Sensitivity_List); + +                  --  Extract sensitivity from subprograms called.                    Canon_Extract_Sensitivity_From_Callees -                    (Get_Callees_List (Callee), Sensitivity_List); +                    (Get_Callees_List (Bod), Sensitivity_List); +                 when No_Signal =>                    null; +                 when Unknown | Invalid_Signal =>                    raise Internal_Error;              end case; @@ -499,10 +506,15 @@ package body Canon is        Res : Iir_List;     begin        Res := Create_Iir_List; + +      --  Signals read by statements. +      --  FIXME: justify why signals read in declarations don't care.        Canon_Extract_Sequential_Statement_Chain_Sensitivity          (Get_Sequential_Statement_Chain (Proc), Res); -      Canon_Extract_Sensitivity_From_Callees -        (Get_Callees_List (Proc), Res); + +      --  Signals read indirectly by subprograms called. +      Canon_Extract_Sensitivity_From_Callees (Get_Callees_List (Proc), Res); +        Set_Seen_Flag (Proc, True);        Clear_Seen_Flag (Proc);        return Res; @@ -717,16 +729,16 @@ package body Canon is             | Iir_Kind_Instance_Name_Attribute =>              null; -         when Iir_Kind_Signal_Interface_Declaration +         when Iir_Kind_Interface_Signal_Declaration             | Iir_Kind_Signal_Declaration             | Iir_Kind_Guard_Signal_Declaration             | Iir_Kind_Constant_Declaration -           | Iir_Kind_Constant_Interface_Declaration +           | Iir_Kind_Interface_Constant_Declaration             | Iir_Kind_Iterator_Declaration             | Iir_Kind_Variable_Declaration -           | Iir_Kind_Variable_Interface_Declaration +           | Iir_Kind_Interface_Variable_Declaration             | Iir_Kind_File_Declaration -           | Iir_Kind_File_Interface_Declaration +           | Iir_Kind_Interface_File_Declaration             | Iir_Kind_Object_Alias_Declaration =>              null; @@ -798,9 +810,7 @@ package body Canon is     begin        --  No argument, so return now.        if Interface_Chain = Null_Iir then -         if Association_Chain /= Null_Iir then -            raise Internal_Error; -         end if; +         pragma Assert (Association_Chain = Null_Iir);           return Null_Iir;        end if; @@ -842,8 +852,10 @@ package body Canon is                       end if;                    when Iir_Kind_Association_Element_By_Individual =>                       Found := True; +                  when Iir_Kind_Association_Element_Package => +                     goto Done;                    when others => -                     Error_Kind ("canon_association_list", Assoc_El); +                     Error_Kind ("canon_association_chain", Assoc_El);                 end case;              elsif Found then                 --  No more associations. @@ -2621,11 +2633,17 @@ package body Canon is              Canon_Declarations (Unit, El, Null_Iir);              Canon_Block_Configuration (Unit, Get_Block_Configuration (El));           when Iir_Kind_Package_Instantiation_Declaration => -            Set_Generic_Map_Aspect_Chain -              (El, -               Canon_Association_Chain_And_Actuals -                 (Get_Generic_Chain (El), -                  Get_Generic_Map_Aspect_Chain (El), El)); +            declare +               Pkg : constant Iir := +                 Get_Named_Entity (Get_Uninstantiated_Package_Name (El)); +               Hdr : constant Iir := Get_Package_Header (Pkg); +            begin +               Set_Generic_Map_Aspect_Chain +                 (El, +                  Canon_Association_Chain_And_Actuals +                    (Get_Generic_Chain (Hdr), +                     Get_Generic_Map_Aspect_Chain (El), El)); +            end;           when others =>              Error_Kind ("canonicalize2", El);        end case; diff --git a/disp_vhdl.adb b/disp_vhdl.adb index 018db271a..eb7a44b16 100644 --- a/disp_vhdl.adb +++ b/disp_vhdl.adb @@ -171,10 +171,10 @@ package body Disp_Vhdl is           when Iir_Kind_Component_Declaration             | Iir_Kind_Entity_Declaration             | Iir_Kind_Architecture_Body -           | Iir_Kind_Constant_Interface_Declaration -           | Iir_Kind_Signal_Interface_Declaration -           | Iir_Kind_Variable_Interface_Declaration -           | Iir_Kind_File_Interface_Declaration +           | Iir_Kind_Interface_Constant_Declaration +           | Iir_Kind_Interface_Signal_Declaration +           | Iir_Kind_Interface_Variable_Declaration +           | Iir_Kind_Interface_File_Declaration             | Iir_Kind_Constant_Declaration             | Iir_Kind_Signal_Declaration             | Iir_Kind_Guard_Signal_Declaration @@ -276,7 +276,7 @@ package body Disp_Vhdl is             | Iir_Kind_Unit_Declaration             | Iir_Kind_Implicit_Function_Declaration             | Iir_Kind_Implicit_Procedure_Declaration -           | Iir_Kinds_Interface_Declaration +           | Iir_Kinds_Interface_Object_Declaration             | Iir_Kind_Variable_Declaration             | Iir_Kind_Function_Declaration             | Iir_Kind_Procedure_Declaration @@ -1025,13 +1025,13 @@ package body Disp_Vhdl is     begin        if (Get_Lexical_Layout (Inter) and Iir_Lexical_Has_Class) /= 0 then           case Get_Kind (Inter) is -            when Iir_Kind_Signal_Interface_Declaration => +            when Iir_Kind_Interface_Signal_Declaration =>                 Put ("signal "); -            when Iir_Kind_Variable_Interface_Declaration => +            when Iir_Kind_Interface_Variable_Declaration =>                 Put ("variable "); -            when Iir_Kind_Constant_Interface_Declaration => +            when Iir_Kind_Interface_Constant_Declaration =>                 Put ("constant "); -            when Iir_Kind_File_Interface_Declaration => +            when Iir_Kind_Interface_File_Declaration =>                 Put ("file ");              when others =>                 Error_Kind ("disp_interface_class", Inter); @@ -1054,7 +1054,7 @@ package body Disp_Vhdl is        else           Disp_Subtype_Indication (Get_Subtype_Indication (Inter));        end if; -      if Get_Kind (Inter) = Iir_Kind_Signal_Interface_Declaration then +      if Get_Kind (Inter) = Iir_Kind_Interface_Signal_Declaration then           Disp_Signal_Kind (Get_Signal_Kind (Inter));        end if;        if Default /= Null_Iir then @@ -2536,15 +2536,15 @@ package body Disp_Vhdl is           when Iir_Kind_Element_Declaration =>              Disp_Name_Of (Expr); -         when Iir_Kind_Signal_Interface_Declaration +         when Iir_Kind_Interface_Signal_Declaration             | Iir_Kind_Signal_Declaration             | Iir_Kind_Guard_Signal_Declaration             | Iir_Kind_Variable_Declaration -           | Iir_Kind_Variable_Interface_Declaration +           | Iir_Kind_Interface_Variable_Declaration             | Iir_Kind_Constant_Declaration -           | Iir_Kind_Constant_Interface_Declaration +           | Iir_Kind_Interface_Constant_Declaration             | Iir_Kind_File_Declaration -           | Iir_Kind_File_Interface_Declaration +           | Iir_Kind_Interface_File_Declaration             | Iir_Kind_Iterator_Declaration =>              Disp_Name_Of (Expr);              return; @@ -2949,7 +2949,7 @@ package body Disp_Vhdl is        Put ("package ");        Disp_Identifier (Decl);        Put_Line (" is new "); -      Disp_Name (Get_Uninstantiated_Name (Decl)); +      Disp_Name (Get_Uninstantiated_Package_Name (Decl));        Put (" ");        Disp_Generic_Map_Aspect (Decl);        Put_Line (";"); @@ -3153,7 +3153,7 @@ package body Disp_Vhdl is              Disp_Concurrent_Conditional_Signal_Assignment (An_Iir);           when Iir_Kinds_Dyadic_Operator =>              Disp_Dyadic_Operator (An_Iir); -         when Iir_Kind_Signal_Interface_Declaration +         when Iir_Kind_Interface_Signal_Declaration             | Iir_Kind_Signal_Declaration             | Iir_Kind_Object_Alias_Declaration =>              Disp_Name_Of (An_Iir); diff --git a/errorout.adb b/errorout.adb index 4dde4562d..af6977d31 100644 --- a/errorout.adb +++ b/errorout.adb @@ -419,7 +419,8 @@ package body Errorout is              return "open association element";           when Iir_Kind_Association_Element_By_Individual =>              return "individual association element"; -         when Iir_Kind_Association_Element_By_Expression => +         when Iir_Kind_Association_Element_By_Expression +           | Iir_Kind_Association_Element_Package =>              return "association element";           when Iir_Kind_Overload_List =>              return "overloaded name or expression"; @@ -527,7 +528,7 @@ package body Errorout is           when Iir_Kind_Psl_Expression =>              return "PSL instantiation"; -         when Iir_Kind_Constant_Interface_Declaration => +         when Iir_Kind_Interface_Constant_Declaration =>              if Get_Parent (Node) = Null_Iir then                 --  For constant interface of predefined operator.                 return "anonymous interface"; @@ -540,7 +541,7 @@ package body Errorout is                 when others =>                    return Disp_Identifier (Node, "constant interface");              end case; -         when Iir_Kind_Signal_Interface_Declaration => +         when Iir_Kind_Interface_Signal_Declaration =>              case Get_Kind (Get_Parent (Node)) is                 when Iir_Kind_Entity_Declaration                   | Iir_Kind_Block_Statement @@ -549,10 +550,12 @@ package body Errorout is                 when others =>                    return Disp_Identifier (Node, "signal interface");              end case; -         when Iir_Kind_Variable_Interface_Declaration => +         when Iir_Kind_Interface_Variable_Declaration =>              return Disp_Identifier (Node, "variable interface"); -         when Iir_Kind_File_Interface_Declaration => +         when Iir_Kind_Interface_File_Declaration =>              return Disp_Identifier (Node, "file interface"); +         when Iir_Kind_Interface_Package_Declaration => +            return Disp_Identifier (Node, "package interface");           when Iir_Kind_Signal_Declaration =>              return Disp_Identifier (Node, "signal");           when Iir_Kind_Variable_Declaration => diff --git a/evaluation.adb b/evaluation.adb index dd16b2276..8279e140c 100644 --- a/evaluation.adb +++ b/evaluation.adb @@ -89,23 +89,16 @@ package body Evaluation is     function Build_Enumeration_Constant (Val : Iir_Index32; Origin : Iir)       return Iir_Enumeration_Literal     is +      Enum_Type : constant Iir := Get_Base_Type (Get_Type (Origin)); +      Enum_List : constant Iir_List := +        Get_Enumeration_Literal_List (Enum_Type); +      Lit : constant Iir_Enumeration_Literal := +        Get_Nth_Element (Enum_List, Integer (Val));        Res : Iir_Enumeration_Literal; -      Enum_Type : Iir; -      Enum_List : Iir_List; -      Lit : Iir_Enumeration_Literal;     begin -      Enum_Type := Get_Base_Type (Get_Type (Origin)); -      Enum_List := Get_Enumeration_Literal_List (Enum_Type); -      Lit := Get_Nth_Element (Enum_List, Integer (Val)); - -      Res := Create_Iir (Iir_Kind_Enumeration_Literal); -      Set_Identifier (Res, Get_Identifier (Lit)); +      Res := Copy_Enumeration_Literal (Lit);        Location_Copy (Res, Origin); -      Set_Enum_Pos (Res, Iir_Int32 (Val)); -      Set_Type (Res, Get_Type (Origin));        Set_Literal_Origin (Res, Origin); -      Set_Expr_Staticness (Res, Locally); -      Set_Enumeration_Decl (Res, Lit);        return Res;     end Build_Enumeration_Constant; @@ -3015,14 +3008,14 @@ package body Evaluation is        --    path, as appropriate, will not contain a local item name.        case Get_Kind (Prefix) is           when Iir_Kind_Constant_Declaration -           | Iir_Kind_Constant_Interface_Declaration +           | Iir_Kind_Interface_Constant_Declaration             | Iir_Kind_Iterator_Declaration             | Iir_Kind_Variable_Declaration -           | Iir_Kind_Variable_Interface_Declaration +           | Iir_Kind_Interface_Variable_Declaration             | Iir_Kind_Signal_Declaration -           | Iir_Kind_Signal_Interface_Declaration +           | Iir_Kind_Interface_Signal_Declaration             | Iir_Kind_File_Declaration -           | Iir_Kind_File_Interface_Declaration +           | Iir_Kind_Interface_File_Declaration             | Iir_Kind_Type_Declaration             | Iir_Kind_Subtype_Declaration =>              Path_Add_Element (Get_Parent (Prefix), Is_Instance); diff --git a/ieee-vital_timing.adb b/ieee-vital_timing.adb index c86f1db06..453eeaa12 100644 --- a/ieee-vital_timing.adb +++ b/ieee-vital_timing.adb @@ -231,7 +231,7 @@ package body Ieee.Vital_Timing is     end Check_Level0_Attribute_Specification;     procedure Check_Entity_Port_Declaration -     (Decl : Iir_Signal_Interface_Declaration) +     (Decl : Iir_Interface_Signal_Declaration)     is        use Name_Table; @@ -796,7 +796,7 @@ package body Ieee.Vital_Timing is     end Check_Vital_Delay_Type;     function Check_Timing_Generic_Prefix -     (Decl : Iir_Constant_Interface_Declaration; Length : Natural) +     (Decl : Iir_Interface_Constant_Declaration; Length : Natural)       return Boolean     is        use Name_Table; @@ -818,7 +818,7 @@ package body Ieee.Vital_Timing is     --  <VITALPropagationDelayName> ::=     --     TPD_<InputPort>_<OutputPort>[_<SDFSimpleConditionAndOrEdge>]     procedure Check_Propagation_Delay_Name -     (Decl : Iir_Constant_Interface_Declaration) +     (Decl : Iir_Interface_Constant_Declaration)     is        Iport : Iir;        Oport : Iir; @@ -845,7 +845,7 @@ package body Ieee.Vital_Timing is     --  tsetup     procedure Check_Input_Setup_Time_Name -     (Decl : Iir_Constant_Interface_Declaration) +     (Decl : Iir_Interface_Constant_Declaration)     is     begin        if not Check_Timing_Generic_Prefix (Decl, 7) then @@ -856,7 +856,7 @@ package body Ieee.Vital_Timing is     --  thold     procedure Check_Input_Hold_Time_Name -     (Decl : Iir_Constant_Interface_Declaration) +     (Decl : Iir_Interface_Constant_Declaration)     is     begin        if not Check_Timing_Generic_Prefix (Decl, 6) then @@ -867,7 +867,7 @@ package body Ieee.Vital_Timing is     --  trecovery     procedure Check_Input_Recovery_Time_Name -     (Decl : Iir_Constant_Interface_Declaration) +     (Decl : Iir_Interface_Constant_Declaration)     is     begin        if not Check_Timing_Generic_Prefix (Decl, 10) then @@ -878,7 +878,7 @@ package body Ieee.Vital_Timing is     --  tremoval     procedure Check_Input_Removal_Time_Name -     (Decl : Iir_Constant_Interface_Declaration) +     (Decl : Iir_Interface_Constant_Declaration)     is     begin        if not Check_Timing_Generic_Prefix (Decl, 9) then @@ -889,7 +889,7 @@ package body Ieee.Vital_Timing is     --  tperiod     procedure Check_Input_Period_Name -     (Decl : Iir_Constant_Interface_Declaration) +     (Decl : Iir_Interface_Constant_Declaration)     is        Iport : Iir;     begin @@ -903,7 +903,7 @@ package body Ieee.Vital_Timing is     --  tpw     procedure Check_Pulse_Width_Name -     (Decl : Iir_Constant_Interface_Declaration) +     (Decl : Iir_Interface_Constant_Declaration)     is        Iport : Iir;     begin @@ -917,7 +917,7 @@ package body Ieee.Vital_Timing is     --  tskew     procedure Check_Input_Skew_Time_Name -     (Decl : Iir_Constant_Interface_Declaration) +     (Decl : Iir_Interface_Constant_Declaration)     is        Fport : Iir;        Sport : Iir; @@ -933,7 +933,7 @@ package body Ieee.Vital_Timing is     --  tncsetup     procedure Check_No_Change_Setup_Time_Name -     (Decl : Iir_Constant_Interface_Declaration) +     (Decl : Iir_Interface_Constant_Declaration)     is     begin        if not Check_Timing_Generic_Prefix (Decl, 9) then @@ -944,7 +944,7 @@ package body Ieee.Vital_Timing is     --  tnchold     procedure Check_No_Change_Hold_Time_Name -     (Decl : Iir_Constant_Interface_Declaration) +     (Decl : Iir_Interface_Constant_Declaration)     is     begin        if not Check_Timing_Generic_Prefix (Decl, 8) then @@ -955,7 +955,7 @@ package body Ieee.Vital_Timing is     --  tipd     procedure Check_Interconnect_Path_Delay_Name -     (Decl : Iir_Constant_Interface_Declaration) +     (Decl : Iir_Interface_Constant_Declaration)     is        Iport : Iir;     begin @@ -969,7 +969,7 @@ package body Ieee.Vital_Timing is     --  tdevice     procedure Check_Device_Delay_Name -     (Decl : Iir_Constant_Interface_Declaration) +     (Decl : Iir_Interface_Constant_Declaration)     is        Oport : Iir;        pragma Unreferenced (Oport); @@ -995,7 +995,7 @@ package body Ieee.Vital_Timing is     --  tisd     procedure Check_Internal_Signal_Delay_Name -     (Decl : Iir_Constant_Interface_Declaration) +     (Decl : Iir_Interface_Constant_Declaration)     is        Iport : Iir;        Cport : Iir; @@ -1012,7 +1012,7 @@ package body Ieee.Vital_Timing is     --  tbpd     procedure Check_Biased_Propagation_Delay_Name -     (Decl : Iir_Constant_Interface_Declaration) +     (Decl : Iir_Interface_Constant_Declaration)     is        Iport : Iir;        Oport : Iir; @@ -1082,7 +1082,7 @@ package body Ieee.Vital_Timing is     --  ticd     procedure Check_Internal_Clock_Delay_Generic_Name -     (Decl : Iir_Constant_Interface_Declaration) +     (Decl : Iir_Interface_Constant_Declaration)     is        Cport : Iir;        P_Start : Natural; @@ -1168,7 +1168,7 @@ package body Ieee.Vital_Timing is     end Check_Internal_Clock_Delay_Generic_Name;     procedure Check_Entity_Generic_Declaration -     (Decl : Iir_Constant_Interface_Declaration) +     (Decl : Iir_Interface_Constant_Declaration)     is        use Name_Table;        Id : Name_Id; @@ -242,6 +242,7 @@ package body Iirs is             | Iir_Kind_Association_Element_By_Expression             | Iir_Kind_Association_Element_By_Individual             | Iir_Kind_Association_Element_Open +           | Iir_Kind_Association_Element_Package             | Iir_Kind_Choice_By_Others             | Iir_Kind_Choice_By_Expression             | Iir_Kind_Choice_By_Range @@ -291,8 +292,6 @@ package body Iirs is             | Iir_Kind_Element_Declaration             | Iir_Kind_Non_Object_Alias_Declaration             | Iir_Kind_Terminal_Declaration -           | Iir_Kind_Function_Body -           | Iir_Kind_Procedure_Body             | Iir_Kind_Object_Alias_Declaration             | Iir_Kind_Identity_Operator             | Iir_Kind_Negation_Operator @@ -437,16 +436,19 @@ package body Iirs is             | Iir_Kind_Implicit_Function_Declaration             | Iir_Kind_Implicit_Procedure_Declaration             | Iir_Kind_Procedure_Declaration +           | Iir_Kind_Function_Body +           | Iir_Kind_Procedure_Body             | Iir_Kind_File_Declaration             | Iir_Kind_Guard_Signal_Declaration             | Iir_Kind_Signal_Declaration             | Iir_Kind_Variable_Declaration             | Iir_Kind_Constant_Declaration             | Iir_Kind_Iterator_Declaration -           | Iir_Kind_Constant_Interface_Declaration -           | Iir_Kind_Variable_Interface_Declaration -           | Iir_Kind_Signal_Interface_Declaration -           | Iir_Kind_File_Interface_Declaration +           | Iir_Kind_Interface_Constant_Declaration +           | Iir_Kind_Interface_Variable_Declaration +           | Iir_Kind_Interface_Signal_Declaration +           | Iir_Kind_Interface_File_Declaration +           | Iir_Kind_Interface_Package_Declaration             | Iir_Kind_Sensitized_Process_Statement             | Iir_Kind_Process_Statement             | Iir_Kind_Concurrent_Conditional_Signal_Assignment @@ -3225,19 +3227,19 @@ package body Iirs is        Set_Field7 (Target, Header);     end Set_Block_Header; -   function Get_Uninstantiated_Name (Inst : Iir) return Iir is +   function Get_Uninstantiated_Package_Name (Inst : Iir) return Iir is     begin        pragma Assert (Inst /= Null_Iir); -      pragma Assert (Has_Uninstantiated_Name (Get_Kind (Inst))); +      pragma Assert (Has_Uninstantiated_Package_Name (Get_Kind (Inst)));        return Get_Field5 (Inst); -   end Get_Uninstantiated_Name; +   end Get_Uninstantiated_Package_Name; -   procedure Set_Uninstantiated_Name (Inst : Iir; Name : Iir) is +   procedure Set_Uninstantiated_Package_Name (Inst : Iir; Name : Iir) is     begin        pragma Assert (Inst /= Null_Iir); -      pragma Assert (Has_Uninstantiated_Name (Get_Kind (Inst))); +      pragma Assert (Has_Uninstantiated_Package_Name (Get_Kind (Inst)));        Set_Field5 (Inst, Name); -   end Set_Uninstantiated_Name; +   end Set_Uninstantiated_Package_Name;     function Get_Generate_Block_Configuration (Target : Iir) return Iir is     begin @@ -3689,6 +3691,20 @@ package body Iirs is        Set_Field3 (Target, Atype);     end Set_Actual_Type; +   function Get_Associated_Interface (Assoc : Iir) return Iir is +   begin +      pragma Assert (Assoc /= Null_Iir); +      pragma Assert (Has_Associated_Interface (Get_Kind (Assoc))); +      return Get_Field4 (Assoc); +   end Get_Associated_Interface; + +   procedure Set_Associated_Interface (Assoc : Iir; Inter : Iir) is +   begin +      pragma Assert (Assoc /= Null_Iir); +      pragma Assert (Has_Associated_Interface (Get_Kind (Assoc))); +      Set_Field4 (Assoc, Inter); +   end Set_Associated_Interface; +     function Get_Association_Chain (Target : Iir) return Iir is     begin        pragma Assert (Target /= Null_Iir); @@ -383,6 +383,7 @@ package Iirs is     -- Iir_Kind_Association_Element_By_Expression (Short)     -- Iir_Kind_Association_Element_Open (Short)     -- Iir_Kind_Association_Element_By_Individual (Short) +   -- Iir_Kind_Association_Element_Package (Short)     --  These are used for association element of an association list with     --  an interface (ie subprogram call, port map, generic map).     -- @@ -391,6 +392,7 @@ package Iirs is     --   Get/Set_Chain (Field2)     --     -- Only for Iir_Kind_Association_Element_By_Expression: +   -- Only for Iir_Kind_Association_Element_Package:     --   Get/Set_Actual (Field3)     --     -- Only for Iir_Kind_Association_Element_By_Individual: @@ -399,6 +401,9 @@ package Iirs is     -- Only for Iir_Kind_Association_Element_By_Individual:     --   Get/Set_Individual_Association_Chain (Field4)     -- +   -- Only for Iir_Kind_Association_Element_Package: +   --   Get/Set_Associated_Interface (Field4) +   --     --  A function call or a type conversion for the association.     --  FIXME: should be a name ?     -- Only for Iir_Kind_Association_Element_By_Expression: @@ -842,7 +847,7 @@ package Iirs is     --     --   Get/Set_Attribute_Value_Chain (Field4)     -- -   --   Get/Set_Uninstantiated_Name (Field5) +   --   Get/Set_Uninstantiated_Package_Name (Field5)     --     --   Get/Set_Generic_Chain (Field6)     -- @@ -1072,10 +1077,10 @@ package Iirs is     --     --   Get/Set_Use_Flag (Flag6) -   -- Iir_Kind_Signal_Interface_Declaration (Medium) -   -- Iir_Kind_Constant_Interface_Declaration (Medium) -   -- Iir_Kind_Variable_Interface_Declaration (Medium) -   -- Iir_Kind_File_Interface_Declaration (Medium) +   -- Iir_Kind_Interface_Signal_Declaration (Medium) +   -- Iir_Kind_Interface_Constant_Declaration (Medium) +   -- Iir_Kind_Interface_Variable_Declaration (Medium) +   -- Iir_Kind_Interface_File_Declaration (Medium)     --     --  Get/Set the parent of an interface declaration.     --  The parent is an entity declaration, a subprogram specification, a @@ -1095,20 +1100,20 @@ package Iirs is     --     --   Get/Set_Subtype_Indication (Field5)     -- -   --  Must always be null_iir for iir_kind_file_interface_declaration. +   --  Must always be null_iir for iir_kind_interface_file_declaration.     --   Get/Set_Default_Value (Field6)     --     --   Get/Set_Mode (Odigit1)     --     --   Get/Set_Lexical_Layout (Odigit2)     -- -   -- Only for Iir_Kind_Signal_Interface_Declaration: +   -- Only for Iir_Kind_Interface_Signal_Declaration:     --   Get/Set_Has_Disconnect_Flag (Flag1)     -- -   -- Only for Iir_Kind_Signal_Interface_Declaration: +   -- Only for Iir_Kind_Interface_Signal_Declaration:     --   Get/Set_Has_Active_Flag (Flag2)     -- -   -- Only for Iir_Kind_Signal_Interface_Declaration: +   -- Only for Iir_Kind_Interface_Signal_Declaration:     --   Get/Set_Open_Flag (Flag3)     --     --   Get/Set_Visible_Flag (Flag4) @@ -1123,9 +1128,29 @@ package Iirs is     --     --   Get/Set_Name_Staticness (State2)     -- -   -- Only for Iir_Kind_Signal_Interface_Declaration: +   -- Only for Iir_Kind_Interface_Signal_Declaration:     --   Get/Set_Signal_Kind (State3) +   -- Iir_Kind_Interface_Package_Declaration (Medium) +   -- +   --   Get/Set_Parent (Field0) +   -- +   --   Get/Set_Declaration_Chain (Field1) +   -- +   --   Get/Set_Chain (Field2) +   -- +   --   Get/Set_Identifier (Field3) +   -- +   --   Get/Set_Attribute_Value_Chain (Field4) +   -- +   --   Get/Set_Uninstantiated_Package_Name (Field5) +   -- +   --   Get/Set_Generic_Chain (Field6) +   -- +   --   Get/Set_Generic_Map_Aspect_Chain (Field8) +   -- +   --   Get/Set_Visible_Flag (Flag4) +     -- Iir_Kind_Function_Declaration (Medium)     -- Iir_Kind_Procedure_Declaration (Medium)     -- @@ -1173,8 +1198,6 @@ package Iirs is     --     --   Get/Set_Generic_Chain (Field6)     -- -   --   Get/Set_Callees_List (Field7) -   --     --   --Get/Set_Generic_Map_Aspect_Chain (Field8)     --     --   Get/Set_Return_Type_Mark (Field8) @@ -1219,8 +1242,8 @@ package Iirs is     --     --   Get/Set_All_Sensitized_State (State3) -   -- Iir_Kind_Function_Body (Short) -   -- Iir_Kind_Procedure_Body (Short) +   -- Iir_Kind_Function_Body (Medium) +   -- Iir_Kind_Procedure_Body (Medium)     --     --  LRM08 4.3 Subprogram bodies     -- @@ -1248,6 +1271,8 @@ package Iirs is     --     --   Get/Set_Sequential_Statement_Chain (Field5)     -- +   --   Get/Set_Callees_List (Field7) +   --     --   Get/Set_End_Has_Reserved_Id (Flag8)     --     --   Get/Set_End_Has_Identifier (Flag9) @@ -1277,8 +1302,6 @@ package Iirs is     --     --   Get/Set_Generic_Chain (Field6)     -- -   --   Get/Set_Callees_List (Field7) -   --     --   Get/Set_Generic_Map_Aspect_Chain (Field8)     --     --   Get/Set_Implicit_Definition (Field9) @@ -3429,6 +3452,7 @@ package Iirs is         Iir_Kind_Association_Element_By_Expression,         Iir_Kind_Association_Element_By_Individual,         Iir_Kind_Association_Element_Open, +       Iir_Kind_Association_Element_Package,         Iir_Kind_Choice_By_Others,         Iir_Kind_Choice_By_Expression,         Iir_Kind_Choice_By_Range, @@ -3528,10 +3552,11 @@ package Iirs is         Iir_Kind_Variable_Declaration,           -- object         Iir_Kind_Constant_Declaration,           -- object         Iir_Kind_Iterator_Declaration,           -- object -       Iir_Kind_Constant_Interface_Declaration, -- object, interface -       Iir_Kind_Variable_Interface_Declaration, -- object, interface -       Iir_Kind_Signal_Interface_Declaration,   -- object, interface -       Iir_Kind_File_Interface_Declaration,     -- object, interface +       Iir_Kind_Interface_Constant_Declaration, -- object, interface +       Iir_Kind_Interface_Variable_Declaration, -- object, interface +       Iir_Kind_Interface_Signal_Declaration,   -- object, interface +       Iir_Kind_Interface_File_Declaration,     -- object, interface +       Iir_Kind_Interface_Package_Declaration,     -- Expressions.         Iir_Kind_Identity_Operator, @@ -4076,6 +4101,15 @@ package Iirs is     type Iir_Constraint is       (Unconstrained, Partially_Constrained, Fully_Constrained); +   --  The kind of an inteface list. +   type Interface_Kind_Type is (Generic_Interface_List, +                                Port_Interface_List, +                                Procedure_Parameter_Interface_List, +                                Function_Parameter_Interface_List); +   subtype Parameter_Interface_List is Interface_Kind_Type range +     Procedure_Parameter_Interface_List .. +     Function_Parameter_Interface_List; +     ---------------     -- subranges --     --------------- @@ -4270,11 +4304,11 @@ package Iirs is       Iir_Kind_Sensitized_Process_Statement ..       Iir_Kind_Process_Statement; -   subtype Iir_Kinds_Interface_Declaration is Iir_Kind range -     Iir_Kind_Constant_Interface_Declaration .. -   --Iir_Kind_Variable_Interface_Declaration -   --Iir_Kind_Signal_Interface_Declaration -     Iir_Kind_File_Interface_Declaration; +   subtype Iir_Kinds_Interface_Object_Declaration is Iir_Kind range +     Iir_Kind_Interface_Constant_Declaration .. +   --Iir_Kind_Interface_Variable_Declaration +   --Iir_Kind_Interface_Signal_Declaration +     Iir_Kind_Interface_File_Declaration;     subtype Iir_Kinds_Object_Declaration is Iir_Kind range       Iir_Kind_Object_Alias_Declaration .. @@ -4284,10 +4318,10 @@ package Iirs is     --Iir_Kind_Variable_Declaration     --Iir_Kind_Constant_Declaration     --Iir_Kind_Iterator_Declaration -   --Iir_Kind_Constant_Interface_Declaration -   --Iir_Kind_Variable_Interface_Declaration -   --Iir_Kind_Signal_Interface_Declaration -     Iir_Kind_File_Interface_Declaration; +   --Iir_Kind_Interface_Constant_Declaration +   --Iir_Kind_Interface_Variable_Declaration +   --Iir_Kind_Interface_Signal_Declaration +     Iir_Kind_Interface_File_Declaration;     subtype Iir_Kinds_Branch_Quantity_Declaration is Iir_Kind range       Iir_Kind_Across_Quantity_Declaration .. @@ -4305,10 +4339,10 @@ package Iirs is     --Iir_Kind_Variable_Declaration     --Iir_Kind_Constant_Declaration     --Iir_Kind_Iterator_Declaration -   --Iir_Kind_Constant_Interface_Declaration -   --Iir_Kind_Variable_Interface_Declaration -   --Iir_Kind_Signal_Interface_Declaration -     Iir_Kind_File_Interface_Declaration; +   --Iir_Kind_Interface_Constant_Declaration +   --Iir_Kind_Interface_Variable_Declaration +   --Iir_Kind_Interface_Signal_Declaration +     Iir_Kind_Interface_File_Declaration;     subtype Iir_Kinds_Association_Element is Iir_Kind range       Iir_Kind_Association_Element_By_Expression .. @@ -4515,10 +4549,10 @@ package Iirs is     --Iir_Kind_Variable_Declaration     --Iir_Kind_Constant_Declaration     --Iir_Kind_Iterator_Declaration -   --Iir_Kind_Constant_Interface_Declaration -   --Iir_Kind_Variable_Interface_Declaration -   --Iir_Kind_Signal_Interface_Declaration -     Iir_Kind_File_Interface_Declaration; +   --Iir_Kind_Interface_Constant_Declaration +   --Iir_Kind_Interface_Variable_Declaration +   --Iir_Kind_Interface_Signal_Declaration +     Iir_Kind_Interface_File_Declaration;     -------------------------------------     -- Types and subtypes declarations -- @@ -4760,7 +4794,7 @@ package Iirs is     subtype Iir_Architecture_Body is Iir; -   subtype Iir_Signal_Interface_Declaration is Iir; +   subtype Iir_Interface_Signal_Declaration is Iir;     subtype Iir_Configuration_Declaration is Iir; @@ -4793,11 +4827,11 @@ package Iirs is     subtype Iir_Iterator_Declaration is Iir; -   subtype Iir_Constant_Interface_Declaration is Iir; +   subtype Iir_Interface_Constant_Declaration is Iir; -   subtype Iir_Variable_Interface_Declaration is Iir; +   subtype Iir_Interface_Variable_Declaration is Iir; -   subtype Iir_File_Interface_Declaration is Iir; +   subtype Iir_Interface_File_Declaration is Iir;     subtype Iir_Guard_Signal_Declaration is Iir; @@ -5736,7 +5770,7 @@ package Iirs is     --  from this list, since the purpose of this list is to correctly set     --  flags for side effects (purity_state, wait_state).     --  Can return null_iir if there is no subprogram called. -   --  Field: Field7 (uc) +   --  Field: Field7 Of_Ref (uc)     function Get_Callees_List (Proc : Iir) return Iir_List;     procedure Set_Callees_List (Proc : Iir; List : Iir_List); @@ -5937,8 +5971,8 @@ package Iirs is     procedure Set_Block_Header (Target : Iir; Header : Iir);     --  Field: Field5 -   function Get_Uninstantiated_Name (Inst : Iir) return Iir; -   procedure Set_Uninstantiated_Name (Inst : Iir; Name : Iir); +   function Get_Uninstantiated_Package_Name (Inst : Iir) return Iir; +   procedure Set_Uninstantiated_Package_Name (Inst : Iir; Name : Iir);     --  Get/Set the block_configuration (there may be several     --  block_configuration through the use of prev_configuration singly linked @@ -6098,6 +6132,11 @@ package Iirs is     function Get_Actual_Type (Target : Iir) return Iir;     procedure Set_Actual_Type (Target : Iir; Atype : Iir); +   --  Interface for a package association. +   --  Field: Field4 Ref +   function Get_Associated_Interface (Assoc : Iir) return Iir; +   procedure Set_Associated_Interface (Assoc : Iir; Inter : Iir); +     --  List of individual associations for association_element_by_individual.     --  Associations for parenthesis_name.     --  Field: Field2 Chain diff --git a/iirs_utils.adb b/iirs_utils.adb index 172b0c306..52c1ee8bb 100644 --- a/iirs_utils.adb +++ b/iirs_utils.adb @@ -149,14 +149,14 @@ package body Iirs_Utils is        loop           case Get_Kind (Adecl) is              when Iir_Kind_Variable_Declaration -              | Iir_Kind_Variable_Interface_Declaration => +              | Iir_Kind_Interface_Variable_Declaration =>                 return Adecl;              when Iir_Kind_Constant_Declaration -              | Iir_Kind_Constant_Interface_Declaration => +              | Iir_Kind_Interface_Constant_Declaration =>                 return Adecl;              when Iir_Kind_Signal_Declaration                | Iir_Kind_Guard_Signal_Declaration -              | Iir_Kind_Signal_Interface_Declaration => +              | Iir_Kind_Interface_Signal_Declaration =>                 return Adecl;              when Iir_Kind_Object_Alias_Declaration =>                 --  LRM 4.3.3.1 Object Aliases @@ -190,14 +190,14 @@ package body Iirs_Utils is        loop           case Get_Kind (Adecl) is              when Iir_Kind_Variable_Declaration -              | Iir_Kind_Variable_Interface_Declaration +              | Iir_Kind_Interface_Variable_Declaration                | Iir_Kind_Constant_Declaration -              | Iir_Kind_Constant_Interface_Declaration +              | Iir_Kind_Interface_Constant_Declaration                | Iir_Kind_Signal_Declaration                | Iir_Kind_Guard_Signal_Declaration -              | Iir_Kind_Signal_Interface_Declaration +              | Iir_Kind_Interface_Signal_Declaration                | Iir_Kind_File_Declaration -              | Iir_Kind_File_Interface_Declaration +              | Iir_Kind_Interface_File_Declaration                | Iir_Kind_Iterator_Declaration =>                 return Adecl;              when Iir_Kind_Object_Alias_Declaration => @@ -249,7 +249,7 @@ package body Iirs_Utils is           case Get_Kind (Formal) is              when Iir_Kind_Simple_Name =>                 return Get_Named_Entity (Formal); -            when Iir_Kinds_Interface_Declaration => +            when Iir_Kinds_Interface_Object_Declaration =>                 return Formal;              when Iir_Kind_Slice_Name                | Iir_Kind_Indexed_Name @@ -408,21 +408,38 @@ package body Iirs_Utils is        return String (Ptr (1 .. Len));     end Image_String_Lit; +   function Copy_Enumeration_Literal (Lit : Iir) return Iir +   is +      Res : Iir; +   begin +      Res := Create_Iir (Iir_Kind_Enumeration_Literal); +      Set_Identifier (Res, Get_Identifier (Lit)); +      Location_Copy (Res, Lit); +      Set_Parent (Res, Get_Parent (Lit)); +      Set_Type (Res, Get_Type (Lit)); +      Set_Enum_Pos (Res, Get_Enum_Pos (Lit)); +      Set_Expr_Staticness (Res, Locally); +      Set_Enumeration_Decl (Res, Lit); +      return Res; +   end Copy_Enumeration_Literal; +     procedure Create_Range_Constraint_For_Enumeration_Type       (Def : Iir_Enumeration_Type_Definition)     is        Range_Expr : Iir_Range_Expression; -      Literal_List: Iir_List; +      Literal_List : constant Iir_List := Get_Enumeration_Literal_List (Def);     begin -      Literal_List := Get_Enumeration_Literal_List (Def); -        --  Create a constraint.        Range_Expr := Create_Iir (Iir_Kind_Range_Expression);        Location_Copy (Range_Expr, Def);        Set_Type (Range_Expr, Def);        Set_Direction (Range_Expr, Iir_To); -      Set_Left_Limit (Range_Expr, Get_First_Element (Literal_List)); -      Set_Right_Limit (Range_Expr, Get_Last_Element (Literal_List)); +      Set_Left_Limit +        (Range_Expr, +         Copy_Enumeration_Literal (Get_First_Element (Literal_List))); +      Set_Right_Limit +        (Range_Expr, +         Copy_Enumeration_Literal (Get_Last_Element (Literal_List)));        Set_Expr_Staticness (Range_Expr, Locally);        Set_Range_Constraint (Def, Range_Expr);     end Create_Range_Constraint_For_Enumeration_Type; @@ -492,9 +509,9 @@ package body Iirs_Utils is              return;           when Iir_Kind_Selected_Name =>              Free_Recursive (Get_Prefix (N)); -         when Iir_Kind_Constant_Interface_Declaration -           | Iir_Kind_Variable_Interface_Declaration -           | Iir_Kind_Signal_Interface_Declaration => +         when Iir_Kind_Interface_Constant_Declaration +           | Iir_Kind_Interface_Variable_Declaration +           | Iir_Kind_Interface_Signal_Declaration =>              Free_Recursive (Get_Type (N));              Free_Recursive (Get_Default_Value (N));           when Iir_Kind_Range_Expression => @@ -557,6 +574,20 @@ package body Iirs_Utils is        end loop;     end Mark_Subprogram_Used; +   function Get_Callees_List_Holder (Subprg : Iir) return Iir is +   begin +      case Get_Kind (Subprg) is +         when Iir_Kind_Procedure_Declaration +           | Iir_Kind_Function_Declaration => +            return Get_Subprogram_Body (Subprg); +         when Iir_Kind_Sensitized_Process_Statement +           | Iir_Kind_Process_Statement => +            return Subprg; +         when others => +            Error_Kind ("get_callees_list_holder", Subprg); +      end case; +   end Get_Callees_List_Holder; +     procedure Clear_Seen_Flag (Top : Iir)     is        Callees_List : Iir_Callees_List; @@ -564,7 +595,7 @@ package body Iirs_Utils is     begin        if Get_Seen_Flag (Top) then           Set_Seen_Flag (Top, False); -         Callees_List := Get_Callees_List (Top); +         Callees_List := Get_Callees_List (Get_Callees_List_Holder (Top));           if Callees_List /= Null_Iir_List then              for I in Natural loop                 El := Get_Nth_Element (Callees_List, I); @@ -1040,7 +1071,7 @@ package body Iirs_Utils is        Adecl := Get_Object_Prefix (Name, True);        case Get_Kind (Adecl) is           when Iir_Kind_Signal_Declaration -           | Iir_Kind_Signal_Interface_Declaration +           | Iir_Kind_Interface_Signal_Declaration             | Iir_Kind_Guard_Signal_Declaration             | Iir_Kinds_Signal_Attribute =>              return True; diff --git a/iirs_utils.ads b/iirs_utils.ads index e77e5723e..a588ab870 100644 --- a/iirs_utils.ads +++ b/iirs_utils.ads @@ -63,6 +63,9 @@ package Iirs_Utils is     --  an interface, even if the formal is a name.     function Get_Association_Interface (Assoc : Iir) return Iir; +   --  Duplicate enumeration literal LIT. +   function Copy_Enumeration_Literal (Lit : Iir) return Iir; +     --  Make TARGETS depends on UNIT.     --  UNIT must be either a design unit or a entity_aspect_entity.     procedure Add_Dependence (Target: Iir_Design_Unit; Unit: Iir); @@ -89,6 +92,10 @@ package Iirs_Utils is     procedure Create_Range_Constraint_For_Enumeration_Type       (Def : Iir_Enumeration_Type_Definition); +   --  Return the node containing the Callees_List (ie the subprogram body if +   --  SUBPRG is a subprogram spec, SUBPRG if SUBPRG is a process). +   function Get_Callees_List_Holder (Subprg : Iir) return Iir; +     --  Clear flag of TOP and all of its callees.     procedure Clear_Seen_Flag (Top : Iir); diff --git a/libraries/Makefile.inc b/libraries/Makefile.inc index ab29cfbec..8979f243b 100644 --- a/libraries/Makefile.inc +++ b/libraries/Makefile.inc @@ -57,9 +57,9 @@ ieee2008/numeric_std.vhdl ieee2008/numeric_std-body.vhdl \  ieee2008/numeric_std_unsigned.vhdl ieee2008/numeric_std_unsigned-body.vhdl \  ieee2008/fixed_float_types.vhdl \  ieee2008/fixed_generic_pkg.vhdl ieee2008/fixed_generic_pkg-body.vhdl \ -ieee2008/fixed_pkg.vhdl -#ieee2008/float_generic_pkg.vhdl ieee2008/float_generic_pkg-body.vhdl \ -#ieee2008/float_pkg.vhdl +ieee2008/fixed_pkg.vhdl \ +ieee2008/float_generic_pkg.vhdl ieee2008/float_generic_pkg-body.vhdl \ +ieee2008/float_pkg.vhdl  STD87_BSRCS := $(STD_SRCS:.vhdl=.v87)  STD93_BSRCS := $(STD_SRCS:.vhdl=.v93) diff --git a/libraries/ieee2008/float_generic_pkg-body.vhdl b/libraries/ieee2008/float_generic_pkg-body.vhdl index 635454675..2100f4ad0 100644 --- a/libraries/ieee2008/float_generic_pkg-body.vhdl +++ b/libraries/ieee2008/float_generic_pkg-body.vhdl @@ -370,12 +370,13 @@ package body float_generic_pkg is      arg : UNRESOLVED_float)             -- fp vector      return STD_ULOGIC_VECTOR    is +    subtype result_subtype is STD_ULOGIC_VECTOR (arg'length-1 downto 0);      variable result : STD_ULOGIC_VECTOR (arg'length-1 downto 0);    begin  -- function to_std_ulogic_vector      if arg'length < 1 then        return NSLV;      end if; -    result := STD_ULOGIC_VECTOR (arg); +    result := result_subtype (arg);      return result;    end function to_sulv; @@ -2739,7 +2740,7 @@ package body float_generic_pkg is    -- to_float (unsigned)    function to_float ( -    arg                     : UNSIGNED; +    arg                     : UNRESOLVED_UNSIGNED;      constant exponent_width : NATURAL    := float_exponent_width;  -- length of FP output exponent      constant fraction_width : NATURAL    := float_fraction_width;  -- length of FP output fraction      constant round_style    : round_type := float_round_style)  -- rounding option @@ -2764,7 +2765,7 @@ package body float_generic_pkg is    -- to_float (signed)    function to_float ( -    arg                     : SIGNED; +    arg                     : UNRESOLVED_SIGNED;      constant exponent_width : NATURAL    := float_exponent_width;  -- length of FP output exponent      constant fraction_width : NATURAL    := float_fraction_width;  -- length of FP output fraction      constant round_style    : round_type := float_round_style)  -- rounding option @@ -5073,7 +5074,8 @@ package body float_generic_pkg is      variable c      : CHARACTER;    begin      while L /= null and L.all'length /= 0 loop -      if (L.all(1) = ' ' or L.all(1) = NBSP or L.all(1) = HT) then +      c := l (l'left); +      if (c = ' ' or c = NBSP or c = HT) then          read (l, c, readOk);        else          exit; @@ -281,50 +281,11 @@ package Nodes is     procedure Initialize;  private     type Node_Record (Format : Format_Type := Format_Short) is record - -      --  Usages of Flag1: -      --  seen_flag for iir_kind_process_statement -      --  seen_flag for iir_kind_sensitized_process_statement -      --  seen_flag for iir_kinds_procedure_specification -      --  seen_flag for iir_kinds_function_specification -      --  seen_flag for iir_kind_design_file -      --  deferred_declaration_flag for iir_kind_constant_declaration -      --  loaded_flag for iir_kind_design_unit -      --  resolved_flag for iir_kinds_type_definition -      --  need_body for iir_kind_package_declaration -      --  whole_association_flag for iir_kind_association_element_by_expression -      --  has_disconnect_flag for iir_kind_signal_declaration        Flag1 : Boolean := False; - -      --  Usages of Flag2: -      --  pure_flag for iir_kinds_function_specification -      --  passive_flag for iir_kinds_process_statement -      --  shared_flag for iir_kind_variable_declaration -      --  aggr_others_flag for iir_kind_aggregate_info -      --  signal_type_flag for iir_kinds_type_definition        Flag2 : Boolean := False; - -      --  Usages of Flag3: -      --  (postponed_flag for iir_kinds_process_statement) -      --  elab_flag for iir_kind_design_file -      --  elab_flag for iir_kind_design_unit -      --  dynamic_flag for iir_kind_aggregate_info -      --  text_file_flag for iir_kind_file_type_definition -      --  foreign_flag for iir_kind_architecture_declaration -      --  foreign_flag for iir_kinds_function_specification -      --  foreign_flag for iir_kinds_procedure_specification        Flag3 : Boolean := False; - -      --  Usages of Flag4: -      --  visible_flag for iir_kind_type_declaration -      --  aggr_named_flag for iir_kind_aggregate_info        Flag4 : Boolean := False; - -      --  Usages of Flag5: -      --  is_within_flag for named entities        Flag5 : Boolean := False; - -      --  Usages of Flag6:        Flag6 : Boolean := False;        --  Kind field use 8 bits. @@ -336,512 +297,26 @@ private        Kind : Kind_Type; -      -- expr_staticness for iir_kind_string_literal -      -- expr_staticness for iir_kind_bit_string_literal -      -- expr_staticness for iir_kind_integer_literal -      -- expr_staticness for iir_kind_floating_point_literal -      -- expr_staticness for iir_kind_physical_int_literal -      -- expr_staticness for iir_kind_physical_fp_literal -      -- expr_staticness for iir_kind_enumeration_literal -      -- expr_staticness for iir_kind_monadic_operator -      -- expr_staticness for iir_kind_dyadic_operator -      -- expr_staticness for iir_kinds_name -      -- expr_staticness for iir_kinds_alias_declaration -      -- expr_staticness for iir_kind_constant_declaration -      -- expr_staticness for iir_kind_iterator_declaration -      -- expr_staticness for iir_kind_constant_interface_declaration -      -- expr_staticness for iir_kind_aggregate -      -- expr_staticness for iir_kind_qualified_expression -      -- expr_staticness for iir_kind_type_conversion -      -- expr_staticness for iir_kind_length_array_attribute -      -- expr_staticness for iir_kind_low_type_attribute -      -- expr_staticness for iir_kind_high_type_attribute -      -- expr_staticness for iir_kind_left_type_attribute -      -- expr_staticness for iir_kind_right_type_attribute -      -- expr_staticness for iir_kind_pos_attribute -      -- expr_staticness for iir_kind_val_attribute -      -- expr_staticness for iir_kind_event_attribute -      -- expr_staticness for iir_kind_last_value_attribute -      -- expr_staticness for iir_kind_last_active_attribute -      -- expr_staticness for iir_kind_active_attribute -      -- expr_staticness for iir_kind_range_expression -      -- expr_staticness for iir_kind_selected_element -      -- expr_staticness for iir_kind_function_call -      -- expr_staticness for iir_kind_attribute_value -      -- expr_staticness for iir_kind_signal_declaration -      -- expr_staticness for iir_kind_guard_signal_declaration -      -- expr_staticness for iir_kind_variable_declaration -      -- expr_staticness for iir_kind_file_declaration -      -- expr_staticness for iir_kinds_discrete_type_attribute -      -- type_staticness for iir_kinds_type_and_subtype_definition        State1 : Bit2_Type := 0; - -      -- name_staticness for iir_kinds_name -      -- name_staticness for iir_kind_object_alias_declaration -      -- name_staticness for iir_kind_selected_element -      -- name_staticness for iir_kind_selected_by_all_name -      -- choice_staticness for iir_kind_choice_by_range -      -- choice_staticness for iir_kind_choice_by_expression        State2 : Bit2_Type := 0; -        Flag7 : Boolean := False;        Flag8 : Boolean := False;        Flag9 : Boolean := False;        Flag10 : Boolean := False; +        Flag11 : Boolean := False;        Flag12 : Boolean := False; - -      -- 3bits fields (1 -> 3 bits) -      --  Usages of odigit1: -      --  lexical_layout for iir_kinds_interface_declaration -      --  iir_mode        Odigit1 : Bit3_Type := 0; -        Unused_Odigit2 : Bit3_Type := 0;        -- Location.        Location: Location_Type := Location_Nil; -      --  The parent node. -      -- parent for iir_kind_if_statement -      -- parent for iir_kind_elsif_statement -      -- parent for iir_kind_for_loop_statement -      -- parent for iir_kind_while_loop_statement -      -- parent for iir_kind_case_statement -      -- parent for iir_kind_exit_statement -      -- parent for iir_kind_next_statement -      -- parent (library_declaration) for iir_kind_design_file -      -- parent (design_unit_list) for iir_kind_design_file -      -- interface_parent for iir_kind_signal_interface_declaration -      -- interface_parent for iir_kind_constant_interface_declaration -      -- interface_parent for iir_kind_variable_interface_declaration -      -- interface_parent for iir_kind_file_interface_declaration        Field0 : Node_Type := Null_Node; - -      -- usages of field1: -      -- type for iir_kind_character_literal -      -- type for iir_kind_type_computed_literal -      -- type for iir_kind_integer_literal -      -- type for iir_kind_floating_point_literal -      -- type for iir_type_declaration. -      -- type for iir_subtype_declaration. -      -- type for iir_kind_identifier -      -- type for iir_kind_string_literal -      -- type for iir_kind_bit_string_literal -      -- type for iir_kind_base_attribute -      -- list_element for iir_kinds_list -      -- port_chain for iir_kind_entity_declaration -      -- port_chain for iir_kind_component_declaration -      -- port_chain for iir_kind_block_header -      -- entity for iir_kind_architecture_declaration -      -- entity for iir_kind_configuration_declaration -      -- entity for iir_kind_entity_aspect_entity -      -- package for iir_kind_package_body -      -- primary_units(iir_library_unit_list) for iir_kind_library_declaration -      -- selected_name for iir_kind_use_clause -      -- type_declaration for iir_kinds_type_definition -      -- type_definition for iir_kind_signal_declaration -      -- type_definition for iir_kind_guard_signal_declaration -      -- type_definition for iir_kind_signal_interface_declaration. -      -- type_definition for iir_kind_variable_declaration -      -- type_definition for iir_kind_variable_interface_declaration. -      -- type_definition for iir_kind_constant_declaration -      -- type_definition for iir_kind_iterator_declaration -      -- type_definition for iir_kind_constant_interface_declaration. -      -- type_definition for iir_kind_file_declaration -      -- type_definition for iir_kind_file_interface_declaration. -      -- type_definition for iir_kind_enumeration_literal -      -- type_definition for iir_kind_unit_declaration -      -- type_definition for iir_kind_component_port -      -- type_definition for iir_kind_element_declaration -      -- type_definition for iir_kinds_attribute_declaration -      -- type_definition for iir_kinds_attribute -      -- type_definition for iir_kinds_name -      -- type_definition for iir_kind_return_statement -      -- type_definition for iir_kind_aggregate -      -- type_definition for iir_kind_physical_int_literal -      -- type_definition for iir_kind_physical_fp_literal -      -- type_definition for iir_kind_object_alias_declaration -      -- type_definition for iir_kind_null_literal -      -- type_definition for iir_kind_qualified_expression -      -- type_definition for iir_kind_type_conversion -      -- type_definition for iir_kind_function_call -      -- type_definition for iir_kind_allocator_by_expression -      -- type_definition for iir_kind_allocator_by_subtype -      -- type_definition for iir_kind_attribute_value -      -- type_definition for iir_kind_selected_element -      -- type_definition for iir_kind_implicit_dereference. -      -- type_definition for iir_kind_disconnection_specification -      -- type_definition for iir_kinds_monadic_operator -      -- type_definition for iir_kinds_dyadic_operator -      -- null_iir for iir_kind_signal_assignment_statement -      -- null_iir for iir_kind_variable_assignment_statement -      -- we_value for iir_kind_waveform_element -      -- condition for iir_kind_conditional_waveform -      -- condition for iir_kind_if_statement -      -- condition for iir_kind_elsif -      -- condition for iir_kind_while_loop_statement -      -- condition for iir_kind_next_statement -      -- condition for iir_kind_exit_statement -      -- design_unit_chain for iir_kind_design_file -      -- formal for iir_kinds_association_element -      -- iterator_scheme for iir_kind_for_loop_statement -      -- associated for iir_kinds_association_by_choice -      -- context_items for iir_kind_design_unit -      -- design_file_chain for iir_kind_library_declaration -      -- proxy for iir_kind_proxy -      -- selected_waveform_l for iir_kind_concurrent_selected_signal_assignment -      -- block_specification for iir_kind_block_configuration -      -- instantiation_list for iir_kind_component_configuration -      -- instantiation_list for iir_kind_configuration_specification -      -- component_configuration for iir_kind_component_instantiation_statement -      -- configuration for iir_kind_entity_aspect_configuration -      -- guard_decl for iir_kind_block_statement -      -- entity_class_entry_chain for iir_kind_group_template_declaration -      -- group_constituent_chain for iir_kind_group_declaration -      -- entity_name_list for iir_kind_attribute_specification -      -- generate_block_configuration for iir_kind_generate_statement -      -- type_declarator for Iir_Kind_Enumeration_Type_Definition -      -- type_declarator for Iir_Kind_Enumeration_Subtype_Definition -      -- type_declarator for Iir_Kind_Integer_Type_Definition -      -- type_declarator for Iir_Kind_Integer_Subtype_Definition -      -- type_declarator for Iir_Kind_Floating_Type_Definition -      -- type_declarator for Iir_Kind_Floating_Subtype_Definition -      -- type_declarator for Iir_Kind_Physical_Type_Definition -      -- type_declarator for Iir_Kind_Physical_Subtype_Definition -      -- type_declarator for Iir_Kind_Record_Type_Definition -      -- type_declarator for Iir_Kind_Record_Subtype_Definition -      -- type_declarator for Iir_Kind_Array_Type_Definition -      -- type_declarator for Iir_Kind_Array_Subtype_Definition -      -- type_declarator for Iir_Kind_Unconstrained_Array_Subtype_Definition -      -- type_declarator for Iir_Kind_Access_Type_Definition -      -- type_declarator for Iir_Kind_Access_Subtype_Definition -      -- type_declarator for Iir_Kind_Incomplete_Type_Definition -      -- type_declarator for Iir_Kind_File_Type_Definition -      -- return_type for iir_kind_function_specification -      -- return_type for iir_kind_function_spec_body -      -- return_type for iir_kind_implicit_function_declaration -      -- default_entity_aspect for iir_kind_binding_indication -      -- sub_aggregate_info for iir_kind_aggregate_info        Field1: Node_Type := Null_Node; - -      -- usages of field2: -      -- concurrent_statement_list for iir_kind_architecture_declaration -      -- concurrent_statement_list for iir_kind_block_statement -      -- concurrent_statement_list for iir_kind_entity_declaration -      -- concurrent_statement_list for iir_kind_generate_statement -      -- block_configuration for iir_kind_configuration_declaration -      -- block_configuration for iir_kind_component_configuration -      -- subprogram_body for iir_kind_function_specification -      -- subprogram_body for iir_kind_procedure_specification -      -- range_constraint for iir_kind_integer_subtype_definition -      -- range_constraint for iir_kind_floating_subtype_definition -      -- range_constraint for iir_kind_subtype_definition -      -- range_constraint for iir_kind_enumeration_subtype_definition -      -- range_constraint for iir_kind_physical_subtype_definition -      -- range_constraint for iir_kind_enumeration_type_definition -      -- left_limit for iir_kind_range_expression -      -- designated_type for iir_kind_access_type_definition -      -- index_subtype for iir_array_type_definition -      -- index_subtype for iir_array_subtype_definition -      -- suffix for iir_kinds_attribute -      -- suffix for iir_kind_user_attribute -      -- suffix for iir_kind_slice_name -      -- selected_element for iir_kind_selected_element -      -- parameter for iir_kind_val_attribute -      -- parameter for iir_kind_pos_attribute -      -- parameter for iir_kind_delayed_attribute -      -- parameter for iir_kind_stable_attribute -      -- parameter for iir_kind_quiet_attribute -      -- parameter for iir_kind_attribute -      -- index_list for iir_kind_indexed_name -      -- index_list for iir_kind_array_type_definition -      -- index_list for iir_kind_array_subtype_definition -      -- target for iir_kind_signal_assignment_statement -      -- target for iir_kind_variable_assignment_statement -      -- time for iir_kind_waveform_element -      -- target for iir_kind_concurrent_conditional_signal_assignment -      -- target for iir_kind_concurrent_selected_signal_assignment -      -- assertion_condition for iir_kind_concurrent_assertion_statement -      -- assertion_condition for iir_kind_assertion_statement -      -- null_iir for iir_kind_conditional_waveform -      -- sequential_statement_chain for iir_kind_if_statement -      -- sequential_statement_chain for iir_kind_elsif -      -- sequential_statement_chain for iir_kind_sensitized_process_statement -      -- sequential_statement_chain for iir_kind_process_statement -      -- sequential_statement_chain for iir_kind_for_loop_statement -      -- sequential_statement_chain for iir_kind_while_loop_statement -      -- sequential_statement_chain for iir_kind_function_Body -      -- sequential_statement_chain for iir_kind_function_Spec_Body -      -- sequential_statement_chain for iir_kind_procedure_Body -      -- sequential_statement_chain for iir_kind_procedure_Spec_Body -      -- name for iir_kind_object_alias_declaration -      -- name for iir_kind_physical_int_literal -      -- name for iir_kind_physical_fp_literal -      -- name for iir_kind_association_choice_by_name -      -- name for iir_kind_group_declaration -      -- default_value for iir_kind_signal_declaration -      -- default_value for iir_kind_guard_signal_declaration -      -- default_value for iir_kind_variable_declaration -      -- default_value for iir_kind_constant_declaration -      -- default_value for iir_kind_signal_interface_declaration -      -- default_value for iir_kind_variable_interface_declaration -      -- default_value for iir_kind_constant_interface_declaration -      -- default_value for iir_kind_file_interface_declaration -      -- guard_expression for iir_kind_guard_signal_declaration -      -- operand for iir_kinds_monadic_operator -      -- left for iir_kinds_dyadic_operator -      -- actual for iir_kind_association_element_by_expression -      -- instantiated_unit for Iir_Kind_Component_Instantiation_Statement -      -- parameter_association_chain for iir_kind_function_call -      -- parameter_association_chain for iir_kind_procedure_call -      -- parameter_association_chain for iir_kind_concurrent_procedure_call_st. -      -- library_unit for iir_kind_design_unit -      -- multiplier for iir_kind_unit_declaration -      -- primary_unit for iir_kind_physical_type_definition -      -- condition_clause for iir_kind_wait_statement -      -- element_declaration_list for iir_kind_record_type_definition -      -- loop for iir_kind_exit_statement -      -- loop for iir_kind_next_statement -      -- file_logical_name for iir_kind_file_declaration -      -- configuration_item_chain for iir_kind_block_configuration -      -- architecture for iir_kind_entity_aspect_entity -      -- library_declaration for iir_kind_library_clause -      -- attribute_designator for iir_kind_attribute_specification -      -- attribute_specification for iir_kind_attribute_value -      -- signal_list for iir_kind_disconnection_specification -      -- generation_scheme for iir_kind_generate_statement -      -- incomplete_type_List for iir_kind_incomplete_type_definition -      -- file_time_stamp for iir_kind_design_file -      -- default_generic_map_aspect_list for iir_kind_binding_indication -      -- aggr_low_limit for iir_kind_aggregate_info -      -- enumeration_decl for iir_kind_enumeration_literal -      -- simple_aggregate_list for iir_kind_simple_aggregate        Field2: Node_Type := Null_Node; - -      -- Usages of field3: -      -- dependence_list for iir_kind_design_unit -      -- block_statement for iir_kind_signal_declaration -      -- block_statement for iir_kind_guard_signal_declaration -      -- subprogram_declaration for iir_kind_function_Spec_Body -      -- subprogram_declaration for iir_kind_function_Body -      -- subprogram_declaration for iir_kind_Procedure_Spec_Body -      -- subprogram_declaration for iir_kind_Procedure_Body -      -- body for iir_kind_function_specification -      -- body for iir_kind_procedure_specification -      -- declaration_list for iir_kind_entity_declaration -      -- declaration_list for iir_kind_architecture_declaration -      -- declaration_list for iir_kind_configuration_declaration -      -- declaration_list for iir_kind_block_statement -      -- declaration_list for iir_kind_package_declaration -      -- declaration_list for iir_kind_package_body -      -- declaration_list for iir_kind_sensitized_process_statement -      -- declaration_list for iir_kind_process_statement -      -- declaration_list for iir_kind_block_configuration -      -- declaration_list for iir_kind_generate_statement -      -- enumeration_literal_list for iir_enumeration_type_definition -      -- right_limit for iir_kind_range_expression -      -- element_subtype for iir_array_type_definition -      -- element_subtype for iir_array_subtype_definition -      -- report_expression for iir_kind_concurrent_assertion_statement -      -- report_expression for iir_kind_assertion_statement -      -- report_expression for iir_kind_report_statement -      -- waveform_chain for iir_kind_signal_assignment_statement -      -- conditional_waveform_chain for iir_kind_conc_conditional_signal_assign -      -- waveform_chain for iir_kind_conditional_waveform -      -- else_clause for iir_kind_if_statement -      -- else_clause for iir_kind_elsif -      -- expression of iir_kind_concurrent_selected_signal_assignment -      -- expression of iir_kind_variable_assignment_statement -      -- prefix for iir_kinds_attribute -      -- prefix for iir_kind_indexed_name -      -- prefix for iir_kind_slice_name -      -- prefix for iir_kind_selected_name -      -- prefix for iir_kind_selected_by_all_name -      -- prefix for iir_kind_parenthesis_name -      -- prefix for iir_kind_selected_element -      -- prefix for iir_kind_implicit_dereference -      -- port_map_aspect for Iir_Kind_Component_Instantiation_Statement -      -- port_map_aspect for Iir_Kind_binding_indication -      -- port_map_aspect for Iir_Kind_block_header -      -- binding_indication for iir_kind_Component_configuration -      -- binding_indication for Iir_Kind_Configuration_specifiation -      -- expression for iir_kind_return_statement -      -- expression for iir_kind_association_choice_by_expression -      -- expression for iir_kind_case_statement -      -- expression for iir_kind_qualified_expression -      -- expression for iir_kind_type_conversion -      -- expression for iir_kind_allocator_by_expression -      -- expression for iir_kind_allocator_by_subtype -      -- expression for iir_kind_attribute_specification -      -- expression for iir_kind_disconnection_specification -      -- unit_chain for iir_kind_physical_type_definition -      -- timeout_clause for iir_kind_wait_statement -      -- file_open_kind for iir_kind_file_declaration -      -- designated_entity for iir_kind_attribute_value -      -- associated_formal for iir_kinds_association_element -      -- deferred_declaration for iir_kind_constant_declaration -      -- literal_origin for iir_kind_character_literal -      -- literal_origin for iir_kind_string_literal -      -- literal_origin for iir_kind_bit_string_literal -      -- literal_origin for iir_kind_integer_literal -      -- literal_origin for iir_kind_floating_point_literal -      -- literal_origin for iir_kind_physical_int_literal -      -- literal_origin for iir_kind_physical_fp_literal -      -- literal_origin for iir_kind_enumeration_literal -      -- analysis_time_stamp for iir_kind_design_file -      -- aggr_high_limit for iir_kind_aggregate_info -      -- aggregate_info for iir_kind_aggregate -      -- implementation for iir_kind_function_call -      -- implementation for iir_kind_procedure_call -      -- implementation for iir_kind_concurrent_procedure_call_statement -      -- implementation for iir_kind_dyadic_operator -      -- implementation for iir_kind_monadic_operator        Field3: Node_Type := Null_Node; -      -- Usages of field4: -      -- design_file for iir_kind_design_unit -      -- generic_chain for iir_kind_entity_declaration -      -- generic_chain for iir_kind_component_declaration -      -- generic_chain for iir_kind_block_header -      -- base_type for iir_kind_integer_type_definition -      -- base_type for iir_kind_integer_subtype_definition -      -- base_type for iir_kind_floating_type_definition -      -- base_type for iir_kind_floating_subtype_definition -      -- base_type for iir_kind_subtype_definition -      -- base_type for iir_kind_enumeration_type_definition -      -- base_type for iir_kind_enumeration_subtype_definition -      -- base_type for iir_kind_array_type_definition -      -- base_type for iir_kind_array_subtype_definition -      -- base_type for iir_kind_unconstrained_array_subtype_definition -      -- base_type for iir_kind_range_attribute -      -- base_type for iir_kind_physical_type_definition -      -- base_type for iir_kind_physical_subtype_definition -      -- base_type for iir_kind_record_type_definition -      -- base_type for iir_kind_record_subtype_definition -      -- base_type for iir_kind_access_type_definition -      -- base_type for iir_kind_access_subtype_definition -      -- base_type for iir_kind_incomplete_type_definition -      -- base_type for iir_kind_file_type_definition -      -- severity_expression for iir_kind_concurrent_assertion_statement -      -- severity_expression for iir_kind_assertion_statement -      -- severity_expression for iir_kind_report_statement -      -- sensitivity_list for iir_kind_sensitized_process_statement -      -- sensitivity_list for iir_kind_wait_statement -      -- name_value of iir_kind_simple_name -      -- association_chain for iir_kind_association_element_by_individual -      -- association_chain for iir_kind_parenthesis_name -      -- association_choices_list for iir_kind_aggregate -      -- association_choices_list for iir_kind_case_statement -      -- guard for iir_kind_concurrent_conditional_signal_assignment -      -- guard for iir_kind_concurrent_selected_signal_assignment -      -- entity_aspect for iir_kind_binding_indication -      -- default_binding_indicat for iir_kind_component_instantiation_statement -      -- component_name for iir_kind_component_configuration -      -- component_name for iir_kind_configuration_specification -      -- prev_block_configuration for iir_kind_block_configuration -      -- interface_declaration for iir_kind_function_Specification -      -- interface_declaration for iir_kind_function_Spec_Body -      -- interface_declaration for iir_kind_procedure_Specification -      -- interface_declaration for iir_kind_procedure_Spec_Body -      -- interface_declaration for iir_kind_implicit_function_declaration -      -- interface_declaration for iir_kind_implicit_procedure_declaration -      -- subprogram_specification for iir_kind_function_Body -      -- subprogram_specification for iir_kind_procedure_Body -      -- in_conversion for iir_kind_association_element_by_expression -      -- default_configuration for iir_kind_architecture_declaration -      -- bit_string_0 for iir_kind_bit_string_literal -      -- base_name for iir_kind_object_alias_declaration -      -- base_name for iir_kind_signal_declaration -      -- base_name for iir_kind_guard_signal_declaration -      -- base_name for iir_kind_variable_declaration -      -- base_name for iir_kind_file_declaration -      -- base_name for iir_kind_constant_declaration -      -- base_name for iir_kind_iterator_declaration -      -- base_name for iir_kind_slice_name -      -- base_name for iir_kind_indexed_name -      -- base_name for iir_kind_selected_element -      -- base_name for iir_kind_selected_by_all_name -      -- base_name for iir_kind_implicit_dereference -      -- base_name for iir_kind_attribute_value -      -- base_name for iir_kind_function_call -      -- block_block_configuration for iir_kind_block_statement -      -- right for iir_kinds_dyadic_operator -      --Field4: Node_Type := Null_Node; - -      -- Usages of field5 (aka nbr1). -      -- driver_list for iir_kind_sensitized_process_statement -      -- driver_list for iir_kind_process_statement -      -- driver_list for iir_kinds_function_specification -      -- driver_list for iir_kinds_procedure_specification -      -- guard_sensitivity_list for iir_kind_guard_signal_declaration -      -- signal_driver for iir_kind_signal_declaration -      -- reject_time for iir_kind_concurrent_selected_signal_assignment -      -- reject_time for iir_kind_concurrent_conditionnal_signal_assignment -      -- reject_time for iir_kind_signal_assignment_statement -      -- resolution_function for iir_kind_integer_subtype_definition -      -- resolution_function for iir_kind_floating_subtype_definition -      -- resolution_function for iir_kind_enumeration_subtype_definition -      -- resolution_function for iir_kind_physical_subtype_definition -      -- resolution_function for iir_kind_array_subtype_definition -      -- resolution_function for iir_kind_unconstrained_array_subtype_definit. -      -- resolution_function for iir_kind_record_subtype_definition -      -- date for iir_kind_library_declaration -      -- date for iir_kind_design_unit -      -- generic_map_aspect for Iir_Kind_Component_Instantiation_Statement -      -- generic_map_aspect for Iir_Kind_block_header -      -- generic_map_aspect for Iir_Kind_binding_indication -      -- generation_scheme for iir_kind_generate_statement -      -- design_unit for iir_kind_constant_declaration -      -- design_unit for iir_kind_entity_declaration -      -- design_unit for iir_kind_configuration_declaration -      -- design_unit for iir_kind_package_declaration -      -- design_unit for iir_kind_body_declaration -      -- design_unit for iir_kind_architecture_declaration -      -- out_conversion for iir_kind_association_element_by_expression -      -- bit_string_1 for iir_kind_bit_string_literal -      --Field5: Node_Type := Null_Node; - -      -- Usages of Field6: -      -- offset for iir_kind_design_unit -      -- number of element for iir_kinds_list -      -- base for iir_kind_bit_string_literal -      -- element_position for iir_kind_element_declaration -      -- type_mark for iir_kind_qualified_expression -      -- type_mark for iir_kind_file_type_definition -      -- type_mark for iir_kind_integer_subtype_definition -      -- type_mark for iir_kind_floating_subtype_definition -      -- type_mark for iir_kind_enumeration_subtype_definition -      -- type_mark for iir_kind_physical_subtype_definition -      -- type_mark for iir_kind_access_subtype_definition -      -- type_mark for iir_kind_record_subtype_definition -      -- type_mark for iir_kind_unconstrained_array_subtype_definition -      -- bit_string_base for iir_kind_bit_string_literal -      -- default_port_map_aspect_list for iir_kind_binding_indication - -      -- Usages of nbr3/field7: -      -- line for iir_kind_design_unit -      -- max number of elements for iir_kinds_list -      -- implicit_definition for iir_kind_implicit_function_declaration -      -- implicit_definition for iir_kind_implicit_procedure_declaration -      -- block_header for iir_kind_block_statement -      -- delay_mechanism for iir_kind_concurrent_selected_signal_assignment -      -- delay_mechanism for iir_kind_concurrent_conditionnal_signal_assignment -      -- delay_mechanism for iir_kind_signal_assignment_statement -      -- value for iir_kind_integer_literal -      -- value for iir_kind_enumeration_literal -      -- value for iir_kind_unit_declaration -      -- value for iir_kind_physical_int_literal -      -- fp_value for iir_kind_physical_fp_literal -      -- fp_value for iir_kind_floating_point_literal -      -- entity_kind for iir_kind_entity_class -      -- entity_kind for iir_kind_attribute_specification -      -- callees_list for iir_kind_process_declaration -      -- callees_list for iir_kind_sensitized_process_declaration -      -- library_directory for iir_kind_library_declaration -      -- filename for iir_kind_design_file -      -- directory for iir_kind_design_file -      -- aggr_max_length for iir_kind_aggregate_info        case Format is           when Format_Short             | Format_Medium => diff --git a/nodes_gc.adb b/nodes_gc.adb index 65fe7f2b5..38966f27c 100644 --- a/nodes_gc.adb +++ b/nodes_gc.adb @@ -82,7 +82,7 @@ package body Nodes_GC is        end if;        case Get_Kind (N) is -         when Iir_Kind_Constant_Interface_Declaration => +         when Iir_Kind_Interface_Constant_Declaration =>              if Get_Identifier (N) = Null_Identifier then                 --  Anonymous interfaces are shared by predefined functions.                 return; diff --git a/nodes_meta.adb b/nodes_meta.adb index c84ff2337..3e038f549 100644 --- a/nodes_meta.adb +++ b/nodes_meta.adb @@ -214,7 +214,7 @@ package body Nodes_Meta is        Field_Block_Block_Configuration => Type_Iir,        Field_Package_Header => Type_Iir,        Field_Block_Header => Type_Iir, -      Field_Uninstantiated_Name => Type_Iir, +      Field_Uninstantiated_Package_Name => Type_Iir,        Field_Generate_Block_Configuration => Type_Iir,        Field_Generation_Scheme => Type_Iir,        Field_Condition => Type_Iir, @@ -247,6 +247,7 @@ package body Nodes_Meta is        Field_Index_Subtype => Type_Iir,        Field_Parameter => Type_Iir,        Field_Actual_Type => Type_Iir, +      Field_Associated_Interface => Type_Iir,        Field_Association_Chain => Type_Iir,        Field_Individual_Association_Chain => Type_Iir,        Field_Aggregate_Info => Type_Iir, @@ -704,8 +705,8 @@ package body Nodes_Meta is              return "package_header";           when Field_Block_Header =>              return "block_header"; -         when Field_Uninstantiated_Name => -            return "uninstantiated_name"; +         when Field_Uninstantiated_Package_Name => +            return "uninstantiated_package_name";           when Field_Generate_Block_Configuration =>              return "generate_block_configuration";           when Field_Generation_Scheme => @@ -770,6 +771,8 @@ package body Nodes_Meta is              return "parameter";           when Field_Actual_Type =>              return "actual_type"; +         when Field_Associated_Interface => +            return "associated_interface";           when Field_Association_Chain =>              return "association_chain";           when Field_Individual_Association_Chain => @@ -930,6 +933,8 @@ package body Nodes_Meta is              return "association_element_by_individual";           when Iir_Kind_Association_Element_Open =>              return "association_element_open"; +         when Iir_Kind_Association_Element_Package => +            return "association_element_package";           when Iir_Kind_Choice_By_Others =>              return "choice_by_others";           when Iir_Kind_Choice_By_Expression => @@ -1100,14 +1105,16 @@ package body Nodes_Meta is              return "constant_declaration";           when Iir_Kind_Iterator_Declaration =>              return "iterator_declaration"; -         when Iir_Kind_Constant_Interface_Declaration => -            return "constant_interface_declaration"; -         when Iir_Kind_Variable_Interface_Declaration => -            return "variable_interface_declaration"; -         when Iir_Kind_Signal_Interface_Declaration => -            return "signal_interface_declaration"; -         when Iir_Kind_File_Interface_Declaration => -            return "file_interface_declaration"; +         when Iir_Kind_Interface_Constant_Declaration => +            return "interface_constant_declaration"; +         when Iir_Kind_Interface_Variable_Declaration => +            return "interface_variable_declaration"; +         when Iir_Kind_Interface_Signal_Declaration => +            return "interface_signal_declaration"; +         when Iir_Kind_Interface_File_Declaration => +            return "interface_file_declaration"; +         when Iir_Kind_Interface_Package_Declaration => +            return "interface_package_declaration";           when Iir_Kind_Identity_Operator =>              return "identity_operator";           when Iir_Kind_Negation_Operator => @@ -1693,7 +1700,7 @@ package body Nodes_Meta is           when Field_Postponed_Flag =>              return Attr_None;           when Field_Callees_List => -            return Attr_None; +            return Attr_Of_Ref;           when Field_Passive_Flag =>              return Attr_None;           when Field_Resolution_Function_Flag => @@ -1762,7 +1769,7 @@ package body Nodes_Meta is              return Attr_None;           when Field_Block_Header =>              return Attr_None; -         when Field_Uninstantiated_Name => +         when Field_Uninstantiated_Package_Name =>              return Attr_None;           when Field_Generate_Block_Configuration =>              return Attr_None; @@ -1828,6 +1835,8 @@ package body Nodes_Meta is              return Attr_None;           when Field_Actual_Type =>              return Attr_None; +         when Field_Associated_Interface => +            return Attr_Ref;           when Field_Association_Chain =>              return Attr_Chain;           when Field_Individual_Association_Chain => @@ -2076,6 +2085,13 @@ package body Nodes_Meta is        Field_Artificial_Flag,        Field_Formal,        Field_Chain, +      --  Iir_Kind_Association_Element_Package +      Field_Whole_Association_Flag, +      Field_Collapse_Signal_Flag, +      Field_Formal, +      Field_Chain, +      Field_Actual, +      Field_Associated_Interface,        --  Iir_Kind_Choice_By_Others        Field_Same_Alternative_Flag,        Field_Chain, @@ -2463,7 +2479,7 @@ package body Nodes_Meta is        Field_End_Has_Identifier,        Field_Declaration_Chain,        Field_Attribute_Value_Chain, -      Field_Uninstantiated_Name, +      Field_Uninstantiated_Package_Name,        Field_Generic_Chain,        Field_Generic_Map_Aspect_Chain,        Field_Parent, @@ -2674,7 +2690,6 @@ package body Nodes_Meta is        Field_Attribute_Value_Chain,        Field_Interface_Declaration_Chain,        Field_Generic_Chain, -      Field_Callees_List,        Field_Return_Type_Mark,        Field_Parent,        Field_Return_Type, @@ -2694,7 +2709,6 @@ package body Nodes_Meta is        Field_Attribute_Value_Chain,        Field_Interface_Declaration_Chain,        Field_Generic_Chain, -      Field_Callees_List,        Field_Generic_Map_Aspect_Chain,        Field_Parent,        Field_Return_Type, @@ -2713,7 +2727,6 @@ package body Nodes_Meta is        Field_Attribute_Value_Chain,        Field_Interface_Declaration_Chain,        Field_Generic_Chain, -      Field_Callees_List,        Field_Generic_Map_Aspect_Chain,        Field_Parent,        Field_Type_Reference, @@ -2736,7 +2749,6 @@ package body Nodes_Meta is        Field_Attribute_Value_Chain,        Field_Interface_Declaration_Chain,        Field_Generic_Chain, -      Field_Callees_List,        Field_Return_Type_Mark,        Field_Parent,        Field_Subprogram_Body, @@ -2749,6 +2761,7 @@ package body Nodes_Meta is        Field_Sequential_Statement_Chain,        Field_Parent,        Field_Subprogram_Specification, +      Field_Callees_List,        --  Iir_Kind_Procedure_Body        Field_Impure_Depth,        Field_End_Has_Reserved_Id, @@ -2758,6 +2771,7 @@ package body Nodes_Meta is        Field_Sequential_Statement_Chain,        Field_Parent,        Field_Subprogram_Specification, +      Field_Callees_List,        --  Iir_Kind_Object_Alias_Declaration        Field_Identifier,        Field_Visible_Flag, @@ -2866,7 +2880,7 @@ package body Nodes_Meta is        Field_Subtype_Indication,        Field_Parent,        Field_Type, -      --  Iir_Kind_Constant_Interface_Declaration +      --  Iir_Kind_Interface_Constant_Declaration        Field_Identifier,        Field_Visible_Flag,        Field_After_Drivers_Flag, @@ -2882,7 +2896,7 @@ package body Nodes_Meta is        Field_Default_Value,        Field_Parent,        Field_Type, -      --  Iir_Kind_Variable_Interface_Declaration +      --  Iir_Kind_Interface_Variable_Declaration        Field_Identifier,        Field_Visible_Flag,        Field_After_Drivers_Flag, @@ -2898,7 +2912,7 @@ package body Nodes_Meta is        Field_Default_Value,        Field_Parent,        Field_Type, -      --  Iir_Kind_Signal_Interface_Declaration +      --  Iir_Kind_Interface_Signal_Declaration        Field_Identifier,        Field_Has_Disconnect_Flag,        Field_Has_Active_Flag, @@ -2918,7 +2932,7 @@ package body Nodes_Meta is        Field_Default_Value,        Field_Parent,        Field_Type, -      --  Iir_Kind_File_Interface_Declaration +      --  Iir_Kind_Interface_File_Declaration        Field_Identifier,        Field_Visible_Flag,        Field_After_Drivers_Flag, @@ -2934,6 +2948,16 @@ package body Nodes_Meta is        Field_Default_Value,        Field_Parent,        Field_Type, +      --  Iir_Kind_Interface_Package_Declaration +      Field_Identifier, +      Field_Visible_Flag, +      Field_Declaration_Chain, +      Field_Chain, +      Field_Attribute_Value_Chain, +      Field_Uninstantiated_Package_Name, +      Field_Generic_Chain, +      Field_Generic_Map_Aspect_Chain, +      Field_Parent,        --  Iir_Kind_Identity_Operator        Field_Expr_Staticness,        Field_Operand, @@ -3276,9 +3300,9 @@ package body Nodes_Meta is        Field_Attribute_Value_Chain,        Field_Sequential_Statement_Chain,        Field_Sensitivity_List, -      Field_Callees_List,        Field_Process_Origin,        Field_Parent, +      Field_Callees_List,        --  Iir_Kind_Process_Statement        Field_Label,        Field_Seen_Flag, @@ -3295,9 +3319,9 @@ package body Nodes_Meta is        Field_Chain,        Field_Attribute_Value_Chain,        Field_Sequential_Statement_Chain, -      Field_Callees_List,        Field_Process_Origin,        Field_Parent, +      Field_Callees_List,        --  Iir_Kind_Concurrent_Conditional_Signal_Assignment        Field_Delay_Mechanism,        Field_Label, @@ -3865,224 +3889,226 @@ package body Nodes_Meta is        Iir_Kind_Association_Element_By_Expression => 97,        Iir_Kind_Association_Element_By_Individual => 103,        Iir_Kind_Association_Element_Open => 108, -      Iir_Kind_Choice_By_Others => 113, -      Iir_Kind_Choice_By_Expression => 120, -      Iir_Kind_Choice_By_Range => 127, -      Iir_Kind_Choice_By_None => 132, -      Iir_Kind_Choice_By_Name => 138, -      Iir_Kind_Entity_Aspect_Entity => 140, -      Iir_Kind_Entity_Aspect_Configuration => 141, -      Iir_Kind_Entity_Aspect_Open => 141, -      Iir_Kind_Block_Configuration => 147, -      Iir_Kind_Block_Header => 151, -      Iir_Kind_Component_Configuration => 157, -      Iir_Kind_Binding_Indication => 163, -      Iir_Kind_Entity_Class => 165, -      Iir_Kind_Attribute_Value => 173, -      Iir_Kind_Signature => 176, -      Iir_Kind_Aggregate_Info => 183, -      Iir_Kind_Procedure_Call => 187, -      Iir_Kind_Record_Element_Constraint => 193, -      Iir_Kind_Array_Element_Resolution => 194, -      Iir_Kind_Record_Resolution => 195, -      Iir_Kind_Record_Element_Resolution => 198, -      Iir_Kind_Attribute_Specification => 206, -      Iir_Kind_Disconnection_Specification => 211, -      Iir_Kind_Configuration_Specification => 216, -      Iir_Kind_Access_Type_Definition => 223, -      Iir_Kind_Incomplete_Type_Definition => 230, -      Iir_Kind_File_Type_Definition => 237, -      Iir_Kind_Protected_Type_Declaration => 246, -      Iir_Kind_Record_Type_Definition => 256, -      Iir_Kind_Array_Type_Definition => 268, -      Iir_Kind_Array_Subtype_Definition => 283, -      Iir_Kind_Record_Subtype_Definition => 294, -      Iir_Kind_Access_Subtype_Definition => 302, -      Iir_Kind_Physical_Subtype_Definition => 311, -      Iir_Kind_Floating_Subtype_Definition => 321, -      Iir_Kind_Integer_Subtype_Definition => 330, -      Iir_Kind_Enumeration_Subtype_Definition => 339, -      Iir_Kind_Enumeration_Type_Definition => 348, -      Iir_Kind_Integer_Type_Definition => 354, -      Iir_Kind_Floating_Type_Definition => 360, -      Iir_Kind_Physical_Type_Definition => 369, -      Iir_Kind_Range_Expression => 375, -      Iir_Kind_Protected_Type_Body => 382, -      Iir_Kind_Subtype_Definition => 386, -      Iir_Kind_Scalar_Nature_Definition => 390, -      Iir_Kind_Overload_List => 391, -      Iir_Kind_Type_Declaration => 398, -      Iir_Kind_Anonymous_Type_Declaration => 403, -      Iir_Kind_Subtype_Declaration => 412, -      Iir_Kind_Nature_Declaration => 419, -      Iir_Kind_Subnature_Declaration => 426, -      Iir_Kind_Package_Declaration => 436, -      Iir_Kind_Package_Instantiation_Declaration => 447, -      Iir_Kind_Package_Body => 453, -      Iir_Kind_Configuration_Declaration => 462, -      Iir_Kind_Entity_Declaration => 474, -      Iir_Kind_Architecture_Body => 486, -      Iir_Kind_Package_Header => 488, -      Iir_Kind_Unit_Declaration => 498, -      Iir_Kind_Library_Declaration => 504, -      Iir_Kind_Component_Declaration => 515, -      Iir_Kind_Attribute_Declaration => 522, -      Iir_Kind_Group_Template_Declaration => 528, -      Iir_Kind_Group_Declaration => 536, -      Iir_Kind_Element_Declaration => 543, -      Iir_Kind_Non_Object_Alias_Declaration => 551, -      Iir_Kind_Psl_Declaration => 559, -      Iir_Kind_Terminal_Declaration => 565, -      Iir_Kind_Free_Quantity_Declaration => 575, -      Iir_Kind_Across_Quantity_Declaration => 588, -      Iir_Kind_Through_Quantity_Declaration => 601, -      Iir_Kind_Enumeration_Literal => 614, -      Iir_Kind_Function_Declaration => 638, -      Iir_Kind_Implicit_Function_Declaration => 657, -      Iir_Kind_Implicit_Procedure_Declaration => 674, -      Iir_Kind_Procedure_Declaration => 696, -      Iir_Kind_Function_Body => 704, -      Iir_Kind_Procedure_Body => 712, -      Iir_Kind_Object_Alias_Declaration => 724, -      Iir_Kind_File_Declaration => 740, -      Iir_Kind_Guard_Signal_Declaration => 753, -      Iir_Kind_Signal_Declaration => 771, -      Iir_Kind_Variable_Declaration => 785, -      Iir_Kind_Constant_Declaration => 800, -      Iir_Kind_Iterator_Declaration => 813, -      Iir_Kind_Constant_Interface_Declaration => 828, -      Iir_Kind_Variable_Interface_Declaration => 843, -      Iir_Kind_Signal_Interface_Declaration => 862, -      Iir_Kind_File_Interface_Declaration => 877, -      Iir_Kind_Identity_Operator => 881, -      Iir_Kind_Negation_Operator => 885, -      Iir_Kind_Absolute_Operator => 889, -      Iir_Kind_Not_Operator => 893, -      Iir_Kind_Condition_Operator => 897, -      Iir_Kind_Reduction_And_Operator => 901, -      Iir_Kind_Reduction_Or_Operator => 905, -      Iir_Kind_Reduction_Nand_Operator => 909, -      Iir_Kind_Reduction_Nor_Operator => 913, -      Iir_Kind_Reduction_Xor_Operator => 917, -      Iir_Kind_Reduction_Xnor_Operator => 921, -      Iir_Kind_And_Operator => 926, -      Iir_Kind_Or_Operator => 931, -      Iir_Kind_Nand_Operator => 936, -      Iir_Kind_Nor_Operator => 941, -      Iir_Kind_Xor_Operator => 946, -      Iir_Kind_Xnor_Operator => 951, -      Iir_Kind_Equality_Operator => 956, -      Iir_Kind_Inequality_Operator => 961, -      Iir_Kind_Less_Than_Operator => 966, -      Iir_Kind_Less_Than_Or_Equal_Operator => 971, -      Iir_Kind_Greater_Than_Operator => 976, -      Iir_Kind_Greater_Than_Or_Equal_Operator => 981, -      Iir_Kind_Match_Equality_Operator => 986, -      Iir_Kind_Match_Inequality_Operator => 991, -      Iir_Kind_Match_Less_Than_Operator => 996, -      Iir_Kind_Match_Less_Than_Or_Equal_Operator => 1001, -      Iir_Kind_Match_Greater_Than_Operator => 1006, -      Iir_Kind_Match_Greater_Than_Or_Equal_Operator => 1011, -      Iir_Kind_Sll_Operator => 1016, -      Iir_Kind_Sla_Operator => 1021, -      Iir_Kind_Srl_Operator => 1026, -      Iir_Kind_Sra_Operator => 1031, -      Iir_Kind_Rol_Operator => 1036, -      Iir_Kind_Ror_Operator => 1041, -      Iir_Kind_Addition_Operator => 1046, -      Iir_Kind_Substraction_Operator => 1051, -      Iir_Kind_Concatenation_Operator => 1056, -      Iir_Kind_Multiplication_Operator => 1061, -      Iir_Kind_Division_Operator => 1066, -      Iir_Kind_Modulus_Operator => 1071, -      Iir_Kind_Remainder_Operator => 1076, -      Iir_Kind_Exponentiation_Operator => 1081, -      Iir_Kind_Function_Call => 1089, -      Iir_Kind_Aggregate => 1095, -      Iir_Kind_Parenthesis_Expression => 1098, -      Iir_Kind_Qualified_Expression => 1102, -      Iir_Kind_Type_Conversion => 1107, -      Iir_Kind_Allocator_By_Expression => 1111, -      Iir_Kind_Allocator_By_Subtype => 1115, -      Iir_Kind_Selected_Element => 1121, -      Iir_Kind_Dereference => 1126, -      Iir_Kind_Implicit_Dereference => 1131, -      Iir_Kind_Slice_Name => 1138, -      Iir_Kind_Indexed_Name => 1144, -      Iir_Kind_Psl_Expression => 1146, -      Iir_Kind_Sensitized_Process_Statement => 1165, -      Iir_Kind_Process_Statement => 1183, -      Iir_Kind_Concurrent_Conditional_Signal_Assignment => 1195, -      Iir_Kind_Concurrent_Selected_Signal_Assignment => 1208, -      Iir_Kind_Concurrent_Assertion_Statement => 1217, -      Iir_Kind_Psl_Default_Clock => 1221, -      Iir_Kind_Psl_Assert_Statement => 1231, -      Iir_Kind_Psl_Cover_Statement => 1241, -      Iir_Kind_Concurrent_Procedure_Call_Statement => 1248, -      Iir_Kind_Block_Statement => 1261, -      Iir_Kind_Generate_Statement => 1273, -      Iir_Kind_Component_Instantiation_Statement => 1284, -      Iir_Kind_Simple_Simultaneous_Statement => 1292, -      Iir_Kind_Signal_Assignment_Statement => 1302, -      Iir_Kind_Null_Statement => 1307, -      Iir_Kind_Assertion_Statement => 1315, -      Iir_Kind_Report_Statement => 1322, -      Iir_Kind_Wait_Statement => 1330, -      Iir_Kind_Variable_Assignment_Statement => 1337, -      Iir_Kind_Return_Statement => 1344, -      Iir_Kind_For_Loop_Statement => 1353, -      Iir_Kind_While_Loop_Statement => 1361, -      Iir_Kind_Next_Statement => 1368, -      Iir_Kind_Exit_Statement => 1375, -      Iir_Kind_Case_Statement => 1383, -      Iir_Kind_Procedure_Call_Statement => 1389, -      Iir_Kind_If_Statement => 1398, -      Iir_Kind_Elsif => 1403, -      Iir_Kind_Character_Literal => 1410, -      Iir_Kind_Simple_Name => 1417, -      Iir_Kind_Selected_Name => 1425, -      Iir_Kind_Operator_Symbol => 1430, -      Iir_Kind_Selected_By_All_Name => 1435, -      Iir_Kind_Parenthesis_Name => 1439, -      Iir_Kind_Base_Attribute => 1441, -      Iir_Kind_Left_Type_Attribute => 1446, -      Iir_Kind_Right_Type_Attribute => 1451, -      Iir_Kind_High_Type_Attribute => 1456, -      Iir_Kind_Low_Type_Attribute => 1461, -      Iir_Kind_Ascending_Type_Attribute => 1466, -      Iir_Kind_Image_Attribute => 1472, -      Iir_Kind_Value_Attribute => 1478, -      Iir_Kind_Pos_Attribute => 1484, -      Iir_Kind_Val_Attribute => 1490, -      Iir_Kind_Succ_Attribute => 1496, -      Iir_Kind_Pred_Attribute => 1502, -      Iir_Kind_Leftof_Attribute => 1508, -      Iir_Kind_Rightof_Attribute => 1514, -      Iir_Kind_Delayed_Attribute => 1522, -      Iir_Kind_Stable_Attribute => 1530, -      Iir_Kind_Quiet_Attribute => 1538, -      Iir_Kind_Transaction_Attribute => 1546, -      Iir_Kind_Event_Attribute => 1550, -      Iir_Kind_Active_Attribute => 1554, -      Iir_Kind_Last_Event_Attribute => 1558, -      Iir_Kind_Last_Active_Attribute => 1562, -      Iir_Kind_Last_Value_Attribute => 1566, -      Iir_Kind_Driving_Attribute => 1570, -      Iir_Kind_Driving_Value_Attribute => 1574, -      Iir_Kind_Behavior_Attribute => 1574, -      Iir_Kind_Structure_Attribute => 1574, -      Iir_Kind_Simple_Name_Attribute => 1581, -      Iir_Kind_Instance_Name_Attribute => 1586, -      Iir_Kind_Path_Name_Attribute => 1591, -      Iir_Kind_Left_Array_Attribute => 1598, -      Iir_Kind_Right_Array_Attribute => 1605, -      Iir_Kind_High_Array_Attribute => 1612, -      Iir_Kind_Low_Array_Attribute => 1619, -      Iir_Kind_Length_Array_Attribute => 1626, -      Iir_Kind_Ascending_Array_Attribute => 1633, -      Iir_Kind_Range_Array_Attribute => 1640, -      Iir_Kind_Reverse_Range_Array_Attribute => 1647, -      Iir_Kind_Attribute_Name => 1655 +      Iir_Kind_Association_Element_Package => 114, +      Iir_Kind_Choice_By_Others => 119, +      Iir_Kind_Choice_By_Expression => 126, +      Iir_Kind_Choice_By_Range => 133, +      Iir_Kind_Choice_By_None => 138, +      Iir_Kind_Choice_By_Name => 144, +      Iir_Kind_Entity_Aspect_Entity => 146, +      Iir_Kind_Entity_Aspect_Configuration => 147, +      Iir_Kind_Entity_Aspect_Open => 147, +      Iir_Kind_Block_Configuration => 153, +      Iir_Kind_Block_Header => 157, +      Iir_Kind_Component_Configuration => 163, +      Iir_Kind_Binding_Indication => 169, +      Iir_Kind_Entity_Class => 171, +      Iir_Kind_Attribute_Value => 179, +      Iir_Kind_Signature => 182, +      Iir_Kind_Aggregate_Info => 189, +      Iir_Kind_Procedure_Call => 193, +      Iir_Kind_Record_Element_Constraint => 199, +      Iir_Kind_Array_Element_Resolution => 200, +      Iir_Kind_Record_Resolution => 201, +      Iir_Kind_Record_Element_Resolution => 204, +      Iir_Kind_Attribute_Specification => 212, +      Iir_Kind_Disconnection_Specification => 217, +      Iir_Kind_Configuration_Specification => 222, +      Iir_Kind_Access_Type_Definition => 229, +      Iir_Kind_Incomplete_Type_Definition => 236, +      Iir_Kind_File_Type_Definition => 243, +      Iir_Kind_Protected_Type_Declaration => 252, +      Iir_Kind_Record_Type_Definition => 262, +      Iir_Kind_Array_Type_Definition => 274, +      Iir_Kind_Array_Subtype_Definition => 289, +      Iir_Kind_Record_Subtype_Definition => 300, +      Iir_Kind_Access_Subtype_Definition => 308, +      Iir_Kind_Physical_Subtype_Definition => 317, +      Iir_Kind_Floating_Subtype_Definition => 327, +      Iir_Kind_Integer_Subtype_Definition => 336, +      Iir_Kind_Enumeration_Subtype_Definition => 345, +      Iir_Kind_Enumeration_Type_Definition => 354, +      Iir_Kind_Integer_Type_Definition => 360, +      Iir_Kind_Floating_Type_Definition => 366, +      Iir_Kind_Physical_Type_Definition => 375, +      Iir_Kind_Range_Expression => 381, +      Iir_Kind_Protected_Type_Body => 388, +      Iir_Kind_Subtype_Definition => 392, +      Iir_Kind_Scalar_Nature_Definition => 396, +      Iir_Kind_Overload_List => 397, +      Iir_Kind_Type_Declaration => 404, +      Iir_Kind_Anonymous_Type_Declaration => 409, +      Iir_Kind_Subtype_Declaration => 418, +      Iir_Kind_Nature_Declaration => 425, +      Iir_Kind_Subnature_Declaration => 432, +      Iir_Kind_Package_Declaration => 442, +      Iir_Kind_Package_Instantiation_Declaration => 453, +      Iir_Kind_Package_Body => 459, +      Iir_Kind_Configuration_Declaration => 468, +      Iir_Kind_Entity_Declaration => 480, +      Iir_Kind_Architecture_Body => 492, +      Iir_Kind_Package_Header => 494, +      Iir_Kind_Unit_Declaration => 504, +      Iir_Kind_Library_Declaration => 510, +      Iir_Kind_Component_Declaration => 521, +      Iir_Kind_Attribute_Declaration => 528, +      Iir_Kind_Group_Template_Declaration => 534, +      Iir_Kind_Group_Declaration => 542, +      Iir_Kind_Element_Declaration => 549, +      Iir_Kind_Non_Object_Alias_Declaration => 557, +      Iir_Kind_Psl_Declaration => 565, +      Iir_Kind_Terminal_Declaration => 571, +      Iir_Kind_Free_Quantity_Declaration => 581, +      Iir_Kind_Across_Quantity_Declaration => 594, +      Iir_Kind_Through_Quantity_Declaration => 607, +      Iir_Kind_Enumeration_Literal => 620, +      Iir_Kind_Function_Declaration => 643, +      Iir_Kind_Implicit_Function_Declaration => 661, +      Iir_Kind_Implicit_Procedure_Declaration => 677, +      Iir_Kind_Procedure_Declaration => 698, +      Iir_Kind_Function_Body => 707, +      Iir_Kind_Procedure_Body => 716, +      Iir_Kind_Object_Alias_Declaration => 728, +      Iir_Kind_File_Declaration => 744, +      Iir_Kind_Guard_Signal_Declaration => 757, +      Iir_Kind_Signal_Declaration => 775, +      Iir_Kind_Variable_Declaration => 789, +      Iir_Kind_Constant_Declaration => 804, +      Iir_Kind_Iterator_Declaration => 817, +      Iir_Kind_Interface_Constant_Declaration => 832, +      Iir_Kind_Interface_Variable_Declaration => 847, +      Iir_Kind_Interface_Signal_Declaration => 866, +      Iir_Kind_Interface_File_Declaration => 881, +      Iir_Kind_Interface_Package_Declaration => 890, +      Iir_Kind_Identity_Operator => 894, +      Iir_Kind_Negation_Operator => 898, +      Iir_Kind_Absolute_Operator => 902, +      Iir_Kind_Not_Operator => 906, +      Iir_Kind_Condition_Operator => 910, +      Iir_Kind_Reduction_And_Operator => 914, +      Iir_Kind_Reduction_Or_Operator => 918, +      Iir_Kind_Reduction_Nand_Operator => 922, +      Iir_Kind_Reduction_Nor_Operator => 926, +      Iir_Kind_Reduction_Xor_Operator => 930, +      Iir_Kind_Reduction_Xnor_Operator => 934, +      Iir_Kind_And_Operator => 939, +      Iir_Kind_Or_Operator => 944, +      Iir_Kind_Nand_Operator => 949, +      Iir_Kind_Nor_Operator => 954, +      Iir_Kind_Xor_Operator => 959, +      Iir_Kind_Xnor_Operator => 964, +      Iir_Kind_Equality_Operator => 969, +      Iir_Kind_Inequality_Operator => 974, +      Iir_Kind_Less_Than_Operator => 979, +      Iir_Kind_Less_Than_Or_Equal_Operator => 984, +      Iir_Kind_Greater_Than_Operator => 989, +      Iir_Kind_Greater_Than_Or_Equal_Operator => 994, +      Iir_Kind_Match_Equality_Operator => 999, +      Iir_Kind_Match_Inequality_Operator => 1004, +      Iir_Kind_Match_Less_Than_Operator => 1009, +      Iir_Kind_Match_Less_Than_Or_Equal_Operator => 1014, +      Iir_Kind_Match_Greater_Than_Operator => 1019, +      Iir_Kind_Match_Greater_Than_Or_Equal_Operator => 1024, +      Iir_Kind_Sll_Operator => 1029, +      Iir_Kind_Sla_Operator => 1034, +      Iir_Kind_Srl_Operator => 1039, +      Iir_Kind_Sra_Operator => 1044, +      Iir_Kind_Rol_Operator => 1049, +      Iir_Kind_Ror_Operator => 1054, +      Iir_Kind_Addition_Operator => 1059, +      Iir_Kind_Substraction_Operator => 1064, +      Iir_Kind_Concatenation_Operator => 1069, +      Iir_Kind_Multiplication_Operator => 1074, +      Iir_Kind_Division_Operator => 1079, +      Iir_Kind_Modulus_Operator => 1084, +      Iir_Kind_Remainder_Operator => 1089, +      Iir_Kind_Exponentiation_Operator => 1094, +      Iir_Kind_Function_Call => 1102, +      Iir_Kind_Aggregate => 1108, +      Iir_Kind_Parenthesis_Expression => 1111, +      Iir_Kind_Qualified_Expression => 1115, +      Iir_Kind_Type_Conversion => 1120, +      Iir_Kind_Allocator_By_Expression => 1124, +      Iir_Kind_Allocator_By_Subtype => 1128, +      Iir_Kind_Selected_Element => 1134, +      Iir_Kind_Dereference => 1139, +      Iir_Kind_Implicit_Dereference => 1144, +      Iir_Kind_Slice_Name => 1151, +      Iir_Kind_Indexed_Name => 1157, +      Iir_Kind_Psl_Expression => 1159, +      Iir_Kind_Sensitized_Process_Statement => 1178, +      Iir_Kind_Process_Statement => 1196, +      Iir_Kind_Concurrent_Conditional_Signal_Assignment => 1208, +      Iir_Kind_Concurrent_Selected_Signal_Assignment => 1221, +      Iir_Kind_Concurrent_Assertion_Statement => 1230, +      Iir_Kind_Psl_Default_Clock => 1234, +      Iir_Kind_Psl_Assert_Statement => 1244, +      Iir_Kind_Psl_Cover_Statement => 1254, +      Iir_Kind_Concurrent_Procedure_Call_Statement => 1261, +      Iir_Kind_Block_Statement => 1274, +      Iir_Kind_Generate_Statement => 1286, +      Iir_Kind_Component_Instantiation_Statement => 1297, +      Iir_Kind_Simple_Simultaneous_Statement => 1305, +      Iir_Kind_Signal_Assignment_Statement => 1315, +      Iir_Kind_Null_Statement => 1320, +      Iir_Kind_Assertion_Statement => 1328, +      Iir_Kind_Report_Statement => 1335, +      Iir_Kind_Wait_Statement => 1343, +      Iir_Kind_Variable_Assignment_Statement => 1350, +      Iir_Kind_Return_Statement => 1357, +      Iir_Kind_For_Loop_Statement => 1366, +      Iir_Kind_While_Loop_Statement => 1374, +      Iir_Kind_Next_Statement => 1381, +      Iir_Kind_Exit_Statement => 1388, +      Iir_Kind_Case_Statement => 1396, +      Iir_Kind_Procedure_Call_Statement => 1402, +      Iir_Kind_If_Statement => 1411, +      Iir_Kind_Elsif => 1416, +      Iir_Kind_Character_Literal => 1423, +      Iir_Kind_Simple_Name => 1430, +      Iir_Kind_Selected_Name => 1438, +      Iir_Kind_Operator_Symbol => 1443, +      Iir_Kind_Selected_By_All_Name => 1448, +      Iir_Kind_Parenthesis_Name => 1452, +      Iir_Kind_Base_Attribute => 1454, +      Iir_Kind_Left_Type_Attribute => 1459, +      Iir_Kind_Right_Type_Attribute => 1464, +      Iir_Kind_High_Type_Attribute => 1469, +      Iir_Kind_Low_Type_Attribute => 1474, +      Iir_Kind_Ascending_Type_Attribute => 1479, +      Iir_Kind_Image_Attribute => 1485, +      Iir_Kind_Value_Attribute => 1491, +      Iir_Kind_Pos_Attribute => 1497, +      Iir_Kind_Val_Attribute => 1503, +      Iir_Kind_Succ_Attribute => 1509, +      Iir_Kind_Pred_Attribute => 1515, +      Iir_Kind_Leftof_Attribute => 1521, +      Iir_Kind_Rightof_Attribute => 1527, +      Iir_Kind_Delayed_Attribute => 1535, +      Iir_Kind_Stable_Attribute => 1543, +      Iir_Kind_Quiet_Attribute => 1551, +      Iir_Kind_Transaction_Attribute => 1559, +      Iir_Kind_Event_Attribute => 1563, +      Iir_Kind_Active_Attribute => 1567, +      Iir_Kind_Last_Event_Attribute => 1571, +      Iir_Kind_Last_Active_Attribute => 1575, +      Iir_Kind_Last_Value_Attribute => 1579, +      Iir_Kind_Driving_Attribute => 1583, +      Iir_Kind_Driving_Value_Attribute => 1587, +      Iir_Kind_Behavior_Attribute => 1587, +      Iir_Kind_Structure_Attribute => 1587, +      Iir_Kind_Simple_Name_Attribute => 1594, +      Iir_Kind_Instance_Name_Attribute => 1599, +      Iir_Kind_Path_Name_Attribute => 1604, +      Iir_Kind_Left_Array_Attribute => 1611, +      Iir_Kind_Right_Array_Attribute => 1618, +      Iir_Kind_High_Array_Attribute => 1625, +      Iir_Kind_Low_Array_Attribute => 1632, +      Iir_Kind_Length_Array_Attribute => 1639, +      Iir_Kind_Ascending_Array_Attribute => 1646, +      Iir_Kind_Range_Array_Attribute => 1653, +      Iir_Kind_Reverse_Range_Array_Attribute => 1660, +      Iir_Kind_Attribute_Name => 1668       );     function Get_Fields (K : Iir_Kind) return Fields_Array @@ -4606,8 +4632,8 @@ package body Nodes_Meta is              return Get_Package_Header (N);           when Field_Block_Header =>              return Get_Block_Header (N); -         when Field_Uninstantiated_Name => -            return Get_Uninstantiated_Name (N); +         when Field_Uninstantiated_Package_Name => +            return Get_Uninstantiated_Package_Name (N);           when Field_Generate_Block_Configuration =>              return Get_Generate_Block_Configuration (N);           when Field_Generation_Scheme => @@ -4666,6 +4692,8 @@ package body Nodes_Meta is              return Get_Parameter (N);           when Field_Actual_Type =>              return Get_Actual_Type (N); +         when Field_Associated_Interface => +            return Get_Associated_Interface (N);           when Field_Association_Chain =>              return Get_Association_Chain (N);           when Field_Individual_Association_Chain => @@ -4966,8 +4994,8 @@ package body Nodes_Meta is              Set_Package_Header (N, V);           when Field_Block_Header =>              Set_Block_Header (N, V); -         when Field_Uninstantiated_Name => -            Set_Uninstantiated_Name (N, V); +         when Field_Uninstantiated_Package_Name => +            Set_Uninstantiated_Package_Name (N, V);           when Field_Generate_Block_Configuration =>              Set_Generate_Block_Configuration (N, V);           when Field_Generation_Scheme => @@ -5026,6 +5054,8 @@ package body Nodes_Meta is              Set_Parameter (N, V);           when Field_Actual_Type =>              Set_Actual_Type (N, V); +         when Field_Associated_Interface => +            Set_Associated_Interface (N, V);           when Field_Association_Chain =>              Set_Association_Chain (N, V);           when Field_Individual_Association_Chain => @@ -6112,7 +6142,8 @@ package body Nodes_Meta is        case K is           when Iir_Kind_Association_Element_By_Expression             | Iir_Kind_Association_Element_By_Individual -           | Iir_Kind_Association_Element_Open => +           | Iir_Kind_Association_Element_Open +           | Iir_Kind_Association_Element_Package =>              return True;           when others =>              return False; @@ -6121,7 +6152,13 @@ package body Nodes_Meta is     function Has_Actual (K : Iir_Kind) return Boolean is     begin -      return K = Iir_Kind_Association_Element_By_Expression; +      case K is +         when Iir_Kind_Association_Element_By_Expression +           | Iir_Kind_Association_Element_Package => +            return True; +         when others => +            return False; +      end case;     end Has_Actual;     function Has_In_Conversion (K : Iir_Kind) return Boolean is @@ -6139,7 +6176,8 @@ package body Nodes_Meta is        case K is           when Iir_Kind_Association_Element_By_Expression             | Iir_Kind_Association_Element_By_Individual -           | Iir_Kind_Association_Element_Open => +           | Iir_Kind_Association_Element_Open +           | Iir_Kind_Association_Element_Package =>              return True;           when others =>              return False; @@ -6151,7 +6189,8 @@ package body Nodes_Meta is        case K is           when Iir_Kind_Association_Element_By_Expression             | Iir_Kind_Association_Element_By_Individual -           | Iir_Kind_Association_Element_Open => +           | Iir_Kind_Association_Element_Open +           | Iir_Kind_Association_Element_Package =>              return True;           when others =>              return False; @@ -6165,7 +6204,7 @@ package body Nodes_Meta is     function Has_Open_Flag (K : Iir_Kind) return Boolean is     begin -      return K = Iir_Kind_Signal_Interface_Declaration; +      return K = Iir_Kind_Interface_Signal_Declaration;     end Has_Open_Flag;     function Has_After_Drivers_Flag (K : Iir_Kind) return Boolean is @@ -6173,10 +6212,10 @@ package body Nodes_Meta is        case K is           when Iir_Kind_Object_Alias_Declaration             | Iir_Kind_Signal_Declaration -           | Iir_Kind_Constant_Interface_Declaration -           | Iir_Kind_Variable_Interface_Declaration -           | Iir_Kind_Signal_Interface_Declaration -           | Iir_Kind_File_Interface_Declaration => +           | Iir_Kind_Interface_Constant_Declaration +           | Iir_Kind_Interface_Variable_Declaration +           | Iir_Kind_Interface_Signal_Declaration +           | Iir_Kind_Interface_File_Declaration =>              return True;           when others =>              return False; @@ -6299,10 +6338,11 @@ package body Nodes_Meta is             | Iir_Kind_Variable_Declaration             | Iir_Kind_Constant_Declaration             | Iir_Kind_Iterator_Declaration -           | Iir_Kind_Constant_Interface_Declaration -           | Iir_Kind_Variable_Interface_Declaration -           | Iir_Kind_Signal_Interface_Declaration -           | Iir_Kind_File_Interface_Declaration +           | Iir_Kind_Interface_Constant_Declaration +           | Iir_Kind_Interface_Variable_Declaration +           | Iir_Kind_Interface_Signal_Declaration +           | Iir_Kind_Interface_File_Declaration +           | Iir_Kind_Interface_Package_Declaration             | Iir_Kind_Sensitized_Process_Statement             | Iir_Kind_Process_Statement             | Iir_Kind_Concurrent_Conditional_Signal_Assignment @@ -6414,6 +6454,7 @@ package body Nodes_Meta is             | Iir_Kind_Association_Element_By_Expression             | Iir_Kind_Association_Element_By_Individual             | Iir_Kind_Association_Element_Open +           | Iir_Kind_Association_Element_Package             | Iir_Kind_Choice_By_Others             | Iir_Kind_Choice_By_Expression             | Iir_Kind_Choice_By_Range @@ -6457,10 +6498,11 @@ package body Nodes_Meta is             | Iir_Kind_Variable_Declaration             | Iir_Kind_Constant_Declaration             | Iir_Kind_Iterator_Declaration -           | Iir_Kind_Constant_Interface_Declaration -           | Iir_Kind_Variable_Interface_Declaration -           | Iir_Kind_Signal_Interface_Declaration -           | Iir_Kind_File_Interface_Declaration +           | Iir_Kind_Interface_Constant_Declaration +           | Iir_Kind_Interface_Variable_Declaration +           | Iir_Kind_Interface_Signal_Declaration +           | Iir_Kind_Interface_File_Declaration +           | Iir_Kind_Interface_Package_Declaration             | Iir_Kind_Sensitized_Process_Statement             | Iir_Kind_Process_Statement             | Iir_Kind_Concurrent_Conditional_Signal_Assignment @@ -6521,7 +6563,8 @@ package body Nodes_Meta is             | Iir_Kind_Function_Declaration             | Iir_Kind_Implicit_Function_Declaration             | Iir_Kind_Implicit_Procedure_Declaration -           | Iir_Kind_Procedure_Declaration => +           | Iir_Kind_Procedure_Declaration +           | Iir_Kind_Interface_Package_Declaration =>              return True;           when others =>              return False; @@ -6562,10 +6605,10 @@ package body Nodes_Meta is             | Iir_Kind_Variable_Declaration             | Iir_Kind_Constant_Declaration             | Iir_Kind_Iterator_Declaration -           | Iir_Kind_Constant_Interface_Declaration -           | Iir_Kind_Variable_Interface_Declaration -           | Iir_Kind_Signal_Interface_Declaration -           | Iir_Kind_File_Interface_Declaration +           | Iir_Kind_Interface_Constant_Declaration +           | Iir_Kind_Interface_Variable_Declaration +           | Iir_Kind_Interface_Signal_Declaration +           | Iir_Kind_Interface_File_Declaration             | Iir_Kind_Identity_Operator             | Iir_Kind_Negation_Operator             | Iir_Kind_Absolute_Operator @@ -6683,10 +6726,10 @@ package body Nodes_Meta is             | Iir_Kind_Variable_Declaration             | Iir_Kind_Constant_Declaration             | Iir_Kind_Iterator_Declaration -           | Iir_Kind_Constant_Interface_Declaration -           | Iir_Kind_Variable_Interface_Declaration -           | Iir_Kind_Signal_Interface_Declaration -           | Iir_Kind_File_Interface_Declaration +           | Iir_Kind_Interface_Constant_Declaration +           | Iir_Kind_Interface_Variable_Declaration +           | Iir_Kind_Interface_Signal_Declaration +           | Iir_Kind_Interface_File_Declaration             | Iir_Kind_Allocator_By_Subtype =>              return True;           when others => @@ -6731,10 +6774,10 @@ package body Nodes_Meta is     begin        case K is           when Iir_Kind_File_Declaration -           | Iir_Kind_Constant_Interface_Declaration -           | Iir_Kind_Variable_Interface_Declaration -           | Iir_Kind_Signal_Interface_Declaration -           | Iir_Kind_File_Interface_Declaration => +           | Iir_Kind_Interface_Constant_Declaration +           | Iir_Kind_Interface_Variable_Declaration +           | Iir_Kind_Interface_Signal_Declaration +           | Iir_Kind_Interface_File_Declaration =>              return True;           when others =>              return False; @@ -6746,7 +6789,7 @@ package body Nodes_Meta is        case K is           when Iir_Kind_Guard_Signal_Declaration             | Iir_Kind_Signal_Declaration -           | Iir_Kind_Signal_Interface_Declaration => +           | Iir_Kind_Interface_Signal_Declaration =>              return True;           when others =>              return False; @@ -6947,10 +6990,10 @@ package body Nodes_Meta is             | Iir_Kind_Signal_Declaration             | Iir_Kind_Variable_Declaration             | Iir_Kind_Constant_Declaration -           | Iir_Kind_Constant_Interface_Declaration -           | Iir_Kind_Variable_Interface_Declaration -           | Iir_Kind_Signal_Interface_Declaration -           | Iir_Kind_File_Interface_Declaration => +           | Iir_Kind_Interface_Constant_Declaration +           | Iir_Kind_Interface_Variable_Declaration +           | Iir_Kind_Interface_Signal_Declaration +           | Iir_Kind_Interface_File_Declaration =>              return True;           when others =>              return False; @@ -7011,6 +7054,7 @@ package body Nodes_Meta is             | Iir_Kind_Architecture_Body             | Iir_Kind_Function_Body             | Iir_Kind_Procedure_Body +           | Iir_Kind_Interface_Package_Declaration             | Iir_Kind_Sensitized_Process_Statement             | Iir_Kind_Process_Statement             | Iir_Kind_Block_Statement @@ -7158,10 +7202,11 @@ package body Nodes_Meta is             | Iir_Kind_Variable_Declaration             | Iir_Kind_Constant_Declaration             | Iir_Kind_Iterator_Declaration -           | Iir_Kind_Constant_Interface_Declaration -           | Iir_Kind_Variable_Interface_Declaration -           | Iir_Kind_Signal_Interface_Declaration -           | Iir_Kind_File_Interface_Declaration +           | Iir_Kind_Interface_Constant_Declaration +           | Iir_Kind_Interface_Variable_Declaration +           | Iir_Kind_Interface_Signal_Declaration +           | Iir_Kind_Interface_File_Declaration +           | Iir_Kind_Interface_Package_Declaration             | Iir_Kind_Sensitized_Process_Statement             | Iir_Kind_Process_Statement             | Iir_Kind_Concurrent_Conditional_Signal_Assignment @@ -7274,10 +7319,11 @@ package body Nodes_Meta is             | Iir_Kind_Variable_Declaration             | Iir_Kind_Constant_Declaration             | Iir_Kind_Iterator_Declaration -           | Iir_Kind_Constant_Interface_Declaration -           | Iir_Kind_Variable_Interface_Declaration -           | Iir_Kind_Signal_Interface_Declaration -           | Iir_Kind_File_Interface_Declaration +           | Iir_Kind_Interface_Constant_Declaration +           | Iir_Kind_Interface_Variable_Declaration +           | Iir_Kind_Interface_Signal_Declaration +           | Iir_Kind_Interface_File_Declaration +           | Iir_Kind_Interface_Package_Declaration             | Iir_Kind_Sensitized_Process_Statement             | Iir_Kind_Process_Statement             | Iir_Kind_Concurrent_Conditional_Signal_Assignment @@ -7700,10 +7746,8 @@ package body Nodes_Meta is     function Has_Callees_List (K : Iir_Kind) return Boolean is     begin        case K is -         when Iir_Kind_Function_Declaration -           | Iir_Kind_Implicit_Function_Declaration -           | Iir_Kind_Implicit_Procedure_Declaration -           | Iir_Kind_Procedure_Declaration +         when Iir_Kind_Function_Body +           | Iir_Kind_Procedure_Body             | Iir_Kind_Sensitized_Process_Statement             | Iir_Kind_Process_Statement =>              return True; @@ -7951,6 +7995,7 @@ package body Nodes_Meta is             | Iir_Kind_Package_Header             | Iir_Kind_Implicit_Function_Declaration             | Iir_Kind_Implicit_Procedure_Declaration +           | Iir_Kind_Interface_Package_Declaration             | Iir_Kind_Component_Instantiation_Statement =>              return True;           when others => @@ -8066,10 +8111,16 @@ package body Nodes_Meta is        return K = Iir_Kind_Block_Statement;     end Has_Block_Header; -   function Has_Uninstantiated_Name (K : Iir_Kind) return Boolean is +   function Has_Uninstantiated_Package_Name (K : Iir_Kind) return Boolean is     begin -      return K = Iir_Kind_Package_Instantiation_Declaration; -   end Has_Uninstantiated_Name; +      case K is +         when Iir_Kind_Package_Instantiation_Declaration +           | Iir_Kind_Interface_Package_Declaration => +            return True; +         when others => +            return False; +      end case; +   end Has_Uninstantiated_Package_Name;     function Has_Generate_Block_Configuration (K : Iir_Kind) return Boolean is     begin @@ -8167,10 +8218,11 @@ package body Nodes_Meta is             | Iir_Kind_Variable_Declaration             | Iir_Kind_Constant_Declaration             | Iir_Kind_Iterator_Declaration -           | Iir_Kind_Constant_Interface_Declaration -           | Iir_Kind_Variable_Interface_Declaration -           | Iir_Kind_Signal_Interface_Declaration -           | Iir_Kind_File_Interface_Declaration +           | Iir_Kind_Interface_Constant_Declaration +           | Iir_Kind_Interface_Variable_Declaration +           | Iir_Kind_Interface_Signal_Declaration +           | Iir_Kind_Interface_File_Declaration +           | Iir_Kind_Interface_Package_Declaration             | Iir_Kind_Sensitized_Process_Statement             | Iir_Kind_Process_Statement             | Iir_Kind_Concurrent_Conditional_Signal_Assignment @@ -8327,10 +8379,10 @@ package body Nodes_Meta is             | Iir_Kind_Variable_Declaration             | Iir_Kind_Constant_Declaration             | Iir_Kind_Iterator_Declaration -           | Iir_Kind_Constant_Interface_Declaration -           | Iir_Kind_Variable_Interface_Declaration -           | Iir_Kind_Signal_Interface_Declaration -           | Iir_Kind_File_Interface_Declaration +           | Iir_Kind_Interface_Constant_Declaration +           | Iir_Kind_Interface_Variable_Declaration +           | Iir_Kind_Interface_Signal_Declaration +           | Iir_Kind_Interface_File_Declaration             | Iir_Kind_Identity_Operator             | Iir_Kind_Negation_Operator             | Iir_Kind_Absolute_Operator @@ -8582,10 +8634,10 @@ package body Nodes_Meta is             | Iir_Kind_Variable_Declaration             | Iir_Kind_Constant_Declaration             | Iir_Kind_Iterator_Declaration -           | Iir_Kind_Constant_Interface_Declaration -           | Iir_Kind_Variable_Interface_Declaration -           | Iir_Kind_Signal_Interface_Declaration -           | Iir_Kind_File_Interface_Declaration +           | Iir_Kind_Interface_Constant_Declaration +           | Iir_Kind_Interface_Variable_Declaration +           | Iir_Kind_Interface_Signal_Declaration +           | Iir_Kind_Interface_File_Declaration             | Iir_Kind_Function_Call             | Iir_Kind_Selected_Element             | Iir_Kind_Dereference @@ -8759,6 +8811,11 @@ package body Nodes_Meta is        return K = Iir_Kind_Association_Element_By_Individual;     end Has_Actual_Type; +   function Has_Associated_Interface (K : Iir_Kind) return Boolean is +   begin +      return K = Iir_Kind_Association_Element_Package; +   end Has_Associated_Interface; +     function Has_Association_Chain (K : Iir_Kind) return Boolean is     begin        return K = Iir_Kind_Parenthesis_Name; @@ -8978,10 +9035,10 @@ package body Nodes_Meta is     function Has_Lexical_Layout (K : Iir_Kind) return Boolean is     begin        case K is -         when Iir_Kind_Constant_Interface_Declaration -           | Iir_Kind_Variable_Interface_Declaration -           | Iir_Kind_Signal_Interface_Declaration -           | Iir_Kind_File_Interface_Declaration => +         when Iir_Kind_Interface_Constant_Declaration +           | Iir_Kind_Interface_Variable_Declaration +           | Iir_Kind_Interface_Signal_Declaration +           | Iir_Kind_Interface_File_Declaration =>              return True;           when others =>              return False; @@ -8997,7 +9054,7 @@ package body Nodes_Meta is     begin        case K is           when Iir_Kind_Signal_Declaration -           | Iir_Kind_Signal_Interface_Declaration => +           | Iir_Kind_Interface_Signal_Declaration =>              return True;           when others =>              return False; @@ -9009,7 +9066,7 @@ package body Nodes_Meta is        case K is           when Iir_Kind_Guard_Signal_Declaration             | Iir_Kind_Signal_Declaration -           | Iir_Kind_Signal_Interface_Declaration +           | Iir_Kind_Interface_Signal_Declaration             | Iir_Kind_Delayed_Attribute             | Iir_Kind_Stable_Attribute             | Iir_Kind_Quiet_Attribute @@ -9140,10 +9197,10 @@ package body Nodes_Meta is             | Iir_Kind_Variable_Declaration             | Iir_Kind_Constant_Declaration             | Iir_Kind_Iterator_Declaration -           | Iir_Kind_Constant_Interface_Declaration -           | Iir_Kind_Variable_Interface_Declaration -           | Iir_Kind_Signal_Interface_Declaration -           | Iir_Kind_File_Interface_Declaration => +           | Iir_Kind_Interface_Constant_Declaration +           | Iir_Kind_Interface_Variable_Declaration +           | Iir_Kind_Interface_Signal_Declaration +           | Iir_Kind_Interface_File_Declaration =>              return True;           when others =>              return False; @@ -9289,10 +9346,10 @@ package body Nodes_Meta is             | Iir_Kind_Variable_Declaration             | Iir_Kind_Constant_Declaration             | Iir_Kind_Iterator_Declaration -           | Iir_Kind_Constant_Interface_Declaration -           | Iir_Kind_Variable_Interface_Declaration -           | Iir_Kind_Signal_Interface_Declaration -           | Iir_Kind_File_Interface_Declaration => +           | Iir_Kind_Interface_Constant_Declaration +           | Iir_Kind_Interface_Variable_Declaration +           | Iir_Kind_Interface_Signal_Declaration +           | Iir_Kind_Interface_File_Declaration =>              return True;           when others =>              return False; diff --git a/nodes_meta.ads b/nodes_meta.ads index 4183fc8a4..2d1f5e1c0 100644 --- a/nodes_meta.ads +++ b/nodes_meta.ads @@ -254,7 +254,7 @@ package Nodes_Meta is        Field_Block_Block_Configuration,        Field_Package_Header,        Field_Block_Header, -      Field_Uninstantiated_Name, +      Field_Uninstantiated_Package_Name,        Field_Generate_Block_Configuration,        Field_Generation_Scheme,        Field_Condition, @@ -287,6 +287,7 @@ package Nodes_Meta is        Field_Index_Subtype,        Field_Parameter,        Field_Actual_Type, +      Field_Associated_Interface,        Field_Association_Chain,        Field_Individual_Association_Chain,        Field_Aggregate_Info, @@ -725,7 +726,7 @@ package Nodes_Meta is     function Has_Block_Block_Configuration (K : Iir_Kind) return Boolean;     function Has_Package_Header (K : Iir_Kind) return Boolean;     function Has_Block_Header (K : Iir_Kind) return Boolean; -   function Has_Uninstantiated_Name (K : Iir_Kind) return Boolean; +   function Has_Uninstantiated_Package_Name (K : Iir_Kind) return Boolean;     function Has_Generate_Block_Configuration (K : Iir_Kind) return Boolean;     function Has_Generation_Scheme (K : Iir_Kind) return Boolean;     function Has_Condition (K : Iir_Kind) return Boolean; @@ -760,6 +761,7 @@ package Nodes_Meta is     function Has_Index_Subtype (K : Iir_Kind) return Boolean;     function Has_Parameter (K : Iir_Kind) return Boolean;     function Has_Actual_Type (K : Iir_Kind) return Boolean; +   function Has_Associated_Interface (K : Iir_Kind) return Boolean;     function Has_Association_Chain (K : Iir_Kind) return Boolean;     function Has_Individual_Association_Chain (K : Iir_Kind) return Boolean;     function Has_Aggregate_Info (K : Iir_Kind) return Boolean; @@ -56,7 +56,8 @@ package body Parse is     function Parse_Primary return Iir_Expression;     function Parse_Use_Clause return Iir_Use_Clause; -   function Parse_Association_Chain return Iir; +   function Parse_Association_List return Iir; +   function Parse_Association_List_In_Parenthesis return Iir;     function Parse_Sequential_Statements (Parent : Iir) return Iir;     function Parse_Configuration_Item return Iir; @@ -838,7 +839,8 @@ package body Parse is                 Res := Create_Iir (Iir_Kind_Parenthesis_Name);                 Set_Location (Res);                 Set_Prefix (Res, Prefix); -               Set_Association_Chain (Res, Parse_Association_Chain); +               Set_Association_Chain +                 (Res, Parse_Association_List_In_Parenthesis);              when Tok_Dot =>                 if Get_Kind (Prefix) = Iir_Kind_String_Literal then @@ -930,16 +932,10 @@ package body Parse is        return Res;     end Parse_Type_Mark; -   --  precond : '(' -   --  postcond: next token -   -- -   --  [ LRM93 4.3.2.1 ] -   --  interface_list ::= interface_element { ; interface_element } -   -- -   --  [ LRM93 4.3.2.1 ] -   --  interface_element ::= interface_declaration +   --  precond : CONSTANT, SIGNAL, VARIABLE. FILE or identifier +   --  postcond: next token (';' or ')')     -- -   --  [ LRM93 4.3.2 ] +   --  [ LRM93 4.3.2 ] [ LRM08 6.5.2 ]     --  interface_declaration ::= interface_constant_declaration     --                          | interface_signal_declaration     --                          | interface_variable_declaration @@ -968,9 +964,10 @@ package body Parse is     --          [ := STATIC_expression ]     --     --  The default kind of interface declaration is DEFAULT. -   function Parse_Interface_Chain (Default: Iir_Kind; Parent : Iir) -                                  return Iir +   function Parse_Interface_Object_Declaration (Ctxt : Interface_Kind_Type) +                                               return Iir     is +      Kind : Iir_Kind;        Res, Last : Iir;        First, Prev_First : Iir;        Inter: Iir; @@ -980,6 +977,305 @@ package body Parse is        Signal_Kind: Iir_Signal_Kind;        Default_Value: Iir;        Lexical_Layout : Iir_Lexical_Layout_Type; +   begin +      Res := Null_Iir; +      Last := Null_Iir; + +      --  LRM08 6.5.2 Interface object declarations +      --  Interface obejcts include interface constants that appear as +      --  generics of a design entity, a component, a block, a package or +      --  a subprogram, or as constant parameter of subprograms; interface +      --  signals that appear as ports of a design entity, component or +      --  block, or as signal parameters of subprograms; interface variables +      --  that appear as variable parameter subprograms; interface files +      --  that appear as file parameters of subrograms. +      case Current_Token is +         when Tok_Identifier => +            --  The class of the object is unknown.  Select default +            --  according to the above rule, assuming the mode is IN.  If +            --  the mode is not IN, Parse_Interface_Object_Declaration will +            --  change the class. +            case Ctxt is +               when Generic_Interface_List +                 | Parameter_Interface_List => +                  Kind := Iir_Kind_Interface_Constant_Declaration; +               when Port_Interface_List => +                  Kind := Iir_Kind_Interface_Signal_Declaration; +            end case; +         when Tok_Constant => +            Kind := Iir_Kind_Interface_Constant_Declaration; +         when Tok_Signal => +            if Ctxt = Generic_Interface_List then +               Error_Msg_Parse +                 ("signal interface not allowed in generic clause"); +            end if; +            Kind := Iir_Kind_Interface_Signal_Declaration; +         when Tok_Variable => +            if Ctxt not in Parameter_Interface_List then +               Error_Msg_Parse +                 ("variable interface not allowed in generic or port clause"); +            end if; +            Kind := Iir_Kind_Interface_Variable_Declaration; +         when Tok_File => +            if Flags.Vhdl_Std = Vhdl_87 then +               Error_Msg_Parse ("file interface not allowed in vhdl 87"); +            end if; +            if Ctxt not in Parameter_Interface_List then +               Error_Msg_Parse +                 ("variable interface not allowed in generic or port clause"); +            end if; +            Kind := Iir_Kind_Interface_File_Declaration; +         when others => +            --  Fall back in case of parse error. +            Kind := Iir_Kind_Interface_Variable_Declaration; +      end case; + +      Inter := Create_Iir (Kind); + +      if Current_Token = Tok_Identifier then +         Is_Default := True; +         Lexical_Layout := 0; +      else +         Is_Default := False; +         Lexical_Layout := Iir_Lexical_Has_Class; + +         --  Skip 'signal', 'variable', 'constant' or 'file'. +         Scan; +      end if; + +      Prev_First := Last; +      First := Inter; +      loop +         if Current_Token /= Tok_Identifier then +            Expect (Tok_Identifier); +         end if; +         Set_Identifier (Inter, Current_Identifier); +         Set_Location (Inter); + +         if Res = Null_Iir then +            Res := Inter; +         else +            Set_Chain (Last, Inter); +         end if; +         Last := Inter; + +         --  Skip identifier +         Scan; + +         exit when Current_Token = Tok_Colon; +         Expect (Tok_Comma, "',' or ':' expected after identifier"); + +         --  Skip ',' +         Scan; + +         Inter := Create_Iir (Kind); +      end loop; + +      Expect (Tok_Colon, "':' must follow the interface element identifier"); + +      --  Skip ':' +      Scan; + +      --  LRM93 2.1.1  LRM08 4.2.2.1 +      --  If the mode is INOUT or OUT, and no object class is explicitly +      --  specified, variable is assumed. +      if Is_Default +        and then Ctxt in Parameter_Interface_List +        and then (Current_Token = Tok_Inout or else Current_Token = Tok_Out) +      then +         --  Convert into variable. +         declare +            O_Interface : Iir_Interface_Constant_Declaration; +            N_Interface : Iir_Interface_Variable_Declaration; +         begin +            O_Interface := First; +            while O_Interface /= Null_Iir loop +               N_Interface := +                 Create_Iir (Iir_Kind_Interface_Variable_Declaration); +               Location_Copy (N_Interface, O_Interface); +               Set_Identifier (N_Interface, +                               Get_Identifier (O_Interface)); +               if Prev_First = Null_Iir then +                  Res := N_Interface; +               else +                  Set_Chain (Prev_First, N_Interface); +               end if; +               Prev_First := N_Interface; +               if O_Interface = First then +                  First := N_Interface; +               end if; +               Last := N_Interface; +               Inter := Get_Chain (O_Interface); +               Free_Iir (O_Interface); +               O_Interface := Inter; +            end loop; +            Inter := First; +         end; +      end if; + +      --  Update lexical layout if mode is present. +      case Current_Token is +         when Tok_In +           | Tok_Out +           | Tok_Inout +           | Tok_Linkage +           | Tok_Buffer => +            Lexical_Layout := Lexical_Layout or Iir_Lexical_Has_Mode; +         when others => +            null; +      end case; + +      --  Parse mode (and handle default mode). +      case Get_Kind (Inter) is +         when Iir_Kind_Interface_File_Declaration => +            if Parse_Mode (Iir_Unknown_Mode) /= Iir_Unknown_Mode then +               Error_Msg_Parse +                 ("mode can't be specified for a file interface"); +            end if; +            Interface_Mode := Iir_Inout_Mode; +         when Iir_Kind_Interface_Signal_Declaration +           | Iir_Kind_Interface_Variable_Declaration => +            --  LRM93 4.3.2 +            --  If no mode is explicitly given in an interface declaration +            --  other than an interface file declaration, mode IN is +            --  assumed. +            Interface_Mode := Parse_Mode (Iir_In_Mode); +         when Iir_Kind_Interface_Constant_Declaration => +            Interface_Mode := Parse_Mode (Iir_In_Mode); +            if Interface_Mode /= Iir_In_Mode then +               Error_Msg_Parse ("mode must be 'in' for a constant"); +            end if; +         when others => +            raise Internal_Error; +      end case; + +      Interface_Type := Parse_Subtype_Indication; + +      --  Signal kind (but only for signal). +      if Get_Kind (Inter) = Iir_Kind_Interface_Signal_Declaration then +         Signal_Kind := Parse_Signal_Kind; +      else +         Signal_Kind := Iir_No_Signal_Kind; +      end if; + +      if Current_Token = Tok_Assign then +         if Get_Kind (Inter) = Iir_Kind_Interface_File_Declaration then +            Error_Msg_Parse +              ("default expression not allowed for an interface file"); +         end if; + +         --  Skip ':=' +         Scan; + +         Default_Value := Parse_Expression; +      else +         Default_Value := Null_Iir; +      end if; + +      --  Subtype_Indication and Default_Value are set only on the first +      --  interface. +      Set_Subtype_Indication (First, Interface_Type); +      if Get_Kind (First) /= Iir_Kind_Interface_File_Declaration then +         Set_Default_Value (First, Default_Value); +      end if; + +      Inter := First; +      while Inter /= Null_Iir loop +         Set_Mode (Inter, Interface_Mode); +         Set_Is_Ref (Inter, Inter /= First); +         if Inter = Last then +            Set_Lexical_Layout (Inter, +                                Lexical_Layout or Iir_Lexical_Has_Type); +         else +            Set_Lexical_Layout (Inter, Lexical_Layout); +         end if; +         if Get_Kind (Inter) = Iir_Kind_Interface_Signal_Declaration then +            Set_Signal_Kind (Inter, Signal_Kind); +         end if; +         Inter := Get_Chain (Inter); +      end loop; + +      return Res; +   end Parse_Interface_Object_Declaration; + +   --  Precond : 'package' +   --  Postcond: next token +   -- +   --  LRM08 6.5.5 Interface package declarations +   --  interface_package_declaration ::= +   --    PACKAGE identifier IS NEW uninstantiated_package name +   --      interface_package_generic_map_aspect +   -- +   --  interface_package_generic_map_aspect ::= +   --       generic_map_aspect +   --     | GENERIC MAP ( <> ) +   --     | GENERIC MAP ( DEFAULT ) +   function Parse_Interface_Package_Declaration return Iir +   is +      Inter : Iir; +      Map : Iir; +   begin +      Inter := Create_Iir (Iir_Kind_Interface_Package_Declaration); + +      --  Skip 'package' +      Scan_Expect (Tok_Identifier, +                   "an identifier is expected after ""package"""); +      Set_Identifier (Inter, Current_Identifier); +      Set_Location (Inter); + +      --  Skip identifier +      Scan_Expect (Tok_Is); + +      --  Skip 'is' +      Scan_Expect (Tok_New); + +      --  Skip 'new' +      Scan; + +      Set_Uninstantiated_Package_Name (Inter, Parse_Name (False)); + +      Expect (Tok_Generic); + +      --  Skip 'generic' +      Scan_Expect (Tok_Map); + +      --  Skip 'map' +      Scan_Expect (Tok_Left_Paren); + +      --  Skip '(' +      Scan; + +      case Current_Token is +         when Tok_Box => +            Map := Null_Iir; +            --  Skip '<>' +            Scan; +         when others => +            Map := Parse_Association_List; +      end case; +      Set_Generic_Map_Aspect_Chain (Inter, Map); + +      Expect (Tok_Right_Paren); + +      --  Skip ')' +      Scan; + +      return Inter; +   end Parse_Interface_Package_Declaration; + +   --  Precond : '(' +   --  Postcond: next token +   -- +   --  LRM08 6.5.6 Interface lists +   --  interface_list ::= interface_element { ';' interface_element } +   -- +   --  interface_element ::= interface_declaration +   function Parse_Interface_List (Ctxt : Interface_Kind_Type; Parent : Iir) +                                 return Iir +   is +      Res, Last : Iir; +      Inters : Iir; +      Next : Iir;        Prev_Loc : Location_Type;     begin        Expect (Tok_Left_Paren); @@ -993,19 +1289,22 @@ package body Parse is           Scan;           case Current_Token is -            when Tok_Identifier => -               Inter := Create_Iir (Default); -            when Tok_Signal => -               Inter := Create_Iir (Iir_Kind_Signal_Interface_Declaration); -            when Tok_Variable => -               Inter := Create_Iir (Iir_Kind_Variable_Interface_Declaration); -            when Tok_Constant => -               Inter := Create_Iir (Iir_Kind_Constant_Interface_Declaration); -            when Tok_File => -               if Flags.Vhdl_Std = Vhdl_87 then -                  Error_Msg_Parse ("file interface not allowed in vhdl 87"); +            when Tok_Identifier +              | Tok_Signal +              | Tok_Variable +              | Tok_Constant +              | Tok_File => +               --  An inteface object. +               Inters := Parse_Interface_Object_Declaration (Ctxt); +            when Tok_Package => +               if Ctxt /= Generic_Interface_List then +                  Error_Msg_Parse +                    ("package interface only allowed in generic interface"); +               elsif Flags.Vhdl_Std < Vhdl_08 then +                  Error_Msg_Parse +                    ("package interface not allowed before vhdl 08");                 end if; -               Inter := Create_Iir (Iir_Kind_File_Interface_Declaration); +               Inters := Parse_Interface_Package_Declaration;              when Tok_Right_Paren =>                 if Res = Null_Iir then                    Error_Msg_Parse @@ -1020,172 +1319,25 @@ package body Parse is                   ("'signal', 'constant', 'variable', 'file' "                    & "or identifier expected");                 --  Use a variable interface as a fall-back. -               Inter := Create_Iir (Iir_Kind_Variable_Interface_Declaration); +               Inters := Parse_Interface_Object_Declaration (Ctxt);           end case; -         if Current_Token = Tok_Identifier then -            Is_Default := True; -            Lexical_Layout := 0; -         else -            Is_Default := False; -            Lexical_Layout := Iir_Lexical_Has_Class; -            --  Skip 'signal', 'variable', 'constant' or 'file'. -            Scan; +         --  Chain +         if Last = Null_Iir then +            Res := Inters; +         else +            Set_Chain (Last, Inters);           end if; -         Prev_First := Last; -         First := Inter; +         --  Set parent and set Last to the last interface. +         Last := Inters;           loop -            if Current_Token /= Tok_Identifier then -               Expect (Tok_Identifier); -            end if; -            Set_Identifier (Inter, Current_Identifier); -            Set_Location (Inter); - -            if Res = Null_Iir then -               Res := Inter; -            else -               Set_Chain (Last, Inter); -            end if; -            Last := Inter; - -            --  Skip identifier -            Scan; - -            exit when Current_Token = Tok_Colon; -            Expect (Tok_Comma, "',' or ':' expected after identifier"); - -            --  Skip ',' -            Scan; - -            Inter := Create_Iir (Get_Kind (Inter)); +            Set_Parent (Last, Parent); +            Next := Get_Chain (Last); +            exit when Next = Null_Iir; +            Last := Next;           end loop; -         Expect (Tok_Colon, -                 "':' must follow the interface element identifier"); - -         --  Skip ':' -         Scan; - -         --  LRM93 2.1.1 -         --  If the mode is INOUT or OUT, and no object class is explicitly -         --  specified, variable is assumed. -         if Is_Default -           and then Default /= Iir_Kind_Signal_Interface_Declaration -           and then (Current_Token = Tok_Inout or else Current_Token = Tok_Out) -         then -            --  Convert into variable. -            declare -               O_Interface : Iir_Constant_Interface_Declaration; -               N_Interface : Iir_Variable_Interface_Declaration; -            begin -               O_Interface := First; -               while O_Interface /= Null_Iir loop -                  N_Interface := -                    Create_Iir (Iir_Kind_Variable_Interface_Declaration); -                  Location_Copy (N_Interface, O_Interface); -                  Set_Identifier (N_Interface, -                                  Get_Identifier (O_Interface)); -                  if Prev_First = Null_Iir then -                     Res := N_Interface; -                  else -                     Set_Chain (Prev_First, N_Interface); -                  end if; -                  Prev_First := N_Interface; -                  if O_Interface = First then -                     First := N_Interface; -                  end if; -                  Last := N_Interface; -                  Inter := Get_Chain (O_Interface); -                  Free_Iir (O_Interface); -                  O_Interface := Inter; -               end loop; -               Inter := First; -            end; -         end if; - -         --  Update lexical layout if mode is present. -         case Current_Token is -            when Tok_In -              | Tok_Out -              | Tok_Inout -              | Tok_Linkage -              | Tok_Buffer => -               Lexical_Layout := Lexical_Layout or Iir_Lexical_Has_Mode; -            when others => -               null; -         end case; - -         --  Parse mode (and handle default mode). -         case Get_Kind (Inter) is -            when Iir_Kind_File_Interface_Declaration => -               if Parse_Mode (Iir_Unknown_Mode) /= Iir_Unknown_Mode then -                  Error_Msg_Parse -                    ("mode can't be specified for a file interface"); -               end if; -               Interface_Mode := Iir_Inout_Mode; -            when Iir_Kind_Signal_Interface_Declaration -              | Iir_Kind_Variable_Interface_Declaration => -               --  LRM93 4.3.2 -               --  If no mode is explicitly given in an interface declaration -               --  other than an interface file declaration, mode IN is -               --  assumed. -               Interface_Mode := Parse_Mode (Iir_In_Mode); -            when Iir_Kind_Constant_Interface_Declaration => -               Interface_Mode := Parse_Mode (Iir_In_Mode); -               if Interface_Mode /= Iir_In_Mode then -                  Error_Msg_Parse ("mode must be 'in' for a constant"); -               end if; -            when others => -               raise Internal_Error; -         end case; - -         Interface_Type := Parse_Subtype_Indication; - -         --  Signal kind (but only for signal). -         if Get_Kind (Inter) = Iir_Kind_Signal_Interface_Declaration then -            Signal_Kind := Parse_Signal_Kind; -         else -            Signal_Kind := Iir_No_Signal_Kind; -         end if; - -         if Current_Token = Tok_Assign then -            if Get_Kind (Inter) = Iir_Kind_File_Interface_Declaration then -               Error_Msg_Parse -                 ("default expression not allowed for an interface file"); -            end if; - -            --  Skip ':=' -            Scan; - -            Default_Value := Parse_Expression; -         else -            Default_Value := Null_Iir; -         end if; - -         --  Subtype_Indication and Default_Value are set only on the first -         --  interface. -         Set_Subtype_Indication (First, Interface_Type); -         if Get_Kind (First) /= Iir_Kind_File_Interface_Declaration then -            Set_Default_Value (First, Default_Value); -         end if; - -         Inter := First; -         while Inter /= Null_Iir loop -            Set_Mode (Inter, Interface_Mode); -            Set_Parent (Inter, Parent); -            Set_Is_Ref (Inter, Inter /= First); -            if Inter = Last then -               Set_Lexical_Layout (Inter, -                                   Lexical_Layout or Iir_Lexical_Has_Type); -            else -               Set_Lexical_Layout (Inter, Lexical_Layout); -            end if; -            if Get_Kind (Inter) = Iir_Kind_Signal_Interface_Declaration then -               Set_Signal_Kind (Inter, Signal_Kind); -            end if; -            Inter := Get_Chain (Inter); -         end loop;           exit when Current_Token /= Tok_Semi_Colon;        end loop; @@ -1197,7 +1349,7 @@ package body Parse is        Scan;        return Res; -   end Parse_Interface_Chain; +   end Parse_Interface_List;     --  precond : PORT     --  postcond: next token @@ -1216,13 +1368,12 @@ package body Parse is        pragma Assert (Current_Token = Tok_Port);        Scan; -      Res := Parse_Interface_Chain -        (Iir_Kind_Signal_Interface_Declaration, Parent); +      Res := Parse_Interface_List (Port_Interface_List, Parent);        --  Check the interface are signal interfaces.        El := Res;        while El /= Null_Iir loop -         if Get_Kind (El) /= Iir_Kind_Signal_Interface_Declaration then +         if Get_Kind (El) /= Iir_Kind_Interface_Signal_Declaration then              Error_Msg_Parse ("port must be a signal", El);           end if;           El := Get_Chain (El); @@ -1248,8 +1399,7 @@ package body Parse is        pragma Assert (Current_Token = Tok_Generic);        Scan; -      Res := Parse_Interface_Chain -        (Iir_Kind_Constant_Interface_Declaration, Parent); +      Res := Parse_Interface_List (Generic_Interface_List, Parent);        Set_Generic_Chain (Parent, Res);        Scan_Semi_Colon ("generic clause"); @@ -5136,6 +5286,8 @@ package body Parse is     --  operator_symbol ::= string_literal     function Parse_Subprogram_Declaration (Parent : Iir) return Iir     is +      Kind : Iir_Kind; +      Inters : Iir;        Subprg: Iir;        Subprg_Body : Iir;        Old : Iir; @@ -5144,14 +5296,15 @@ package body Parse is        -- Create the node.        case Current_Token is           when Tok_Procedure => -            Subprg := Create_Iir (Iir_Kind_Procedure_Declaration); +            Kind := Iir_Kind_Procedure_Declaration;           when Tok_Function             | Tok_Pure             | Tok_Impure => -            Subprg := Create_Iir (Iir_Kind_Function_Declaration); +            Kind := Iir_Kind_Function_Declaration;           when others =>              raise Internal_Error;        end case; +      Subprg := Create_Iir (Kind);        Set_Location (Subprg);        case Current_Token is @@ -5185,7 +5338,7 @@ package body Parse is           Set_Identifier (Subprg, Current_Identifier);           Set_Location (Subprg);        elsif Current_Token = Tok_String then -         if Get_Kind (Subprg) = Iir_Kind_Procedure_Declaration then +         if Kind = Iir_Kind_Procedure_Declaration then              --  LRM93 2.1              --  A procedure designator is always an identifier.              Error_Msg_Parse ("a procedure name must be an identifier"); @@ -5203,14 +5356,18 @@ package body Parse is        Scan;        if Current_Token = Tok_Left_Paren then           --  Parse the interface declaration. -         Set_Interface_Declaration_Chain -           (Subprg, -            Parse_Interface_Chain (Iir_Kind_Constant_Interface_Declaration, -                                   Subprg)); +         if Kind = Iir_Kind_Function_Declaration then +            Inters := Parse_Interface_List +              (Function_Parameter_Interface_List, Subprg); +         else +            Inters := Parse_Interface_List +              (Procedure_Parameter_Interface_List, Subprg); +         end if; +         Set_Interface_Declaration_Chain (Subprg, Inters);        end if;        if Current_Token = Tok_Return then -         if Get_Kind (Subprg) = Iir_Kind_Procedure_Declaration then +         if Kind = Iir_Kind_Procedure_Declaration then              Error_Msg_Parse ("'return' not allowed for a procedure");              Error_Msg_Parse ("(remove return part or define a function)"); @@ -5226,7 +5383,7 @@ package body Parse is                (Subprg, Parse_Type_Mark (Check_Paren => True));           end if;        else -         if Get_Kind (Subprg) = Iir_Kind_Function_Declaration then +         if Kind = Iir_Kind_Function_Declaration then              Error_Msg_Parse ("'return' expected");           end if;        end if; @@ -5237,7 +5394,7 @@ package body Parse is        --  The body.        Set_Has_Body (Subprg, True); -      if Get_Kind (Subprg) = Iir_Kind_Function_Declaration then +      if Kind = Iir_Kind_Function_Declaration then           Subprg_Body := Create_Iir (Iir_Kind_Function_Body);        else           Subprg_Body := Create_Iir (Iir_Kind_Procedure_Body); @@ -5266,7 +5423,7 @@ package body Parse is              if Flags.Vhdl_Std = Vhdl_87 then                 Error_Msg_Parse ("'function' not allowed here by vhdl 87");              end if; -            if Get_Kind (Subprg) = Iir_Kind_Procedure_Declaration then +            if Kind = Iir_Kind_Procedure_Declaration then                 Error_Msg_Parse ("'procedure' expected instead of 'function'");              end if;              Set_End_Has_Reserved_Id (Subprg_Body, True); @@ -5275,7 +5432,7 @@ package body Parse is              if Flags.Vhdl_Std = Vhdl_87 then                 Error_Msg_Parse ("'procedure' not allowed here by vhdl 87");              end if; -            if Get_Kind (Subprg) = Iir_Kind_Function_Declaration then +            if Kind = Iir_Kind_Function_Declaration then                 Error_Msg_Parse ("'function' expected instead of 'procedure'");              end if;              Set_End_Has_Reserved_Id (Subprg_Body, True); @@ -5397,39 +5554,39 @@ package body Parse is        return Res;     end Parse_Process_Statement; -   -- precond : '(' +   -- precond : NEXT_TOKEN     -- postcond: NEXT_TOKEN     -- -   --  [ §4.3.2.2 ] +   --  [ LRM93 4.3.2.2 ]     --  association_list ::= association_element { , association_element }     -- -   --  [ §4.3.2.2 ] +   --  [ LRM93 4.3.2.2 ]     --  association_element ::= [ formal_part => ] actual_part     -- -   --  [ §4.3.2.2 ] +   --  [ LRM93 4.3.2.2 ]     --  actual_part ::= actual_designator     --                | FUNCTION_name ( actual_designator )     --                | type_mark ( actual_designator )     -- -   --  [ §4.3.2.2 ] +   --  [ LRM93 4.3.2.2 ]     --  actual_designator ::= expression     --                      | SIGNAL_name     --                      | VARIABLE_name     --                      | FILE_name     --                      | OPEN     -- -   --  [ §4.3.2.2 ] +   --  [ LRM93 4.3.2.2 ]     --  formal_part ::= formal_designator     --                | FUNCTION_name ( formal_designator )     --                | type_mark ( formal_designator )     -- -   --  [ §4.3.2.2 ] +   --  [ LRM93 4.3.2.2 ]     --  formal_designator ::= GENERIC_name     --                      | PORT_name     --                      | PARAMETER_name     --     --  Note: an actual part is parsed as an expression. -   function Parse_Association_Chain return Iir +   function Parse_Association_List return Iir     is        Res, Last: Iir;        El: Iir; @@ -5440,10 +5597,6 @@ package body Parse is     begin        Sub_Chain_Init (Res, Last); -      --  Skip '(' -      Expect (Tok_Left_Paren); -      Scan; -        if Current_Token = Tok_Right_Paren then           Error_Msg_Parse ("empty association list is not allowed");           return Res; @@ -5510,11 +5663,28 @@ package body Parse is           Nbr_Assocs := Nbr_Assocs + 1;        end loop; +      return Res; +   end Parse_Association_List; + +   -- precond : NEXT_TOKEN +   -- postcond: NEXT_TOKEN +   -- +   -- Parse: '(' association_list ')' +   function Parse_Association_List_In_Parenthesis return Iir +   is +      Res : Iir; +   begin +      --  Skip '(' +      Expect (Tok_Left_Paren); +      Scan; + +      Res := Parse_Association_List; +        --  Skip ')'        Scan;        return Res; -   end Parse_Association_Chain; +   end Parse_Association_List_In_Parenthesis;     --  precond : GENERIC     --  postcond: next token @@ -5526,7 +5696,7 @@ package body Parse is        Expect (Tok_Generic);        Scan_Expect (Tok_Map);        Scan; -      return Parse_Association_Chain; +      return Parse_Association_List_In_Parenthesis;     end Parse_Generic_Map_Aspect;     --  precond : PORT @@ -5539,7 +5709,7 @@ package body Parse is        Expect (Tok_Port);        Scan_Expect (Tok_Map);        Scan; -      return Parse_Association_Chain; +      return Parse_Association_List_In_Parenthesis;     end Parse_Port_Map_Aspect;     --  precond : COMPONENT | ENTIY | CONFIGURATION @@ -6800,7 +6970,7 @@ package body Parse is        --  Skip 'new'        Scan; -      Set_Uninstantiated_Name (Res, Parse_Name (False)); +      Set_Uninstantiated_Package_Name (Res, Parse_Name (False));        if Current_Token = Tok_Generic then           Set_Generic_Map_Aspect_Chain (Res, Parse_Generic_Map_Aspect); @@ -72,10 +72,10 @@ package body Sem is        Open_Declarative_Region;        -- Sem generics. -      Sem_Interface_Chain (Get_Generic_Chain (Entity), Interface_Generic); +      Sem_Interface_Chain (Get_Generic_Chain (Entity), Generic_Interface_List);        -- Sem ports. -      Sem_Interface_Chain (Get_Port_Chain (Entity), Interface_Port); +      Sem_Interface_Chain (Get_Port_Chain (Entity), Port_Interface_List);        --  Entity declarative part and concurrent statements.        Sem_Block (Entity, True); @@ -230,7 +230,7 @@ package body Sem is                 return Res;              end if;           when Iir_Kind_Signal_Declaration -           | Iir_Kind_Signal_Interface_Declaration +           | Iir_Kind_Interface_Signal_Declaration             | Iir_Kind_Guard_Signal_Declaration =>              null;           when Iir_Kind_Object_Alias_Declaration => @@ -352,6 +352,7 @@ package body Sem is        El : Iir;        Match : Boolean;        Assoc_Chain : Iir; +      Inter_Chain : Iir;        Miss : Missing_Type;     begin        --  LRM08 6.5.6.2 Generic clauses @@ -398,11 +399,17 @@ package body Sem is        end case;        --  The generics +      Inter_Chain := Get_Generic_Chain (Inter_Parent);        Assoc_Chain := Get_Generic_Map_Aspect_Chain (Assoc_Parent); + +      --  Extract non-object associations, as the actual cannot be analyzed +      --  as an expression. +      Assoc_Chain := Extract_Non_Object_Association (Assoc_Chain, Inter_Chain); +      Set_Generic_Map_Aspect_Chain (Assoc_Parent, Assoc_Chain); +        if Sem_Actual_Of_Association_Chain (Assoc_Chain) then           Sem_Association_Chain -           (Get_Generic_Chain (Inter_Parent), Assoc_Chain, -            True, Miss, Assoc_Parent, Match); +           (Inter_Chain, Assoc_Chain, True, Miss, Assoc_Parent, Match);           Set_Generic_Map_Aspect_Chain (Assoc_Parent, Assoc_Chain);           --  LRM 5.2.1.2   Generic map and port map aspects @@ -414,9 +421,9 @@ package body Sem is                 case Get_Kind (El) is                    when Iir_Kind_Association_Element_By_Expression =>                       Check_Read (Get_Actual (El)); -                  when Iir_Kind_Association_Element_Open => -                     null; -                  when Iir_Kind_Association_Element_By_Individual => +                  when Iir_Kind_Association_Element_Open +                    | Iir_Kind_Association_Element_By_Individual +                    | Iir_Kind_Association_Element_Package =>                       null;                    when others =>                       Error_Kind ("sem_generic_map_association_chain(1)", El); @@ -522,7 +529,7 @@ package body Sem is              end if;              case Get_Kind (Prefix) is                 when Iir_Kind_Signal_Declaration -                 | Iir_Kind_Signal_Interface_Declaration +                 | Iir_Kind_Interface_Signal_Declaration                   | Iir_Kind_Guard_Signal_Declaration                   | Iir_Kinds_Signal_Attribute =>                    --  Port or signal. @@ -531,8 +538,7 @@ package body Sem is                    if Get_Name_Staticness (Object) < Globally then                       Error_Msg_Sem ("actual must be a static name", Actual);                    end if; -                  if Get_Kind (Prefix) -                    = Iir_Kind_Signal_Interface_Declaration +                  if Get_Kind (Prefix) = Iir_Kind_Interface_Signal_Declaration                    then                       declare                          P : Boolean; @@ -1158,10 +1164,10 @@ package body Sem is                 return False;              end if;              return True; -         when Iir_Kind_Constant_Interface_Declaration -           | Iir_Kind_Variable_Interface_Declaration -           | Iir_Kind_Signal_Interface_Declaration -           | Iir_Kind_File_Interface_Declaration => +         when Iir_Kind_Interface_Constant_Declaration +           | Iir_Kind_Interface_Variable_Declaration +           | Iir_Kind_Interface_Signal_Declaration +           | Iir_Kind_Interface_File_Declaration =>              if Get_Identifier (Left) /= Get_Identifier (Right) then                 return False;              end if; @@ -1683,15 +1689,16 @@ package body Sem is        Interface_Chain := Get_Interface_Declaration_Chain (Subprg);        case Get_Kind (Subprg) is           when Iir_Kind_Function_Declaration => -            Sem_Interface_Chain (Interface_Chain, Interface_Function); -            --  FIXME: the return type is in fact a type mark. +            Sem_Interface_Chain +              (Interface_Chain, Function_Parameter_Interface_List);              Return_Type := Get_Return_Type_Mark (Subprg);              Return_Type := Sem_Type_Mark (Return_Type);              Set_Return_Type_Mark (Subprg, Return_Type);              Set_Return_Type (Subprg, Get_Type (Return_Type));              Set_All_Sensitized_State (Subprg, Unknown);           when Iir_Kind_Procedure_Declaration => -            Sem_Interface_Chain (Interface_Chain, Interface_Procedure); +            Sem_Interface_Chain +              (Interface_Chain, Procedure_Parameter_Interface_List);              --  Unless the body is analyzed, the procedure purity is unknown.              Set_Purity_State (Subprg, Unknown);              --  Check if the procedure is passive. @@ -1702,7 +1709,7 @@ package body Sem is              begin                 Inter := Interface_Chain;                 while Inter /= Null_Iir loop -                  if Get_Kind (Inter) = Iir_Kind_Signal_Interface_Declaration +                  if Get_Kind (Inter) = Iir_Kind_Interface_Signal_Declaration                      and then Get_Mode (Inter) /= Iir_In_Mode                    then                       --  There is a driver for this signal interface. @@ -1782,7 +1789,7 @@ package body Sem is        El := Get_Interface_Declaration_Chain (Spec);        while El /= Null_Iir loop           Add_Name (El, Get_Identifier (El), False); -         if Get_Kind (El) = Iir_Kind_Signal_Interface_Declaration then +         if Get_Kind (El) = Iir_Kind_Interface_Signal_Declaration then              Set_Has_Active_Flag (El, False);           end if;           El := Get_Chain (El); @@ -1804,7 +1811,7 @@ package body Sem is                 when Impure =>                    null;                 when Unknown => -                  if Get_Callees_List (Spec) = Null_Iir_List then +                  if Get_Callees_List (Subprg) = Null_Iir_List then                       --  Since there are no callees, purity state can                       --  be updated.                       if Get_Impure_Depth (Subprg) = Iir_Depth_Pure then @@ -1822,7 +1829,7 @@ package body Sem is                    Callee : Iir;                    State : Tri_State_Type;                 begin -                  Callees := Get_Callees_List (Spec); +                  Callees := Get_Callees_List (Subprg);                    --  Per default, has no wait.                    Set_Wait_State (Spec, False);                    if Callees /= Null_Iir_List then @@ -1858,7 +1865,7 @@ package body Sem is              --  Set All_Sensitized_State in trivial cases.              if Get_All_Sensitized_State (Spec) = Unknown -              and then Get_Callees_List (Spec) = Null_Iir_List +              and then Get_Callees_List (Subprg) = Null_Iir_List              then                 Set_All_Sensitized_State (Spec, No_Signal);              end if; @@ -1867,7 +1874,7 @@ package body Sem is              --  generate purity/wait/all-sensitized errors by themselves.           when Iir_Kind_Function_Declaration => -            if Get_Callees_List (Spec) /= Null_Iir_List then +            if Get_Callees_List (Subprg) /= Null_Iir_List then                 --  Purity calls to be checked later.                 --  No wait statements in procedures called.                 Add_Analysis_Checks_List (Spec); @@ -1904,8 +1911,10 @@ package body Sem is        type Caller_Kind is (K_Function, K_Process, K_Procedure);        Kind : Caller_Kind; -      Callees_List : Iir_List := Get_Callees_List (Subprg); +      Callees_List : Iir_List; +      Callees_List_Holder : Iir;        Callee : Iir; +      Callee_Orig : Iir;        Callee_Bod : Iir;        Subprg_Depth : Iir_Int32;        Subprg_Bod : Iir; @@ -1921,6 +1930,7 @@ package body Sem is              Kind := K_Function;              Subprg_Bod := Get_Subprogram_Body (Subprg);              Subprg_Depth := Get_Subprogram_Depth (Subprg); +            Callees_List_Holder := Subprg_Bod;              if Get_Pure_Flag (Subprg) then                 Depth := Iir_Depth_Pure;              else @@ -1929,6 +1939,7 @@ package body Sem is           when Iir_Kind_Procedure_Declaration =>              Kind := K_Procedure; +            Subprg_Bod := Get_Subprogram_Body (Subprg);              if Get_Purity_State (Subprg) = Impure                and then Get_Wait_State (Subprg) /= Unknown                and then Get_All_Sensitized_State (Subprg) /= Unknown @@ -1937,26 +1948,29 @@ package body Sem is                 if Get_All_Sensitized_State (Subprg) = No_Signal                   or else Vhdl_Std < Vhdl_08                 then +                  Callees_List := Get_Callees_List (Subprg_Bod);                    Destroy_Iir_List (Callees_List); -                  Set_Callees_List (Subprg, Null_Iir_List); +                  Set_Callees_List (Subprg_Bod, Null_Iir_List);                 end if;                 return Update_Pure_Done;              end if; -            Subprg_Bod := Get_Subprogram_Body (Subprg);              Subprg_Depth := Get_Subprogram_Depth (Subprg);              Depth := Get_Impure_Depth (Subprg_Bod); +            Callees_List_Holder := Subprg_Bod;           when Iir_Kind_Sensitized_Process_Statement =>              Kind := K_Process;              Subprg_Bod := Null_Iir;              Subprg_Depth := Iir_Depth_Top;              Depth := Iir_Depth_Impure; +            Callees_List_Holder := Subprg;           when others =>              Error_Kind ("update_and_check_pure_wait(1)", Subprg);        end case;        --  If the subprogram has no callee list, there is nothing to do. +      Callees_List := Get_Callees_List (Callees_List_Holder);        if Callees_List = Null_Iir_List then           --  There are two reasons why a callees_list is null:           --  * either because SUBPRG does not call any procedure @@ -1972,7 +1986,7 @@ package body Sem is        --  This subprogram is being considered.        --  To avoid infinite loop, suppress its callees list. -      Set_Callees_List (Subprg, Null_Iir_List); +      Set_Callees_List (Callees_List_Holder, Null_Iir_List);        --  First loop: check without recursion.        --  Second loop: recurse if necessary. @@ -1988,6 +2002,17 @@ package body Sem is              --  Check pure.              Callee_Bod := Get_Subprogram_Body (Callee); + +            if Callee_Bod = Null_Iir then +               --  The body of subprograms may not be set for instances. +               --  Use the body from the generic (if any). +               Callee_Orig := Sem_Inst.Get_Origin (Callee); +               if Callee_Orig /= Null_Iir then +                  Callee_Bod := Get_Subprogram_Body (Callee_Orig); +                  Set_Subprogram_Body (Callee, Callee_Bod); +               end if; +            end if; +              if Callee_Bod = Null_Iir then                 --  No body yet for the subprogram called.                 --  Nothing can be extracted from it, postpone the checks until @@ -2123,7 +2148,7 @@ package body Sem is           end if;        end loop; -      Set_Callees_List (Subprg, Callees_List); +      Set_Callees_List (Callees_List_Holder, Callees_List);        return Res;     end Update_And_Check_Pure_Wait; @@ -2172,8 +2197,10 @@ package body Sem is        Callee : Iir;     begin        if List = Null_Iir_List then +         --  Return now if there is nothing to check.           return;        end if; +        Npos := 0;        for I in Natural loop           El := Get_Nth_Element (List, I); @@ -2186,9 +2213,7 @@ package body Sem is                    Keep := True;                    if Emit_Warnings then                       Callees := Get_Callees_List (El); -                     if Callees = Null_Iir_List then -                        raise Internal_Error; -                     end if; +                     pragma Assert (Callees /= Null_Iir_List);                       Warning_Msg_Sem                         ("can't assert that all calls in " & Disp_Node (El)                          & " are pure or have not wait; " @@ -2318,7 +2343,8 @@ package body Sem is        Push_Signals_Declarative_Part (Implicit, Decl);        if Header /= Null_Iir then -         Sem_Interface_Chain (Get_Generic_Chain (Header), Interface_Generic); +         Sem_Interface_Chain +           (Get_Generic_Chain (Header), Generic_Interface_List);           if Get_Generic_Map_Aspect_Chain (Header) /= Null_Iir then              --  FIXME: todo              raise Internal_Error; @@ -2389,33 +2415,47 @@ package body Sem is        Close_Declarative_Region;     end Sem_Package_Body; -   --  LRM08 4.9  Package Instantiation Declaration -   procedure Sem_Package_Instantiation_Declaration (Decl : Iir) +   function Sem_Uninstantiated_Package_Name (Decl : Iir) return Iir     is        Name : Iir;        Pkg : Iir; -      Bod : Iir_Design_Unit;     begin -      Sem_Scopes.Add_Name (Decl); -      Set_Visible_Flag (Decl, True); -      Xref_Decl (Decl); - -      --  LRM08 4.9 -      --  The uninstantiated package name shall denote an uninstantiated -      --  package declared in a package declaration. -      Name := Sem_Denoting_Name (Get_Uninstantiated_Name (Decl)); -      Set_Uninstantiated_Name (Decl, Name); +      Name := Sem_Denoting_Name (Get_Uninstantiated_Package_Name (Decl)); +      Set_Uninstantiated_Package_Name (Decl, Name);        Pkg := Get_Named_Entity (Name);        if Get_Kind (Pkg) /= Iir_Kind_Package_Declaration then           Error_Class_Match (Name, "package");           --  What could be done ? -         return; +         return Null_Iir;        elsif not Is_Uninstantiated_Package (Pkg) then           Error_Msg_Sem             (Disp_Node (Pkg) & " is not an uninstantiated package", Name);           --  What could be done ? +         return Null_Iir; +      end if; + +      return Pkg; +   end Sem_Uninstantiated_Package_Name; + +   --  LRM08 4.9  Package Instantiation Declaration +   procedure Sem_Package_Instantiation_Declaration (Decl : Iir) +   is +      Hdr : Iir; +      Pkg : Iir; +      Bod : Iir_Design_Unit; +   begin +      Sem_Scopes.Add_Name (Decl); +      Set_Visible_Flag (Decl, True); +      Xref_Decl (Decl); + +      --  LRM08 4.9 +      --  The uninstantiated package name shall denote an uninstantiated +      --  package declared in a package declaration. +      Pkg := Sem_Uninstantiated_Package_Name (Decl); +      if Pkg = Null_Iir then +         --  What could be done ?           return;        end if; @@ -2428,8 +2468,9 @@ package body Sem is        --  GHDL: the generics are first instantiated (ie copied) and then        --  the actuals are associated with the instantiated formal.        --  FIXME: do it in Instantiate_Package_Declaration ? +      Hdr := Get_Package_Header (Pkg); +      Sem_Generic_Association_Chain (Hdr, Decl);        Sem_Inst.Instantiate_Package_Declaration (Decl, Pkg); -      Sem_Generic_Association_Chain (Decl, Decl);        --  FIXME: unless the parent is a package declaration library unit, the        --  design unit depends on the body. @@ -2489,7 +2530,8 @@ package body Sem is           case Get_Kind (Prefix) is              when Iir_Kind_Library_Declaration =>                 null; -            when Iir_Kind_Package_Instantiation_Declaration => +            when Iir_Kind_Package_Instantiation_Declaration +              | Iir_Kind_Interface_Package_Declaration =>                 null;              when Iir_Kind_Package_Declaration =>                 --  LRM08 12.4 Use clauses @@ -74,4 +74,9 @@ package Sem is     procedure Sem_Analysis_Checks_List (Unit : Iir_Design_Unit;                                         Emit_Warnings : Boolean); +   --  Analyze the uninstantiated package name of DECL, and return the +   --  package declaration.  Return Null_Iir if the name doesn't denote an +   --  uninstantiated package. +   function Sem_Uninstantiated_Package_Name (Decl : Iir) return Iir; +  end Sem; diff --git a/sem_assocs.adb b/sem_assocs.adb index ee43e30ef..96e660875 100644 --- a/sem_assocs.adb +++ b/sem_assocs.adb @@ -26,6 +26,97 @@ with Iir_Chains; use Iir_Chains;  with Xrefs;  package body Sem_Assocs is +   function Rewrite_Non_Object_Association (Assoc : Iir; Inter : Iir) +                                           return Iir +   is +      N_Assoc : Iir; +   begin +      case Get_Kind (Inter) is +         when Iir_Kind_Interface_Package_Declaration => +            N_Assoc := Create_Iir (Iir_Kind_Association_Element_Package); +         when others => +            Error_Kind ("rewrite_non_object_association", Inter); +      end case; +      Location_Copy (N_Assoc, Assoc); +      Set_Formal (N_Assoc, Get_Formal (Assoc)); +      Set_Actual (N_Assoc, Get_Actual (Assoc)); +      Set_Chain (N_Assoc, Get_Chain (Assoc)); +      Set_Associated_Interface (N_Assoc, Inter); +      Set_Whole_Association_Flag (N_Assoc, True); +      Free_Iir (Assoc); +      return N_Assoc; +   end Rewrite_Non_Object_Association; + +   function Extract_Non_Object_Association +     (Assoc_Chain : Iir; Inter_Chain : Iir) return Iir +   is +      Inter : Iir; +      Assoc : Iir; +      --  N_Assoc : Iir; +      Prev_Assoc : Iir; +      Formal : Iir; +      Res : Iir; +   begin +      Inter := Inter_Chain; +      Assoc := Assoc_Chain; +      Prev_Assoc := Null_Iir; +      Res := Null_Iir; + +      --  Common case: only objects in interfaces. +      while Inter /= Null_Iir loop +         exit when Get_Kind (Inter) +           not in Iir_Kinds_Interface_Object_Declaration; +         Inter := Get_Chain (Inter); +      end loop; +      if Inter = Null_Iir then +         return Assoc_Chain; +      end if; + +      loop +         --  Don't try to detect errors. +         if Assoc = Null_Iir then +            return Res; +         end if; + +         Formal := Get_Formal (Assoc); +         if Formal = Null_Iir then +            --  Positional association. + +            if Inter = Null_Iir then +               --  But after a named one.  Be silent on that error. +               null; +            elsif Get_Kind (Inter) +              not in Iir_Kinds_Interface_Object_Declaration +            then +               Assoc := Rewrite_Non_Object_Association (Assoc, Inter); +            end if; +         else +            if Get_Kind (Formal) = Iir_Kind_Simple_Name then +               --  A candidate.  Search the corresponding interface. +               Inter := Find_Name_In_Chain +                 (Inter_Chain, Get_Identifier (Formal)); +               if Inter /= Null_Iir +                 and then +                 Get_Kind (Inter) not in Iir_Kinds_Interface_Object_Declaration +               then +                  Assoc := Rewrite_Non_Object_Association (Assoc, Inter); +               end if; +            end if; + +            --  No more association by position. +            Inter := Null_Iir; +         end if; + +         if Prev_Assoc = Null_Iir then +            Res := Assoc; +         else +            Set_Chain (Prev_Assoc, Assoc); +         end if; +         Prev_Assoc := Assoc; +         Assoc := Get_Chain (Assoc); +      end loop; +   end Extract_Non_Object_Association; +     --  Semantize all arguments of ASSOC_CHAIN     --  Return TRUE if no error.     function Sem_Actual_Of_Association_Chain (Assoc_Chain : Iir) @@ -49,10 +140,11 @@ package body Sem_Assocs is              Has_Named := True;              --  FIXME: check FORMAL is well composed.           elsif Has_Named then +            --  FIXME: do the check in parser.              Error_Msg_Sem ("positional argument after named argument", Assoc);              Ok := False;           end if; -         if Get_Kind (Assoc) /= Iir_Kind_Association_Element_Open then +         if Get_Kind (Assoc) = Iir_Kind_Association_Element_By_Expression then              Res := Sem_Expression_Ov (Get_Actual (Assoc), Null_Iir);              if Res = Null_Iir then                 Ok := False; @@ -136,13 +228,13 @@ package body Sem_Assocs is                 end if;                 case Get_Kind (Formal_Inter) is -                  when Iir_Kind_Signal_Interface_Declaration => +                  when Iir_Kind_Interface_Signal_Declaration =>                       --  LRM93 2.1.1                       --  In a subprogram call, the actual designator                       --  associated with a formal parameter of class                       --  signal must be a signal.                       case Get_Kind (Prefix) is -                        when Iir_Kind_Signal_Interface_Declaration +                        when Iir_Kind_Interface_Signal_Declaration                            | Iir_Kind_Signal_Declaration                            | Iir_Kind_Guard_Signal_Declaration                            | Iir_Kinds_Signal_Attribute => @@ -166,7 +258,7 @@ package body Sem_Assocs is                       end case;                       case Get_Kind (Prefix) is -                        when Iir_Kind_Signal_Interface_Declaration => +                        when Iir_Kind_Interface_Signal_Declaration =>                             Check_Parameter_Association_Restriction                               (Formal_Inter, Prefix, Assoc);                          when Iir_Kind_Guard_Signal_Declaration => @@ -198,19 +290,19 @@ package body Sem_Assocs is                          Error_Msg_Sem ("conversion are not allowed for "                                         & "signal parameters", Assoc);                       end if; -                  when Iir_Kind_Variable_Interface_Declaration => +                  when Iir_Kind_Interface_Variable_Declaration =>                       --  LRM93 2.1.1                       --  The actual designator associated with a formal of                       --  class variable must be a variable.                       case Get_Kind (Prefix) is -                        when Iir_Kind_Variable_Interface_Declaration => +                        when Iir_Kind_Interface_Variable_Declaration =>                             Check_Parameter_Association_Restriction                               (Formal_Inter, Prefix, Assoc);                          when Iir_Kind_Variable_Declaration                            | Iir_Kind_Dereference                            | Iir_Kind_Implicit_Dereference =>                             null; -                        when Iir_Kind_File_Interface_Declaration +                        when Iir_Kind_Interface_File_Declaration                            | Iir_Kind_File_Declaration =>                             --  LRM87 4.3.1.4                             --  Such an object is a member of the variable @@ -223,16 +315,16 @@ package body Sem_Assocs is                             Error_Msg_Sem                               ("variable parameter must be a variable", Assoc);                       end case; -                  when Iir_Kind_File_Interface_Declaration => +                  when Iir_Kind_Interface_File_Declaration =>                       --  LRM93 2.1.1                       --  The actual designator associated with a formal                       --  of class file must be a file.                       case Get_Kind (Prefix) is -                        when Iir_Kind_File_Interface_Declaration +                        when Iir_Kind_Interface_File_Declaration                            | Iir_Kind_File_Declaration =>                             null;                          when Iir_Kind_Variable_Declaration -                          | Iir_Kind_Variable_Interface_Declaration => +                          | Iir_Kind_Interface_Variable_Declaration =>                             if Flags.Vhdl_Std >= Vhdl_93 then                                Error_Msg_Sem ("in vhdl93, file parameter "                                               & "must be a file", Assoc); @@ -253,7 +345,7 @@ package body Sem_Assocs is                          Error_Msg_Sem ("conversion are not allowed for "                                         & "file parameters", Assoc);                       end if; -                  when Iir_Kind_Constant_Interface_Declaration => +                  when Iir_Kind_Interface_Constant_Declaration =>                       --  LRM93 2.1.1                       --  The actual designator associated with a formal of                       --  class constant must be an expression. @@ -302,8 +394,8 @@ package body Sem_Assocs is     --  Check for restrictions in LRM 1.1.1.2     --  Return FALSE in case of error.     function Check_Port_Association_Restriction -     (Formal : Iir_Signal_Interface_Declaration; -      Actual : Iir_Signal_Interface_Declaration; +     (Formal : Iir_Interface_Signal_Declaration; +      Actual : Iir_Interface_Signal_Declaration;        Assoc : Iir)       return Boolean     is @@ -368,12 +460,17 @@ package body Sem_Assocs is                       goto Found;                    end if;                 when Iir_Kind_Choice_By_Range => -                  if Eval_Int_In_Range (Eval_Pos (Index), -                                        Get_Choice_Range (Choice)) -                  then -                     --  FIXME: overlap. -                     raise Internal_Error; -                  end if; +                  declare +                     Choice_Range : constant Iir := Get_Choice_Range (Choice); +                  begin +                     if Get_Expr_Staticness (Choice_Range) = Locally +                       and then +                       Eval_Int_In_Range (Eval_Pos (Index), Choice_Range) +                     then +                        --  FIXME: overlap. +                        raise Internal_Error; +                     end if; +                  end;                 when others =>                    Error_Kind ("add_individual_assoc_index_name", Choice);              end case; @@ -419,8 +516,10 @@ package body Sem_Assocs is        Index := Get_Suffix (Formal);        --  Evaluate index. -      Index := Eval_Range (Index); -      Set_Suffix (Formal, Index); +      if Get_Expr_Staticness (Index) = Locally then +         Index := Eval_Range (Index); +         Set_Suffix (Formal, Index); +      end if;        Choice := Create_Iir (Iir_Kind_Choice_By_Range);        Location_Copy (Choice, Formal); @@ -457,7 +556,7 @@ package body Sem_Assocs is             | Iir_Kind_Slice_Name             | Iir_Kind_Selected_Element =>              Add_Individual_Association_1 (Iassoc, Get_Prefix (Formal_Object)); -         when Iir_Kinds_Interface_Declaration => +         when Iir_Kinds_Interface_Object_Declaration =>              return;           when others =>              Error_Kind ("add_individual_association_1", Formal); @@ -1178,59 +1277,142 @@ package body Sem_Assocs is        return Res;     end Extract_Out_Conversion; -   --  Associate ASSOC with interface INTERFACE -   --  This sets MATCH. -   procedure Sem_Association +   procedure Sem_Association_Open       (Assoc : Iir;        Inter : Iir;        Finish : Boolean;        Match : out Boolean)     is        Formal : Iir; -      Formal_Type : Iir; -      Actual: Iir; -      Out_Conv, In_Conv : Iir; -      Expr : Iir; -      Res_Type : Iir;        Assoc_Kind : Param_Assoc_Type;     begin        Formal := Get_Formal (Assoc); -      --  Handle open association. -      if Get_Kind (Assoc) = Iir_Kind_Association_Element_Open then -         if Formal /= Null_Iir then -            Assoc_Kind := Sem_Formal (Formal, Inter); -            if Assoc_Kind = None then +      if Formal /= Null_Iir then +         Assoc_Kind := Sem_Formal (Formal, Inter); +         if Assoc_Kind = None then +            Match := False; +            return; +         end if; +         Set_Whole_Association_Flag (Assoc, Assoc_Kind = Whole); +         if Finish then +            Sem_Name (Formal); +            Formal := Finish_Sem_Name (Formal); +            Set_Formal (Assoc, Formal); +            if Get_Kind (Formal) in Iir_Kinds_Denoting_Name +              and then Is_Error (Get_Named_Entity (Formal)) +            then                 Match := False;                 return;              end if; -            Set_Whole_Association_Flag (Assoc, Assoc_Kind = Whole); -            if Finish then -               Sem_Name (Formal); -               Formal := Finish_Sem_Name (Formal); -               Set_Formal (Assoc, Formal); -               if Get_Kind (Formal) in Iir_Kinds_Denoting_Name -                 and then Is_Error (Get_Named_Entity (Formal)) -               then -                  Match := False; -                  return; -               end if; -               --  LRM 4.3.3.2  Associations lists -               --  It is an error if an actual of open is associated with a -               --  formal that is associated individually. -               if Assoc_Kind = Individual then -                  Error_Msg_Sem ("cannot associate individually with open", -                                 Assoc); -               end if; +            --  LRM 4.3.3.2  Associations lists +            --  It is an error if an actual of open is associated with a +            --  formal that is associated individually. +            if Assoc_Kind = Individual then +               Error_Msg_Sem ("cannot associate individually with open", +                              Assoc);              end if; -         else -            Set_Whole_Association_Flag (Assoc, True);           end if; -         Match := True; +      else +         Set_Whole_Association_Flag (Assoc, True); +      end if; +      Match := True; +   end Sem_Association_Open; + +   procedure Sem_Association_Package +     (Assoc : Iir; +      Inter : Iir; +      Finish : Boolean; +      Match : out Boolean) +   is +      Formal : constant Iir := Get_Formal (Assoc); +      Actual : Iir; +      Package_Inter : Iir; +   begin +      if not Finish then +         Match := Get_Associated_Interface (Assoc) = Inter; +         return; +      end if; + +      --  Always match (as this is a generic association, there is no +      --  need to resolve overload). +      pragma Assert (Get_Associated_Interface (Assoc) = Inter); +      Match := True; + +      if Formal /= Null_Iir then +         pragma Assert (Get_Kind (Formal) = Iir_Kind_Simple_Name); +         pragma Assert (Get_Identifier (Formal) = Get_Identifier (Inter)); +         Set_Named_Entity (Formal, Inter); +         Set_Base_Name (Formal, Inter); +      end if; + +      --  Analyze actual. +      Actual := Get_Actual (Assoc); +      Actual := Sem_Denoting_Name (Actual); +      Set_Actual (Assoc, Actual); + +      Actual := Get_Named_Entity (Actual); +      if Is_Error (Actual) then +         return; +      end if; + +      --  LRM08 6.5.7.2 Generic map aspects +      --  An actual associated with a formal generic package in a +      --  generic map aspect shall be the name that denotes an instance +      --  of the uninstantiated package named in the formal generic +      --  package declaration [...] +      if Get_Kind (Actual) /= Iir_Kind_Package_Instantiation_Declaration then +         Error_Msg_Sem +           ("actual of association is not a package instantiation", Assoc); +         return; +      end if; + +      Package_Inter := +        Get_Named_Entity (Get_Uninstantiated_Package_Name (Inter)); +      if Get_Named_Entity (Get_Uninstantiated_Package_Name (Actual)) +        /= Package_Inter +      then +         Error_Msg_Sem +           ("actual package name is not an instance of interface package", +            Assoc);           return;        end if; +      --  LRM08 6.5.7.2 Generic map aspects +      --  b) If the formal generic package declaration includes an interface +      --     generic map aspect in the form that includes the box (<>) symbol, +      --     then the instantiaed package denotes by the actual may be any +      --     instance of the uninstantiated package named in the formal +      --     generic package declaration. +      if Get_Generic_Map_Aspect_Chain (Inter) = Null_Iir then +         null; +      else +         --  Other cases not yet handled. +         raise Internal_Error; +      end if; + +      return; +   end Sem_Association_Package; + +   --  Associate ASSOC with interface INTERFACE +   --  This sets MATCH. +   procedure Sem_Association_By_Expression +     (Assoc : Iir; +      Inter : Iir; +      Finish : Boolean; +      Match : out Boolean) +   is +      Formal : Iir; +      Formal_Type : Iir; +      Actual: Iir; +      Out_Conv, In_Conv : Iir; +      Expr : Iir; +      Res_Type : Iir; +      Assoc_Kind : Param_Assoc_Type; +   begin +      Formal := Get_Formal (Assoc); +        --  Pre-semantize formal and extract out conversion.        if Formal /= Null_Iir then           Assoc_Kind := Sem_Formal (Formal, Inter); @@ -1252,7 +1434,7 @@ package body Sem_Assocs is        --  Extract conversion from actual.        Actual := Get_Actual (Assoc);        In_Conv := Null_Iir; -      if Get_Kind (Inter) /= Iir_Kind_Constant_Interface_Declaration then +      if Get_Kind (Inter) /= Iir_Kind_Interface_Constant_Declaration then           case Get_Kind (Actual) is              when Iir_Kind_Function_Call =>                 Expr := Get_Parameter_Association_Chain (Actual); @@ -1403,6 +1585,26 @@ package body Sem_Assocs is              end if;           end if;        end if; +   end Sem_Association_By_Expression; + +      --  Associate ASSOC with interface INTERFACE +   --  This sets MATCH. +   procedure Sem_Association +     (Assoc : Iir; Inter : Iir; Finish : Boolean; Match : out Boolean) is +   begin +      case Get_Kind (Assoc) is +         when Iir_Kind_Association_Element_Open => +            Sem_Association_Open (Assoc, Inter, Finish, Match); + +         when Iir_Kind_Association_Element_Package => +            Sem_Association_Package (Assoc, Inter, Finish, Match); + +         when Iir_Kind_Association_Element_By_Expression => +            Sem_Association_By_Expression (Assoc, Inter, Finish, Match); + +         when others => +            Error_Kind ("sem_assocation", Assoc); +      end case;     end Sem_Association;     procedure Sem_Association_Chain @@ -1609,7 +1811,7 @@ package body Sem_Assocs is           return;        end if; -      --  LRM 8.6 Procedure Call Statement +      --  LRM93 8.6 Procedure Call Statement        --  For each formal parameter of a procedure, a procedure call must        --  specify exactly one corresponding actual parameter.        --  This actual parameter is specified either explicitly, by an @@ -1617,7 +1819,7 @@ package body Sem_Assocs is        --  list, or in the absence of such an association element, by a default        --  expression (see Section 4.3.3.2). -      --  LRM 7.3.3 Function Calls +      --  LRM93 7.3.3 Function Calls        --  For each formal parameter of a function, a function call must        --  specify exactly one corresponding actual parameter.        --  This actual parameter is specified either explicitly, by an @@ -1625,61 +1827,77 @@ package body Sem_Assocs is        --  list, or in the absence of such an association element, by a default        --  expression (see Section 4.3.3.2). -      --  LRM 1.1.1.2 +      --  LRM93 1.1.1.2 / LRM08 6.5.6.3 Port clauses        --  A port of mode IN may be unconnected or unassociated only if its        --  declaration includes a default expression.        --  It is an error if a port of any mode other than IN is unconnected        --  or unassociated and its type is an unconstrained array type. +      --  LRM08 6.5.6.2 Generic clauses +      --  It is an error if no such actual [instantiated package] is specified +      --  for a given formal generic package (either because the formal generic +      --  is unassociated or because the actual is OPEN). +        Inter := Interface_Chain;        Pos := 0;        while Inter /= Null_Iir loop -         if Arg_Matched (Pos) <= Open -           and then Get_Default_Value (Inter) = Null_Iir -         then -            case Missing is -               when Missing_Parameter -                 | Missing_Generic => -                  if Finish then -                     Error_Msg_Sem ("no actual for " & Disp_Node (Inter), Loc); -                  end if; -                  Match := False; -                  return; -               when Missing_Port => -                  case Get_Mode (Inter) is -                     when Iir_In_Mode => -                        if not Finish then -                           raise Internal_Error; -                        end if; -                        Error_Msg_Sem (Disp_Node (Inter) -                                       & " of mode IN must be connected", Loc); -                        Match := False; -                        return; -                     when Iir_Out_Mode -                       | Iir_Linkage_Mode -                       | Iir_Inout_Mode -                       | Iir_Buffer_Mode => -                        if not Finish then -                           raise Internal_Error; -                        end if; -                        if not Is_Fully_Constrained_Type (Get_Type (Inter)) -                        then -                           Error_Msg_Sem -                             ("unconstrained " & Disp_Node (Inter) -                              & " must be connected", Loc); +         if Arg_Matched (Pos) <= Open then +            case Get_Kind (Inter) is +               when Iir_Kinds_Interface_Object_Declaration => +                  if Get_Default_Value (Inter) = Null_Iir then +                     case Missing is +                        when Missing_Parameter +                          | Missing_Generic => +                           if Finish then +                              Error_Msg_Sem +                                ("no actual for " & Disp_Node (Inter), Loc); +                           end if;                             Match := False;                             return; -                        end if; -                     when Iir_Unknown_Mode => -                        raise Internal_Error; -                  end case; -               when Missing_Allowed => -                  null; +                        when Missing_Port => +                           case Get_Mode (Inter) is +                              when Iir_In_Mode => +                                 if not Finish then +                                    raise Internal_Error; +                                 end if; +                                 Error_Msg_Sem +                                   (Disp_Node (Inter) +                                      & " of mode IN must be connected", Loc); +                                 Match := False; +                                 return; +                              when Iir_Out_Mode +                                | Iir_Linkage_Mode +                                | Iir_Inout_Mode +                                | Iir_Buffer_Mode => +                                 if not Finish then +                                    raise Internal_Error; +                                 end if; +                                 if not Is_Fully_Constrained_Type +                                   (Get_Type (Inter)) +                                 then +                                    Error_Msg_Sem +                                      ("unconstrained " & Disp_Node (Inter) +                                         & " must be connected", Loc); +                                    Match := False; +                                    return; +                                 end if; +                              when Iir_Unknown_Mode => +                                 raise Internal_Error; +                           end case; +                        when Missing_Allowed => +                           null; +                     end case; +                  end if; +               when Iir_Kind_Interface_Package_Declaration => +                  Error_Msg_Sem +                    (Disp_Node (Inter) & " must be associated", Loc); +                  Match := False; +               when others => +                  Error_Kind ("sem_association_chain", Inter);              end case;           end if;           Inter := Get_Chain (Inter);           Pos := Pos + 1;        end loop; -      return;     end Sem_Association_Chain;  end Sem_Assocs; diff --git a/sem_assocs.ads b/sem_assocs.ads index 3b5a8841a..ec460e0e3 100644 --- a/sem_assocs.ads +++ b/sem_assocs.ads @@ -18,6 +18,11 @@  with Iirs; use Iirs;  package Sem_Assocs is +   --  Change the kind of association corresponding to non-object interfaces. +   --  Such an association mustn't be handled an like association for object. +   function Extract_Non_Object_Association +     (Assoc_Chain : Iir; Inter_Chain : Iir) return Iir; +     --  Semantize actuals of ASSOC_CHAIN.     --  Check all named associations are after positionnal one.     --  Return TRUE if no error. @@ -48,8 +53,8 @@ package Sem_Assocs is     --  Check for restrictions in §1.1.1.2     --  Return FALSE in case of error.     function Check_Port_Association_Restriction -     (Formal : Iir_Signal_Interface_Declaration; -      Actual : Iir_Signal_Interface_Declaration; +     (Formal : Iir_Interface_Signal_Declaration; +      Actual : Iir_Interface_Signal_Declaration;        Assoc : Iir)       return Boolean;  end Sem_Assocs; diff --git a/sem_decls.adb b/sem_decls.adb index f8647684c..a7c0b4b44 100644 --- a/sem_decls.adb +++ b/sem_decls.adb @@ -32,6 +32,7 @@ with Sem_Scopes; use Sem_Scopes;  with Sem_Names; use Sem_Names;  with Sem_Specs; use Sem_Specs;  with Sem_Types; use Sem_Types; +with Sem_Inst;  with Xrefs; use Xrefs;  use Iir_Chains; @@ -65,240 +66,275 @@ package body Sem_Decls is        end if;     end Check_Signal_Type; -   procedure Sem_Interface_Chain (Interface_Chain: Iir; -                                  Interface_Kind : Interface_Kind_Type) +   procedure Sem_Interface_Object_Declaration +     (Inter, Last : Iir; Interface_Kind : Interface_Kind_Type)     is -      El, A_Type: Iir; +      A_Type: Iir;        Default_Value: Iir; - -      --  LAST is the last interface declaration that has a type.  This is -      --  used to set type and default value for the following declarations -      --  that appeared in a list of identifiers. -      Last : Iir;     begin -      Last := Null_Iir; - -      El := Interface_Chain; -      while El /= Null_Iir loop -         --  Avoid the reanalysed duplicated types. -         --  This is not an optimization, since the unanalysed type must have -         --  been freed. -         A_Type := Get_Subtype_Indication (El); -         if A_Type = Null_Iir then -            pragma Assert (Last /= Null_Iir); -            Set_Subtype_Indication (El, Get_Subtype_Indication (Last)); -            A_Type := Get_Type (Last); -            Default_Value := Get_Default_Value (Last); -         else -            Last := El; -            A_Type := Sem_Subtype_Indication (A_Type); -            Set_Subtype_Indication (El, A_Type); -            A_Type := Get_Type_Of_Subtype_Indication (A_Type); - -            Default_Value := Get_Default_Value (El); -            if Default_Value /= Null_Iir and then A_Type /= Null_Iir then -               Deferred_Constant_Allowed := True; -               Default_Value := Sem_Expression (Default_Value, A_Type); -               Default_Value := -                 Eval_Expr_Check_If_Static (Default_Value, A_Type); -               Deferred_Constant_Allowed := False; -               Check_Read (Default_Value); -            end if; +      --  Avoid the reanalysed duplicated types. +      --  This is not an optimization, since the unanalysed type must have +      --  been freed. +      A_Type := Get_Subtype_Indication (Inter); +      if A_Type = Null_Iir then +         pragma Assert (Last /= Null_Iir); +         Set_Subtype_Indication (Inter, Get_Subtype_Indication (Last)); +         A_Type := Get_Type (Last); +         Default_Value := Get_Default_Value (Last); +      else +         A_Type := Sem_Subtype_Indication (A_Type); +         Set_Subtype_Indication (Inter, A_Type); +         A_Type := Get_Type_Of_Subtype_Indication (A_Type); + +         Default_Value := Get_Default_Value (Inter); +         if Default_Value /= Null_Iir and then A_Type /= Null_Iir then +            Deferred_Constant_Allowed := True; +            Default_Value := Sem_Expression (Default_Value, A_Type); +            Default_Value := +              Eval_Expr_Check_If_Static (Default_Value, A_Type); +            Deferred_Constant_Allowed := False; +            Check_Read (Default_Value);           end if; +      end if; -         Set_Name_Staticness (El, Locally); -         Xref_Decl (El); - -         if A_Type /= Null_Iir then -            Set_Type (El, A_Type); +      Set_Name_Staticness (Inter, Locally); +      Xref_Decl (Inter); -            if Get_Kind (El) = Iir_Kind_Signal_Interface_Declaration then -               case Get_Signal_Kind (El) is -                  when Iir_No_Signal_Kind => -                     null; -                  when Iir_Bus_Kind => -                     --  FIXME: where this test came from ? -                     --  FIXME: from 4.3.1.2 ? -                     if False -                       and -                       (Get_Kind (A_Type) not in Iir_Kinds_Subtype_Definition -                        or else Get_Resolution_Indication (A_Type) = Null_Iir) -                     then -                        Error_Msg_Sem -                          (Disp_Node (A_Type) -                           & " of guarded " & Disp_Node (El) -                           & " is not resolved", El); -                     end if; +      if A_Type /= Null_Iir then +         Set_Type (Inter, A_Type); -                     --  LRM 2.1.1.2  Signal parameter -                     --  It is an error if the declaration of a formal signal -                     --  parameter includes the reserved word BUS. -                     if Flags.Vhdl_Std >= Vhdl_93 -                       and then Interface_Kind in Parameter_Kind_Subtype -                     then -                        Error_Msg_Sem ("signal parameter can't be of kind bus", -                                       El); -                     end if; -                  when Iir_Register_Kind => +         if Get_Kind (Inter) = Iir_Kind_Interface_Signal_Declaration then +            case Get_Signal_Kind (Inter) is +               when Iir_No_Signal_Kind => +                  null; +               when Iir_Bus_Kind => +                  --  FIXME: where this test came from ? +                  --  FIXME: from 4.3.1.2 ? +                  if False +                    and +                    (Get_Kind (A_Type) not in Iir_Kinds_Subtype_Definition +                       or else Get_Resolution_Indication (A_Type) = Null_Iir) +                  then                       Error_Msg_Sem -                       ("interface signal can't be of kind register", El); -               end case; -               Set_Type_Has_Signal (A_Type); -            end if; +                       (Disp_Node (A_Type) & " of guarded " & Disp_Node (Inter) +                          & " is not resolved", Inter); +                  end if; -            case Get_Kind (El) is -               when Iir_Kind_Constant_Interface_Declaration -                 | Iir_Kind_Signal_Interface_Declaration => -                  --  LRM 4.3.2  Interface declarations -                  --  For an interface constant declaration or an interface -                  --  signal declaration, the subtype indication must define -                  --  a subtype that is neither a file type, an access type, -                  --  nor a protected type.  Moreover, the subtype indication -                  --  must not denote a composite type with a subelement that -                  --  is a file type, an access type, or a protected type. -                  Check_Signal_Type (El); -               when Iir_Kind_Variable_Interface_Declaration => -                  case Get_Kind (Get_Base_Type (A_Type)) is -                     when Iir_Kind_File_Type_Definition => -                        if Flags.Vhdl_Std >= Vhdl_93 then -                           Error_Msg_Sem ("variable formal type can't be a " -                                          & "file type (vhdl 93)", El); -                        end if; -                     when Iir_Kind_Protected_Type_Declaration => -                        --  LRM 2.1.1.1  Constant and variable parameters -                        --  It is an error if the mode of the parameter is -                        --  other that INOUT. -                        if Get_Mode (El) /= Iir_Inout_Mode then -                           Error_Msg_Sem -                             ("parameter of protected type must be inout", El); -                        end if; -                     when others => -                        null; -                  end case; -               when Iir_Kind_File_Interface_Declaration => -                  if Get_Kind (Get_Base_Type (A_Type)) -                    /= Iir_Kind_File_Type_Definition +                  --  LRM 2.1.1.2  Signal parameter +                  --  It is an error if the declaration of a formal signal +                  --  parameter includes the reserved word BUS. +                  if Flags.Vhdl_Std >= Vhdl_93 +                    and then Interface_Kind in Parameter_Interface_List                    then                       Error_Msg_Sem -                       ("file formal type must be a file type", El); +                       ("signal parameter can't be of kind bus", Inter);                    end if; -               when others => -                  --  El is not an interface. -                  raise Internal_Error; +               when Iir_Register_Kind => +                  Error_Msg_Sem +                    ("interface signal can't be of kind register", Inter);              end case; +            Set_Type_Has_Signal (A_Type); +         end if; -            if Default_Value /= Null_Iir then -               Set_Default_Value (El, Default_Value); - -               --  LRM 4.3.2  Interface declarations. -               --  It is an error if a default expression appears in an -               --  interface declaration and any of the following conditions -               --  hold: -               --   -  The mode is linkage -               --   -  The interface object is a formal signal parameter -               --   -  The interface object is a formal variable parameter of -               --      mode other than in -               --   -  The subtype indication of the interface declaration -               --      denotes a protected type. -               case Get_Kind (El) is -                  when Iir_Kind_Constant_Interface_Declaration => -                     null; -                  when Iir_Kind_Signal_Interface_Declaration => -                     if Get_Mode (El) = Iir_Linkage_Mode then -                        Error_Msg_Sem -                          ("default expression not allowed for linkage port", -                           El); -                     elsif Interface_Kind in Parameter_Kind_Subtype then -                        Error_Msg_Sem ("default expression not allowed" -                                       & " for signal parameter", El); +         case Get_Kind (Inter) is +            when Iir_Kind_Interface_Constant_Declaration +              | Iir_Kind_Interface_Signal_Declaration => +               --  LRM 4.3.2  Interface declarations +               --  For an interface constant declaration or an interface +               --  signal declaration, the subtype indication must define +               --  a subtype that is neither a file type, an access type, +               --  nor a protected type.  Moreover, the subtype indication +               --  must not denote a composite type with a subelement that +               --  is a file type, an access type, or a protected type. +               Check_Signal_Type (Inter); +            when Iir_Kind_Interface_Variable_Declaration => +               case Get_Kind (Get_Base_Type (A_Type)) is +                  when Iir_Kind_File_Type_Definition => +                     if Flags.Vhdl_Std >= Vhdl_93 then +                        Error_Msg_Sem ("variable formal type can't be a " +                                         & "file type (vhdl 93)", Inter);                       end if; -                  when Iir_Kind_Variable_Interface_Declaration => -                     if Get_Mode (El) /= Iir_In_Mode then -                        Error_Msg_Sem ("default expression not allowed for" -                                       & " out/inout variable parameter", El); -                     elsif Get_Kind (A_Type) -                       = Iir_Kind_Protected_Type_Declaration -                     then +                  when Iir_Kind_Protected_Type_Declaration => +                     --  LRM 2.1.1.1  Constant and variable parameters +                     --  It is an error if the mode of the parameter is +                     --  other that INOUT. +                     if Get_Mode (Inter) /= Iir_Inout_Mode then                          Error_Msg_Sem -                          ("default expression not allowed for" -                           & " variable parameter of protected type", El); +                          ("parameter of protected type must be inout", Inter);                       end if; -                  when Iir_Kind_File_Interface_Declaration => -                     raise Internal_Error;                    when others =>                       null;                 end case; -            end if; -         else -            Set_Type (El, Error_Type); +            when Iir_Kind_Interface_File_Declaration => +               if Get_Kind (Get_Base_Type (A_Type)) +                 /= Iir_Kind_File_Type_Definition +               then +                  Error_Msg_Sem +                    ("file formal type must be a file type", Inter); +               end if; +            when others => +               --  Inter is not an interface. +               raise Internal_Error; +         end case; + +         if Default_Value /= Null_Iir then +            Set_Default_Value (Inter, Default_Value); + +            --  LRM 4.3.2  Interface declarations. +            --  It is an error if a default expression appears in an +            --  interface declaration and any of the following conditions +            --  hold: +            --   -  The mode is linkage +            --   -  The interface object is a formal signal parameter +            --   -  The interface object is a formal variable parameter of +            --      mode other than in +            --   -  The subtype indication of the interface declaration +            --      denotes a protected type. +            case Get_Kind (Inter) is +               when Iir_Kind_Interface_Constant_Declaration => +                  null; +               when Iir_Kind_Interface_Signal_Declaration => +                  if Get_Mode (Inter) = Iir_Linkage_Mode then +                     Error_Msg_Sem +                       ("default expression not allowed for linkage port", +                        Inter); +                  elsif Interface_Kind in Parameter_Interface_List then +                     Error_Msg_Sem ("default expression not allowed" +                                      & " for signal parameter", Inter); +                  end if; +               when Iir_Kind_Interface_Variable_Declaration => +                  if Get_Mode (Inter) /= Iir_In_Mode then +                     Error_Msg_Sem +                       ("default expression not allowed for" +                          & " out or inout variable parameter", Inter); +                  elsif Get_Kind (A_Type) = Iir_Kind_Protected_Type_Declaration +                  then +                     Error_Msg_Sem +                       ("default expression not allowed for" +                          & " variable parameter of protected type", Inter); +                  end if; +               when Iir_Kind_Interface_File_Declaration => +                  raise Internal_Error; +               when others => +                  null; +            end case;           end if; +      else +         Set_Type (Inter, Error_Type); +      end if; -         Sem_Scopes.Add_Name (El); +      Sem_Scopes.Add_Name (Inter); -         --  By default, interface are not static. -         --  This may be changed just below. -         Set_Expr_Staticness (El, None); +      --  By default, interface are not static. +      --  This may be changed just below. +      Set_Expr_Staticness (Inter, None); -         case Interface_Kind is -            when Interface_Generic => -               --  LRM93 1.1.1 -               --  The generic list in the formal generic clause defines -               --  generic constants whose values may be determined by the -               --  environment. -               if Get_Kind (El) /= Iir_Kind_Constant_Interface_Declaration then -                  Error_Msg_Sem -                    ("generic " & Disp_Node (El) & " must be a constant", -                     El); -               else -                  --   LRM93 7.4.2 (Globally static primaries) -                  --   3. a generic constant. -                  Set_Expr_Staticness (El, Globally); -               end if; -            when Interface_Port => -               if Get_Kind (El) /= Iir_Kind_Signal_Interface_Declaration then -                  Error_Msg_Sem -                    ("port " & Disp_Node (El) & " must be a signal", El); -               end if; -            when Interface_Procedure -              | Interface_Function => -               if Get_Kind (El) = Iir_Kind_Variable_Interface_Declaration -                 and then Interface_Kind = Interface_Function -               then -                  Error_Msg_Sem ("variable interface parameter are not " -                                 & "allowed for a function (use a constant)", -                                 El); -               end if; +      case Interface_Kind is +         when Generic_Interface_List => +            --  LRM93 1.1.1 +            --  The generic list in the formal generic clause defines +            --  generic constants whose values may be determined by the +            --  environment. +            if Get_Kind (Inter) /= Iir_Kind_Interface_Constant_Declaration then +               Error_Msg_Sem +                 ("generic " & Disp_Node (Inter) & " must be a constant", +                  Inter); +            else +               --   LRM93 7.4.2 (Globally static primaries) +               --   3. a generic constant. +               Set_Expr_Staticness (Inter, Globally); +            end if; +         when Port_Interface_List => +            if Get_Kind (Inter) /= Iir_Kind_Interface_Signal_Declaration then +               Error_Msg_Sem +                 ("port " & Disp_Node (Inter) & " must be a signal", Inter); +            end if; +         when Parameter_Interface_List => +            if Get_Kind (Inter) = Iir_Kind_Interface_Variable_Declaration +              and then Interface_Kind = Function_Parameter_Interface_List +            then +               Error_Msg_Sem ("variable interface parameter are not " +                                & "allowed for a function (use a constant)", +                              Inter); +            end if; -               --  By default, we suppose a subprogram read the activity of -               --  a signal. -               --  This will be adjusted when the body is analyzed. -               if Get_Kind (El) = Iir_Kind_Signal_Interface_Declaration -                 and then Get_Mode (El) in Iir_In_Modes -               then -                  Set_Has_Active_Flag (El, True); -               end if; +            --  By default, we suppose a subprogram read the activity of +            --  a signal. +            --  This will be adjusted when the body is analyzed. +            if Get_Kind (Inter) = Iir_Kind_Interface_Signal_Declaration +              and then Get_Mode (Inter) in Iir_In_Modes +            then +               Set_Has_Active_Flag (Inter, True); +            end if; -               case Get_Mode (El) is -                  when Iir_Unknown_Mode => -                     raise Internal_Error; -                  when Iir_In_Mode => -                     null; -                  when Iir_Inout_Mode -                    | Iir_Out_Mode => -                     if Interface_Kind = Interface_Function -                       and then -                       Get_Kind (El) /= Iir_Kind_File_Interface_Declaration -                     then -                        Error_Msg_Sem ("mode of a function parameter cannot " -                                       & "be inout or out", El); -                     end if; -                  when Iir_Buffer_Mode -                    | Iir_Linkage_Mode => -                     Error_Msg_Sem ("buffer or linkage mode is not allowed " -                                    & "for a subprogram parameter", El); -               end case; +            case Get_Mode (Inter) is +               when Iir_Unknown_Mode => +                  raise Internal_Error; +               when Iir_In_Mode => +                  null; +               when Iir_Inout_Mode +                 | Iir_Out_Mode => +                  if Interface_Kind = Function_Parameter_Interface_List +                    and then +                    Get_Kind (Inter) /= Iir_Kind_Interface_File_Declaration +                  then +                     Error_Msg_Sem ("mode of a function parameter cannot " +                                      & "be inout or out", Inter); +                  end if; +               when Iir_Buffer_Mode +                 | Iir_Linkage_Mode => +                  Error_Msg_Sem ("buffer or linkage mode is not allowed " +                                   & "for a subprogram parameter", Inter); +            end case; +      end case; +   end Sem_Interface_Object_Declaration; + +   procedure Sem_Interface_Package_Declaration (Inter : Iir) +   is +      Pkg : Iir; +   begin +      --  LRM08 6.5.5 Interface package declarations +      --  the uninstantiated_package_name shall denote an uninstantiated +      --  package declared in a package declaration. +      Pkg := Sem_Uninstantiated_Package_Name (Inter); +      if Pkg = Null_Iir then +         return; +      end if; + +      Sem_Inst.Instantiate_Package_Declaration (Inter, Pkg); + +      if Get_Generic_Map_Aspect_Chain (Inter) /= Null_Iir then +         --  TODO +         raise Internal_Error; +      end if; + +      Sem_Scopes.Add_Name (Inter); +   end Sem_Interface_Package_Declaration; + +   procedure Sem_Interface_Chain (Interface_Chain: Iir; +                                  Interface_Kind : Interface_Kind_Type) +   is +      Inter : Iir; + +      --  LAST is the last interface declaration that has a type.  This is +      --  used to set type and default value for the following declarations +      --  that appeared in a list of identifiers. +      Last : Iir; +   begin +      Last := Null_Iir; + +      Inter := Interface_Chain; +      while Inter /= Null_Iir loop +         case Get_Kind (Inter) is +            when Iir_Kinds_Interface_Object_Declaration => +               Sem_Interface_Object_Declaration (Inter, Last, Interface_Kind); +               Last := Inter; +            when Iir_Kind_Interface_Package_Declaration => +               Sem_Interface_Package_Declaration (Inter); +            when others => +               raise Internal_Error;           end case; -         El := Get_Chain (El); +         Inter := Get_Chain (Inter);        end loop;        --  LRM 10.3  Visibility @@ -312,10 +348,10 @@ package body Sem_Decls is        --  GHDL: this is achieved by making the interface object visible after        --   having analyzed the interface list. -      El := Interface_Chain; -      while El /= Null_Iir loop -         Name_Visible (El); -         El := Get_Chain (El); +      Inter := Interface_Chain; +      while Inter /= Null_Iir loop +         Name_Visible (Inter); +         Inter := Get_Chain (Inter);        end loop;     end Sem_Interface_Chain; @@ -380,7 +416,7 @@ package body Sem_Decls is                                             Iir_Predefined_File_Open_Status);                    --  status : out file_open_status.                    Inter := -                    Create_Iir (Iir_Kind_Variable_Interface_Declaration); +                    Create_Iir (Iir_Kind_Interface_Variable_Declaration);                    Set_Location (Inter, Loc);                    Set_Identifier (Inter, Std_Names.Name_Status);                    Set_Type (Inter, @@ -390,7 +426,7 @@ package body Sem_Decls is                    Append (Last_Interface, Proc, Inter);              end case;              --  File F : FT -            Inter := Create_Iir (Iir_Kind_File_Interface_Declaration); +            Inter := Create_Iir (Iir_Kind_Interface_File_Declaration);              Set_Location (Inter, Loc);              Set_Identifier (Inter, Std_Names.Name_F);              Set_Type (Inter, Type_Definition); @@ -398,7 +434,7 @@ package body Sem_Decls is              Set_Lexical_Layout (Inter, Iir_Lexical_Has_Type);              Append (Last_Interface, Proc, Inter);              --  External_Name : in STRING -            Inter := Create_Iir (Iir_Kind_Constant_Interface_Declaration); +            Inter := Create_Iir (Iir_Kind_Interface_Constant_Declaration);              Set_Location (Inter, Loc);              Set_Identifier (Inter, Std_Names.Name_External_Name);              Set_Type (Inter, Std_Package.String_Type_Definition); @@ -406,7 +442,7 @@ package body Sem_Decls is              Set_Lexical_Layout (Inter, Iir_Lexical_Has_Type);              Append (Last_Interface, Proc, Inter);              --  Open_Kind : in File_Open_Kind := Read_Mode. -            Inter := Create_Iir (Iir_Kind_Constant_Interface_Declaration); +            Inter := Create_Iir (Iir_Kind_Interface_Constant_Declaration);              Set_Location (Inter, Loc);              Set_Identifier (Inter, Std_Names.Name_Open_Kind);              Set_Type (Inter, Std_Package.File_Open_Kind_Type_Definition); @@ -429,7 +465,7 @@ package body Sem_Decls is           Set_Type_Reference (Proc, Decl);           Set_Visible_Flag (Proc, True);           Build_Init (Last_Interface); -         Inter := Create_Iir (Iir_Kind_File_Interface_Declaration); +         Inter := Create_Iir (Iir_Kind_Interface_File_Declaration);           Set_Identifier (Inter, Std_Names.Name_F);           Set_Location (Inter, Loc);           Set_Type (Inter, Type_Definition); @@ -442,9 +478,9 @@ package body Sem_Decls is        end if;        if Flags.Vhdl_Std = Vhdl_87 then -         File_Interface_Kind := Iir_Kind_Variable_Interface_Declaration; +         File_Interface_Kind := Iir_Kind_Interface_Variable_Declaration;        else -         File_Interface_Kind := Iir_Kind_File_Interface_Declaration; +         File_Interface_Kind := Iir_Kind_Interface_File_Declaration;        end if;        -- Create the implicit procedure read declaration. @@ -462,7 +498,7 @@ package body Sem_Decls is        Set_Mode (Inter, Iir_In_Mode);        Set_Lexical_Layout (Inter, Iir_Lexical_Has_Type);        Append (Last_Interface, Proc, Inter); -      Inter := Create_Iir (Iir_Kind_Variable_Interface_Declaration); +      Inter := Create_Iir (Iir_Kind_Interface_Variable_Declaration);        Set_Identifier (Inter, Std_Names.Name_Value);        Set_Location (Inter, Loc);        Set_Subtype_Indication (Inter, Type_Mark); @@ -473,7 +509,7 @@ package body Sem_Decls is        if Get_Kind (Type_Mark_Type) in Iir_Kinds_Array_Type_Definition          and then Get_Constraint_State (Type_Mark_Type) /= Fully_Constrained        then -         Inter := Create_Iir (Iir_Kind_Variable_Interface_Declaration); +         Inter := Create_Iir (Iir_Kind_Interface_Variable_Declaration);           Set_Identifier (Inter, Std_Names.Name_Length);           Set_Location (Inter, Loc);           Set_Type (Inter, Std_Package.Natural_Subtype_Definition); @@ -505,7 +541,7 @@ package body Sem_Decls is        Set_Expr_Staticness (Inter, None);        Set_Lexical_Layout (Inter, Iir_Lexical_Has_Type);        Append (Last_Interface, Proc, Inter); -      Inter := Create_Iir (Iir_Kind_Constant_Interface_Declaration); +      Inter := Create_Iir (Iir_Kind_Interface_Constant_Declaration);        Set_Identifier (Inter, Std_Names.Name_Value);        Set_Location (Inter, Loc);        Set_Subtype_Indication (Inter, Type_Mark); @@ -563,11 +599,11 @@ package body Sem_Decls is     end Create_Implicit_File_Primitives;     function Create_Anonymous_Interface (Atype : Iir) -     return Iir_Constant_Interface_Declaration +     return Iir_Interface_Constant_Declaration     is -      Inter : Iir_Constant_Interface_Declaration; +      Inter : Iir_Interface_Constant_Declaration;     begin -      Inter := Create_Iir (Iir_Kind_Constant_Interface_Declaration); +      Inter := Create_Iir (Iir_Kind_Interface_Constant_Declaration);        Location_Copy (Inter, Atype);        Set_Identifier (Inter, Null_Identifier);        Set_Lexical_Layout (Inter, Iir_Lexical_Has_Type); @@ -654,12 +690,12 @@ package body Sem_Decls is        procedure Add_Shift_Operators        is -         Inter_Chain : Iir_Constant_Interface_Declaration; +         Inter_Chain : Iir_Interface_Constant_Declaration;           Inter_Int : Iir;        begin           Inter_Chain := Create_Anonymous_Interface (Type_Definition); -         Inter_Int := Create_Iir (Iir_Kind_Constant_Interface_Declaration); +         Inter_Int := Create_Iir (Iir_Kind_Interface_Constant_Declaration);           Location_Copy (Inter_Int, Decl);           Set_Identifier (Inter_Int, Null_Identifier);           Set_Mode (Inter_Int, Iir_In_Mode); @@ -988,7 +1024,7 @@ package body Sem_Decls is                (Name_Op_Inequality, Iir_Predefined_Access_Inequality);              declare                 Deallocate_Proc: Iir_Implicit_Procedure_Declaration; -               Var_Interface: Iir_Variable_Interface_Declaration; +               Var_Interface: Iir_Interface_Variable_Declaration;              begin                 Deallocate_Proc :=                   Create_Iir (Iir_Kind_Implicit_Procedure_Declaration); @@ -996,7 +1032,7 @@ package body Sem_Decls is                 Set_Implicit_Definition                   (Deallocate_Proc, Iir_Predefined_Deallocate);                 Var_Interface := -                 Create_Iir (Iir_Kind_Variable_Interface_Declaration); +                 Create_Iir (Iir_Kind_Interface_Variable_Declaration);                 Set_Identifier (Var_Interface, Std_Names.Name_P);                 Set_Type (Var_Interface, Type_Definition);                 Set_Mode (Var_Interface, Iir_Inout_Mode); @@ -1934,8 +1970,10 @@ package body Sem_Decls is        --  6. A component declaration.        Open_Declarative_Region; -      Sem_Interface_Chain (Get_Generic_Chain (Component), Interface_Generic); -      Sem_Interface_Chain (Get_Port_Chain (Component), Interface_Port); +      Sem_Interface_Chain +        (Get_Generic_Chain (Component), Generic_Interface_List); +      Sem_Interface_Chain +        (Get_Port_Chain (Component), Port_Interface_List);        Close_Declarative_Region; diff --git a/sem_decls.ads b/sem_decls.ads index 5ff2b8b8a..7a8e24042 100644 --- a/sem_decls.ads +++ b/sem_decls.ads @@ -18,12 +18,6 @@  with Iirs; use Iirs;  package Sem_Decls is -   --  The kind of an inteface list. -   type Interface_Kind_Type is (Interface_Generic, Interface_Port, -                                Interface_Procedure, Interface_Function); -   subtype Parameter_Kind_Subtype is -     Interface_Kind_Type range Interface_Procedure .. Interface_Function; -     procedure Sem_Interface_Chain (Interface_Chain: Iir;                                    Interface_Kind : Interface_Kind_Type); diff --git a/sem_expr.adb b/sem_expr.adb index 309a2480b..f7af76c09 100644 --- a/sem_expr.adb +++ b/sem_expr.adb @@ -315,7 +315,10 @@ package body Sem_Expr is             | Iir_Kinds_Subtype_Definition             | Iir_Kind_Design_Unit             | Iir_Kind_Architecture_Body +           | Iir_Kind_Configuration_Declaration             | Iir_Kind_Entity_Declaration +           | Iir_Kind_Package_Declaration +           | Iir_Kind_Package_Instantiation_Declaration             | Iir_Kinds_Concurrent_Statement             | Iir_Kinds_Sequential_Statement             | Iir_Kind_Library_Declaration @@ -885,12 +888,13 @@ package body Sem_Expr is     --  Add CALLEE in the callees list of SUBPRG (which must be a subprg decl).     procedure Add_In_Callees_List (Subprg : Iir; Callee : Iir)     is +      Holder : constant Iir := Get_Callees_List_Holder (Subprg);        List : Iir_List;     begin -      List := Get_Callees_List (Subprg); +      List := Get_Callees_List (Holder);        if List = Null_Iir_List then           List := Create_Iir_List; -         Set_Callees_List (Subprg, List); +         Set_Callees_List (Holder, List);        end if;        --  FIXME: May use a flag in IMP to speed up the        --  add operation. @@ -1010,9 +1014,8 @@ package body Sem_Expr is           --  ("(indirect) wait statement not allowed in " & Where, Loc);        end Error_Wait;     begin -      if Get_Kind (Callee) /= Iir_Kind_Procedure_Declaration then -         raise Internal_Error; -      end if; +      pragma Assert (Get_Kind (Callee) = Iir_Kind_Procedure_Declaration); +        case Get_Wait_State (Callee) is           when False =>              return; @@ -1501,14 +1504,14 @@ package body Sem_Expr is              Formal := Get_Base_Name (Formal);              Inter := Null_Iir;           end if; -         if Get_Kind (Formal) = Iir_Kind_Signal_Interface_Declaration +         if Get_Kind (Formal) = Iir_Kind_Interface_Signal_Declaration             and then Get_Mode (Formal) in Iir_Out_Modes           then              Prefix := Name_To_Object (Get_Actual (Param));              if Prefix /= Null_Iir then                 case Get_Kind (Get_Object_Prefix (Prefix)) is                    when Iir_Kind_Signal_Declaration -                    | Iir_Kind_Signal_Interface_Declaration => +                    | Iir_Kind_Interface_Signal_Declaration =>                       Prefix := Get_Longuest_Static_Prefix (Prefix);                       Sem_Stmts.Sem_Add_Driver (Prefix, Stmt);                    when others => @@ -3627,7 +3630,7 @@ package body Sem_Expr is           case Get_Kind (Obj) is              when Iir_Kind_Signal_Declaration                | Iir_Kind_Constant_Declaration -              | Iir_Kind_Constant_Interface_Declaration +              | Iir_Kind_Interface_Constant_Declaration                | Iir_Kind_Variable_Declaration                | Iir_Kind_Attribute_Value                | Iir_Kind_Iterator_Declaration @@ -3636,7 +3639,7 @@ package body Sem_Expr is              when Iir_Kinds_Quantity_Declaration =>                 return;              when Iir_Kind_File_Declaration -              | Iir_Kind_File_Interface_Declaration => +              | Iir_Kind_Interface_File_Declaration =>                 --  LRM 4.3.2  Interface declarations                 --  The value of an object is said to be read [...]                 --   -  When the object is a file and a READ operation is @@ -3644,8 +3647,8 @@ package body Sem_Expr is                 return;              when Iir_Kind_Object_Alias_Declaration =>                 Obj := Get_Name (Obj); -            when Iir_Kind_Signal_Interface_Declaration -              | Iir_Kind_Variable_Interface_Declaration => +            when Iir_Kind_Interface_Signal_Declaration +              | Iir_Kind_Interface_Variable_Declaration =>                 case Get_Mode (Obj) is                    when Iir_In_Mode                      | Iir_Inout_Mode diff --git a/sem_inst.adb b/sem_inst.adb index c368e1f69..d6368397f 100644 --- a/sem_inst.adb +++ b/sem_inst.adb @@ -19,6 +19,7 @@ with Nodes;  with Nodes_Meta;  with Types; use Types;  with Iirs_Utils; use Iirs_Utils; +with Errorout; use Errorout;  package body Sem_Inst is     --  Table of origin.  This is an extension of vhdl nodes to track the @@ -330,7 +331,7 @@ package body Sem_Inst is        begin           Res := Get_Instance (N); -         if Kind = Iir_Kind_Constant_Interface_Declaration +         if Kind = Iir_Kind_Interface_Constant_Declaration             and then Get_Identifier (N) = Null_Identifier             and then Res /= Null_Iir           then @@ -355,8 +356,11 @@ package body Sem_Inst is           for I in Fields'Range loop              F := Fields (I); +            --  Fields that are handled specially.              case F is                 when Field_Index_Subtype_List => +                  --  Index_Subtype_List is always a reference, so retrieve +                  --  the instance of the referenced list.                    declare                       List : Iir_List;                    begin @@ -389,6 +393,9 @@ package body Sem_Inst is                 --  Subprogram body is a forward declaration.                 Set_Subprogram_Body (Res, Null_Iir);              when others => +               --  TODO: other forward references: +               --  incomplete constant +               --  attribute_value                 null;           end case; @@ -396,6 +403,213 @@ package body Sem_Inst is        end;     end Instantiate_Iir; +   --  As the scope generic interfaces extends beyond the immediate scope (see +   --  LRM08 12.2 Scope of declarations), they must be instantiated. +   function Instantiate_Generic_Chain (Inst : Iir; Inters : Iir) return Iir +   is +      Inter : Iir; +      First : Iir; +      Last : Iir; +      Res : Iir; +   begin +      First := Null_Iir; +      Last := Null_Iir; + +      Inter := Inters; +      while Inter /= Null_Iir loop +         --  Create a copy of the interface.  FIXME: is it really needed ? +         Res := Create_Iir (Get_Kind (Inter)); +         Set_Location (Res, Instantiate_Loc); +         Set_Parent (Res, Inst); +         Set_Identifier (Res, Get_Identifier (Inter)); +         Set_Visible_Flag (Res, Get_Visible_Flag (Inter)); + +         Set_Origin (Res, Inter); +         Set_Instance (Inter, Res); + +         case Get_Kind (Res) is +            when Iir_Kind_Interface_Constant_Declaration => +               Set_Type (Res, Get_Type (Inter)); +               Set_Subtype_Indication (Res, Get_Subtype_Indication (Inter)); +               Set_Mode (Res, Get_Mode (Inter)); +               Set_Lexical_Layout (Res, Get_Lexical_Layout (Inter)); +               Set_Expr_Staticness (Res, Get_Expr_Staticness (Inter)); +               Set_Name_Staticness (Res, Get_Name_Staticness (Inter)); +            when Iir_Kind_Interface_Package_Declaration => +               Set_Uninstantiated_Package_Name +                 (Res, Get_Uninstantiated_Package_Name (Inter)); +            when others => +               Error_Kind ("instantiate_generic_chain", Res); +         end case; + +         --  Append +         if First = Null_Iir then +            First := Res; +         else +            Set_Chain (Last, Res); +         end if; +         Last := Res; + +         Inter := Get_Chain (Inter); +      end loop; + +      return First; +   end Instantiate_Generic_Chain; + +   procedure Set_Instance_On_Chain (Chain : Iir; Inst_Chain : Iir); +   procedure Set_Instance_On_Iir_List (N : Iir_List; Inst : Iir_List); + +   procedure Set_Instance_On_Iir (N : Iir; Inst : Iir) is +   begin +      if N = Null_Iir then +         pragma Assert (Inst = Null_Iir); +         return; +      end if; +      pragma Assert (Inst /= Null_Iir); + +      declare +         use Nodes_Meta; +         Kind : constant Iir_Kind := Get_Kind (N); +         Fields : constant Fields_Array := Get_Fields (Kind); +         F : Fields_Enum; +      begin +         pragma Assert (Get_Kind (Inst) = Kind); + +         if Kind = Iir_Kind_Interface_Constant_Declaration +           and then Get_Identifier (N) = Null_Identifier +         then +            --  Anonymous constant interface declarations are the only nodes +            --  that can be shared.  Handle that very special case. +            return; +         end if; + +         --  pragma Assert (Get_Instance (N) = Null_Iir); +         Set_Instance (N, Inst); + +         for I in Fields'Range loop +            F := Fields (I); + +            case Get_Field_Type (F) is +               when Type_Iir => +                  declare +                     S : constant Iir := Get_Iir (N, F); +                     S_Inst : constant Iir := Get_Iir (Inst, F); +                  begin +                     case Get_Field_Attribute (F) is +                        when Attr_None => +                           Set_Instance_On_Iir (S, S_Inst); +                        when Attr_Ref => +                           null; +                        when Attr_Maybe_Ref => +                           if not Get_Is_Ref (N) then +                              Set_Instance_On_Iir (S, S_Inst); +                           end if; +                        when Attr_Chain => +                           Set_Instance_On_Chain (S, S_Inst); +                        when Attr_Chain_Next => +                           null; +                        when Attr_Of_Ref => +                           --  Can only appear in list. +                           raise Internal_Error; +                     end case; +                  end; +               when Type_Iir_List => +                  declare +                     S : constant Iir_List := Get_Iir_List (N, F); +                     S_Inst : constant Iir_List := Get_Iir_List (Inst, F); +                  begin +                     case Get_Field_Attribute (F) is +                        when Attr_None => +                           Set_Instance_On_Iir_List (S, S_Inst); +                        when Attr_Of_Ref +                          | Attr_Ref => +                           null; +                        when others => +                           --  Ref is specially handled in Instantiate_Iir. +                           --  Others cannot appear for lists. +                           raise Internal_Error; +                     end case; +                  end; +               when others => +                  null; +            end case; +         end loop; +      end; +   end Set_Instance_On_Iir; + +   procedure Set_Instance_On_Iir_List (N : Iir_List; Inst : Iir_List) +   is +      El : Iir; +      El_Inst : Iir; +   begin +      case N is +         when Null_Iir_List +           | Iir_List_All +           | Iir_List_Others => +            pragma Assert (Inst = N); +            return; +         when others => +            for I in Natural loop +               El := Get_Nth_Element (N, I); +               El_Inst := Get_Nth_Element (Inst, I); +               exit when El = Null_Iir; +               pragma Assert (El_Inst /= Null_Iir); + +               Set_Instance_On_Iir (El, El_Inst); +            end loop; +            pragma Assert (El_Inst = Null_Iir); +      end case; +   end Set_Instance_On_Iir_List; + +   procedure Set_Instance_On_Chain (Chain : Iir; Inst_Chain : Iir) +   is +      El : Iir; +      Inst_El : Iir; +   begin +      El := Chain; +      Inst_El := Inst_Chain; +      while El /= Null_Iir loop +         pragma Assert (Inst_El /= Null_Iir); +         Set_Instance_On_Iir (El, Inst_El); +         El := Get_Chain (El); +         Inst_El := Get_Chain (Inst_El); +      end loop; +      pragma Assert (Inst_El = Null_Iir); +   end Set_Instance_On_Chain; + +   --  In the instance, replace references (and inner references) to interface +   --  package declaration to the associated package. +   procedure Instantiate_Generic_Map_Chain (Inst : Iir; Pkg : Iir) +   is +      pragma Unreferenced (Pkg); +      Assoc : Iir; +   begin +      Assoc := Get_Generic_Map_Aspect_Chain (Inst); +      while Assoc /= Null_Iir loop +         case Get_Kind (Assoc) is +            when Iir_Kind_Association_Element_By_Expression +              | Iir_Kind_Association_Element_By_Individual +              | Iir_Kind_Association_Element_Open => +               null; +            when Iir_Kind_Association_Element_Package => +               declare +                  Sub_Inst : constant Iir := +                    Get_Named_Entity (Get_Actual (Assoc)); +                  Sub_Pkg : constant Iir := Get_Associated_Interface (Assoc); +               begin +                  Set_Instance (Sub_Pkg, Sub_Inst); +                  Set_Instance_On_Chain (Get_Generic_Chain (Sub_Pkg), +                                         Get_Generic_Chain (Sub_Inst)); +                  Set_Instance_On_Chain (Get_Declaration_Chain (Sub_Pkg), +                                        Get_Declaration_Chain (Sub_Inst)); +               end; +            when others => +               Error_Kind ("instantiate_generic_map_chain", Assoc); +         end case; +         Assoc := Get_Chain (Assoc); +      end loop; +   end Instantiate_Generic_Map_Chain; +     procedure Instantiate_Package_Declaration (Inst : Iir; Pkg : Iir)     is        Header : constant Iir := Get_Package_Header (Pkg); @@ -411,7 +625,8 @@ package body Sem_Inst is        Set_Origin (Pkg, Inst);        Set_Generic_Chain -        (Inst, Instantiate_Iir_Chain (Get_Generic_Chain (Header))); +        (Inst, Instantiate_Generic_Chain (Inst, Get_Generic_Chain (Header))); +      Instantiate_Generic_Map_Chain (Inst, Pkg);        Set_Declaration_Chain          (Inst, Instantiate_Iir_Chain (Get_Declaration_Chain (Pkg))); diff --git a/sem_names.adb b/sem_names.adb index 2958753e5..151e81708 100644 --- a/sem_names.adb +++ b/sem_names.adb @@ -442,9 +442,8 @@ package body Sem_Names is        Prefix := Get_Prefix (Name);        Obj := Get_Named_Entity (Prefix);        if Obj /= Null_Iir -        and then -        (Get_Kind (Obj) = Iir_Kind_Variable_Declaration -           or Get_Kind (Obj) = Iir_Kind_Variable_Interface_Declaration) +        and then Kind_In (Obj, Iir_Kind_Variable_Declaration, +                          Iir_Kind_Interface_Variable_Declaration)          and then Get_Type (Obj) /= Null_Iir        then           if Get_Kind (Get_Type (Obj)) /= Iir_Kind_Protected_Type_Declaration @@ -1247,10 +1246,10 @@ package body Sem_Names is             | Iir_Kind_Guard_Signal_Declaration             | Iir_Kind_Signal_Declaration             | Iir_Kind_Variable_Declaration -           | Iir_Kind_File_Interface_Declaration => +           | Iir_Kind_Interface_File_Declaration =>              null; -         when Iir_Kind_Variable_Interface_Declaration -           | Iir_Kind_Signal_Interface_Declaration => +         when Iir_Kind_Interface_Variable_Declaration +           | Iir_Kind_Interface_Signal_Declaration =>              --  When referenced as a formal name (FIXME: this is an              --  approximation), the rules don't apply.              if not Get_Is_Within_Flag (Get_Parent (Obj)) then @@ -1408,7 +1407,8 @@ package body Sem_Names is             | Iir_Kind_Group_Declaration             | Iir_Kind_Attribute_Declaration             | Iir_Kind_Non_Object_Alias_Declaration -           | Iir_Kind_Library_Declaration => +           | Iir_Kind_Library_Declaration +           | Iir_Kind_Interface_Package_Declaration =>              Name_Res := Finish_Sem_Denoting_Name (Name, Res);              Set_Base_Name (Name_Res, Res);              return Name_Res; @@ -2892,7 +2892,7 @@ package body Sem_Names is        end if;        Set_Base_Name (Res, Res); -      if Get_Kind (Prefix) = Iir_Kind_Signal_Interface_Declaration then +      if Get_Kind (Prefix) = Iir_Kind_Interface_Signal_Declaration then           --  LRM93 2.1.1.2 / LRM08 4.2.2.3           --           --  It is an error if signal-valued attributes 'STABLE , 'QUIET, @@ -2923,7 +2923,7 @@ package body Sem_Names is        Base := Get_Object_Prefix (Prefix);        case Get_Kind (Base) is           when Iir_Kind_Signal_Declaration -           | Iir_Kind_Signal_Interface_Declaration +           | Iir_Kind_Interface_Signal_Declaration             | Iir_Kind_Guard_Signal_Declaration             | Iir_Kinds_Signal_Attribute =>              null; @@ -3032,7 +3032,7 @@ package body Sem_Names is              case Get_Kind (Base) is                 when Iir_Kind_Signal_Declaration =>                    null; -               when Iir_Kind_Signal_Interface_Declaration => +               when Iir_Kind_Interface_Signal_Declaration =>                    case Get_Mode (Base) is                       when Iir_Buffer_Mode                         | Iir_Inout_Mode @@ -3124,7 +3124,7 @@ package body Sem_Names is             | Iir_Kind_Constant_Declaration             | Iir_Kind_Signal_Declaration             | Iir_Kind_Variable_Declaration -           | Iir_Kind_Variable_Interface_Declaration +           | Iir_Kind_Interface_Variable_Declaration             | Iir_Kind_Iterator_Declaration             | Iir_Kind_Component_Declaration             | Iir_Kinds_Concurrent_Statement @@ -3137,8 +3137,8 @@ package body Sem_Names is             | Iir_Kind_Non_Object_Alias_Declaration =>              null; -         when Iir_Kind_Signal_Interface_Declaration -           | Iir_Kind_Constant_Interface_Declaration => +         when Iir_Kind_Interface_Signal_Declaration +           | Iir_Kind_Interface_Constant_Declaration =>              if Get_Identifier (Attr) /= Name_Simple_Name                and then Get_Kind (Get_Parent (Prefix))                = Iir_Kind_Component_Declaration @@ -3650,10 +3650,10 @@ package body Sem_Names is             | Iir_Kind_File_Declaration             | Iir_Kind_Constant_Declaration             | Iir_Kind_Iterator_Declaration -           | Iir_Kind_Constant_Interface_Declaration -           | Iir_Kind_Variable_Interface_Declaration -           | Iir_Kind_Signal_Interface_Declaration -           | Iir_Kind_File_Interface_Declaration +           | Iir_Kind_Interface_Constant_Declaration +           | Iir_Kind_Interface_Variable_Declaration +           | Iir_Kind_Interface_Signal_Declaration +           | Iir_Kind_Interface_File_Declaration             | Iir_Kind_Slice_Name             | Iir_Kind_Indexed_Name             | Iir_Kind_Selected_Element @@ -3681,10 +3681,10 @@ package body Sem_Names is             | Iir_Kind_File_Declaration             | Iir_Kind_Constant_Declaration             | Iir_Kind_Iterator_Declaration -           | Iir_Kind_Constant_Interface_Declaration -           | Iir_Kind_Variable_Interface_Declaration -           | Iir_Kind_Signal_Interface_Declaration -           | Iir_Kind_File_Interface_Declaration +           | Iir_Kind_Interface_Constant_Declaration +           | Iir_Kind_Interface_Variable_Declaration +           | Iir_Kind_Interface_Signal_Declaration +           | Iir_Kind_Interface_File_Declaration             | Iir_Kind_Slice_Name             | Iir_Kind_Indexed_Name             | Iir_Kind_Selected_Element @@ -3744,6 +3744,7 @@ package body Sem_Names is             | Iir_Kind_Configuration_Declaration             | Iir_Kind_Package_Declaration             | Iir_Kind_Package_Instantiation_Declaration +           | Iir_Kind_Interface_Package_Declaration             | Iir_Kind_Library_Declaration             | Iir_Kinds_Subprogram_Declaration             | Iir_Kind_Component_Declaration => diff --git a/sem_scopes.adb b/sem_scopes.adb index 6590e4825..71c758575 100644 --- a/sem_scopes.adb +++ b/sem_scopes.adb @@ -983,10 +983,11 @@ package body Sem_Scopes is             | Iir_Kind_File_Declaration             | Iir_Kind_Object_Alias_Declaration             | Iir_Kind_Non_Object_Alias_Declaration -           | Iir_Kind_Constant_Interface_Declaration -           | Iir_Kind_Signal_Interface_Declaration -           | Iir_Kind_Variable_Interface_Declaration -           | Iir_Kind_File_Interface_Declaration +           | Iir_Kind_Interface_Constant_Declaration +           | Iir_Kind_Interface_Signal_Declaration +           | Iir_Kind_Interface_Variable_Declaration +           | Iir_Kind_Interface_File_Declaration +           | Iir_Kind_Interface_Package_Declaration             | Iir_Kind_Component_Declaration             | Iir_Kind_Attribute_Declaration             | Iir_Kind_Group_Template_Declaration @@ -1284,6 +1285,14 @@ package body Sem_Scopes is              Add_Package_Declarations (Name, True);           when Iir_Kind_Package_Instantiation_Declaration =>              Add_Package_Instantiation_Declarations (Name, True); +         when Iir_Kind_Interface_Package_Declaration => +            --  LRM08 6.5.5 Interface package declarations +            --  Within an entity declaration, an architecture body, a +            --  component declaration, or an uninstantiated subprogram or +            --  package declaration that declares a given interface package, +            --  the name of the given interface package denotes an undefined +            --  instance of the uninstantiated package. +            Add_Package_Instantiation_Declarations (Name, True);           when Iir_Kind_Error =>              null;           when others => diff --git a/sem_specs.adb b/sem_specs.adb index 4c16a078d..ca821b27e 100644 --- a/sem_specs.adb +++ b/sem_specs.adb @@ -59,14 +59,14 @@ package body Sem_Specs is           when Iir_Kind_Subtype_Declaration =>              return Tok_Subtype;           when Iir_Kind_Constant_Declaration -           | Iir_Kind_Constant_Interface_Declaration => +           | Iir_Kind_Interface_Constant_Declaration =>              return Tok_Constant;           when Iir_Kind_Signal_Declaration -           | Iir_Kind_Signal_Interface_Declaration +           | Iir_Kind_Interface_Signal_Declaration             | Iir_Kind_Guard_Signal_Declaration =>              return Tok_Signal;           when Iir_Kind_Variable_Declaration -           | Iir_Kind_Variable_Interface_Declaration => +           | Iir_Kind_Interface_Variable_Declaration =>              return Tok_Variable;           when Iir_Kind_Component_Declaration =>              return Tok_Component; @@ -100,7 +100,7 @@ package body Sem_Specs is           when Iir_Kind_Group_Declaration =>              return Tok_Group;           when Iir_Kind_File_Declaration -           | Iir_Kind_File_Interface_Declaration => +           | Iir_Kind_Interface_File_Declaration =>              return Tok_File;           when Iir_Kind_Attribute_Declaration =>              --  Even if an attribute can't have a attribute... @@ -898,7 +898,7 @@ package body Sem_Specs is                 --  denotes a guarded signal.                 case Get_Kind (Prefix) is                    when Iir_Kind_Signal_Declaration -                    | Iir_Kind_Signal_Interface_Declaration => +                    | Iir_Kind_Interface_Signal_Declaration =>                       null;                    when others =>                       Error_Msg_Sem ("object must be a signal", El); diff --git a/sem_stmts.adb b/sem_stmts.adb index d9758073b..b5912fbc6 100644 --- a/sem_stmts.adb +++ b/sem_stmts.adb @@ -344,7 +344,7 @@ package body Sem_Stmts is        Target_Prefix := Get_Object_Prefix (Target_Object);        Targ_Obj_Kind := Get_Kind (Target_Prefix);        case Targ_Obj_Kind is -         when Iir_Kind_Signal_Interface_Declaration => +         when Iir_Kind_Interface_Signal_Declaration =>              if not Iir_Mode_Writable (Get_Mode (Target_Prefix)) then                 Error_Msg_Sem                   (Disp_Node (Target_Prefix) & " can't be assigned", Target); @@ -373,7 +373,7 @@ package body Sem_Stmts is        --   kind.  This is determined at run-time, according to the actual        --   associated with the formal.        --  GHDL: parent of target cannot be a function. -      if Targ_Obj_Kind = Iir_Kind_Signal_Interface_Declaration +      if Targ_Obj_Kind = Iir_Kind_Interface_Signal_Declaration          and then          Get_Kind (Get_Parent (Target_Prefix)) = Iir_Kind_Procedure_Declaration        then @@ -414,7 +414,7 @@ package body Sem_Stmts is        end if;        Target_Prefix := Get_Object_Prefix (Target_Object);        case Get_Kind (Target_Prefix) is -         when Iir_Kind_Variable_Interface_Declaration => +         when Iir_Kind_Interface_Variable_Declaration =>              if not Iir_Mode_Writable (Get_Mode (Target_Prefix)) then                 Error_Msg_Sem (Disp_Node (Target_Prefix)                                & " cannot be written (bad mode)", Target); @@ -1023,7 +1023,7 @@ package body Sem_Stmts is                   | Iir_Kind_Guard_Signal_Declaration                   | Iir_Kinds_Signal_Attribute =>                    null; -               when Iir_Kind_Signal_Interface_Declaration => +               when Iir_Kind_Interface_Signal_Declaration =>                    if not Iir_Mode_Readable (Get_Mode (Prefix)) then                       Error_Msg_Sem                         (Disp_Node (Res) & " of mode out" @@ -1450,9 +1450,9 @@ package body Sem_Stmts is        Header := Get_Block_Header (Stmt);        if Header /= Null_Iir then           Generic_Chain := Get_Generic_Chain (Header); -         Sem_Interface_Chain (Generic_Chain, Interface_Generic); +         Sem_Interface_Chain (Generic_Chain, Generic_Interface_List);           Port_Chain := Get_Port_Chain (Header); -         Sem_Interface_Chain (Port_Chain, Interface_Port); +         Sem_Interface_Chain (Port_Chain, Port_Interface_List);           --  LRM 9.1           --  Such actuals are evaluated in the context of the enclosing @@ -1619,7 +1619,7 @@ package body Sem_Stmts is        -- FIXME.        case Get_Kind (Guard) is           when Iir_Kind_Signal_Declaration -           | Iir_Kind_Signal_Interface_Declaration +           | Iir_Kind_Interface_Signal_Declaration             | Iir_Kind_Guard_Signal_Declaration =>              null;           when others => diff --git a/sem_types.adb b/sem_types.adb index 27eee590a..12f276be1 100644 --- a/sem_types.adb +++ b/sem_types.adb @@ -776,8 +776,6 @@ package body Sem_Types is        Set_Type_Staticness (Def, Locally);        Set_Signal_Type_Flag (Def, True); -      Create_Range_Constraint_For_Enumeration_Type (Def); -        --  Makes all literal visible.        declare           El: Iir; @@ -806,6 +804,8 @@ package body Sem_Types is        end;        Set_Resolved_Flag (Def, False); +      Create_Range_Constraint_For_Enumeration_Type (Def); +        --  Identifier IEEE.Std_Logic_1164.Std_Ulogic.        if Get_Identifier (Decl) = Std_Names.Name_Std_Ulogic          and then @@ -1245,7 +1245,7 @@ package body Sem_Types is        if Decl = Null_Iir or else Get_Chain (Decl) /= Null_Iir then           return False;        end if; -      if Get_Kind (Decl) /= Iir_Kind_Constant_Interface_Declaration then +      if Get_Kind (Decl) /= Iir_Kind_Interface_Constant_Declaration then           return False;        end if;        -- LRM93 2.4 @@ -1370,6 +1370,7 @@ package body Sem_Types is        Subtype_Index_List : Iir_List;        Resolv_Func : Iir := Null_Iir;        Resolv_El : Iir := Null_Iir; +      Resolv_Ind : Iir;     begin        if Resolution /= Null_Iir then           --  A resolution indication is present. @@ -1545,8 +1546,19 @@ package body Sem_Types is           --  FIXME: may a resolution indication for a record be incomplete ?           Set_Resolved_Flag (Res, Get_Resolved_Flag (El_Def));        elsif Get_Kind (Type_Mark) = Iir_Kind_Array_Subtype_Definition then -         Set_Resolution_Indication -           (Res, Get_Resolution_Indication (Type_Mark)); +         Resolv_Ind := Get_Resolution_Indication (Type_Mark); +         if Resolv_Ind /= Null_Iir then +            case Get_Kind (Resolv_Ind) is +               when Iir_Kinds_Denoting_Name => +                  Error_Kind ("sem_array_constraint(resolution)", Resolv_Ind); +               when Iir_Kind_Array_Element_Resolution => +                  --  Already applied to the element. +                  Resolv_Ind := Null_Iir; +               when others => +                  Error_Kind ("sem_array_constraint(resolution2)", Resolv_Ind); +            end case; +            Set_Resolution_Indication (Res, Resolv_Ind); +         end if;           Set_Resolved_Flag (Res, Get_Resolved_Flag (Type_Mark));        end if; diff --git a/std_package.adb b/std_package.adb index ea2a6916f..1edfb6cda 100644 --- a/std_package.adb +++ b/std_package.adb @@ -292,8 +292,8 @@ package body Std_Package is                                    Inter2_Type : Iir := Null_Iir)        is           Decl : Iir_Implicit_Function_Declaration; -         Inter : Iir_Constant_Interface_Declaration; -         Inter2 : Iir_Constant_Interface_Declaration; +         Inter : Iir_Interface_Constant_Declaration; +         Inter2 : Iir_Interface_Constant_Declaration;        begin           Decl := Create_Std_Decl (Iir_Kind_Implicit_Function_Declaration);           Set_Std_Identifier (Decl, Name); @@ -301,7 +301,7 @@ package body Std_Package is           Set_Pure_Flag (Decl, True);           Set_Implicit_Definition (Decl, Imp); -         Inter := Create_Iir (Iir_Kind_Constant_Interface_Declaration); +         Inter := Create_Iir (Iir_Kind_Interface_Constant_Declaration);           Set_Identifier (Inter, Std_Names.Name_Value);           Set_Type (Inter, Inter_Type);           Set_Mode (Inter, Iir_In_Mode); @@ -309,7 +309,7 @@ package body Std_Package is           Set_Interface_Declaration_Chain (Decl, Inter);           if Inter2_Id /= Null_Identifier then -            Inter2 := Create_Iir (Iir_Kind_Constant_Interface_Declaration); +            Inter2 := Create_Iir (Iir_Kind_Interface_Constant_Declaration);              Set_Identifier (Inter2, Inter2_Id);              Set_Type (Inter2, Inter2_Type);              Set_Mode (Inter2, Iir_In_Mode); @@ -327,7 +327,7 @@ package body Std_Package is          (Name : Name_Id; Func : Iir_Predefined_Functions; Inter_Type : Iir)        is           Decl : Iir_Implicit_Function_Declaration; -         Inter : Iir_Constant_Interface_Declaration; +         Inter : Iir_Interface_Constant_Declaration;        begin           Decl := Create_Std_Decl (Iir_Kind_Implicit_Function_Declaration);           Set_Std_Identifier (Decl, Name); @@ -335,7 +335,7 @@ package body Std_Package is           Set_Pure_Flag (Decl, True);           Set_Implicit_Definition (Decl, Func); -         Inter := Create_Iir (Iir_Kind_Signal_Interface_Declaration); +         Inter := Create_Iir (Iir_Kind_Interface_Signal_Declaration);           Set_Identifier (Inter, Std_Names.Name_S);           Set_Type (Inter, Inter_Type);           Set_Mode (Inter, Iir_In_Mode); diff --git a/translate/ghdldrv/ghdlprint.adb b/translate/ghdldrv/ghdlprint.adb index 73d5ba7ad..01040002c 100644 --- a/translate/ghdldrv/ghdlprint.adb +++ b/translate/ghdldrv/ghdlprint.adb @@ -1660,11 +1660,11 @@ package body Ghdlprint is                       C := 'F';                    when Iir_Kind_Procedure_Declaration =>                       C := 'p'; -                  when Iir_Kind_Signal_Interface_Declaration => +                  when Iir_Kind_Interface_Signal_Declaration =>                       C := 's';                    when Iir_Kind_Signal_Declaration =>                       C := 'S'; -                  when Iir_Kind_Constant_Interface_Declaration => +                  when Iir_Kind_Interface_Constant_Declaration =>                       C := 'c';                    when Iir_Kind_Constant_Declaration =>                       C := 'C'; diff --git a/translate/trans_analyzes.adb b/translate/trans_analyzes.adb index cf800f0d4..8147e93bd 100644 --- a/translate/trans_analyzes.adb +++ b/translate/trans_analyzes.adb @@ -33,7 +33,7 @@ package body Trans_Analyzes is     begin        Base := Get_Object_Prefix (Target);        --  Assigment to subprogram interface does not create a driver. -      if Get_Kind (Base) = Iir_Kind_Signal_Interface_Declaration +      if Get_Kind (Base) = Iir_Kind_Interface_Signal_Declaration          and then          Get_Kind (Get_Parent (Base)) = Iir_Kind_Procedure_Declaration        then @@ -92,7 +92,7 @@ package body Trans_Analyzes is                    if Get_Kind (Assoc)                      = Iir_Kind_Association_Element_By_Expression                      and then -                    Get_Kind (Formal) = Iir_Kind_Signal_Interface_Declaration +                    Get_Kind (Formal) = Iir_Kind_Interface_Signal_Declaration                      and then Get_Mode (Formal) /= Iir_In_Mode                    then                       Status := Extract_Driver_Target (Get_Actual (Assoc)); diff --git a/translate/translation.adb b/translate/translation.adb index af703ef59..e639809b7 100644 --- a/translate/translation.adb +++ b/translate/translation.adb @@ -224,6 +224,9 @@ package body Translation is        Null_Var_Scope : constant Var_Scope_Type; +      type Var_Type is private; +      Null_Var : constant Var_Type; +        --  Return the record type for SCOPE.        function Get_Scope_Type (Scope : Var_Scope_Type) return O_Tnode; @@ -277,21 +280,26 @@ package body Translation is          (Scope : in out Var_Scope_Type;           Scope_Field : O_Fnode; Scope_Parent : Var_Scope_Acc); -      --  Variables defined in SCOPE_TYPE can be accessed by dereferencing +      --  Variables defined in SCOPE can be accessed by dereferencing        --  field SCOPE_FIELD defined in SCOPE_PARENT.        procedure Set_Scope_Via_Field_Ptr          (Scope : in out Var_Scope_Type;           Scope_Field : O_Fnode; Scope_Parent : Var_Scope_Acc); -      --  Variables/scopes defined in SCOPE_TYPE can be accessed via +      --  Variables/scopes defined in SCOPE can be accessed via        --  dereference of parameter SCOPE_PARAM.        procedure Set_Scope_Via_Param_Ptr          (Scope : in out Var_Scope_Type; Scope_Param : O_Dnode); -      --  Variables/scopes defined in SCOPE_TYPE can be accessed via DECL. +      --  Variables/scopes defined in SCOPE can be accessed via DECL.        procedure Set_Scope_Via_Decl          (Scope : in out Var_Scope_Type; Decl : O_Dnode); +      --  Variables/scopes defined in SCOPE can be accessed by derefencing +      --  VAR. +      procedure Set_Scope_Via_Var_Ptr +        (Scope : in out Var_Scope_Type; Var : Var_Type); +        --  No more accesses to SCOPE_TYPE are allowed.  Scopes must be cleared        --  before being set.        procedure Clear_Scope (Scope : in out Var_Scope_Type); @@ -347,9 +355,6 @@ package body Translation is                                       return Var_Ident_Type;        function Create_Uniq_Identifier return Var_Ident_Type; -      type Var_Type is private; -      Null_Var : constant Var_Type; -        --  Create variable NAME of type VTYPE in the current scope.        --  If the current scope is the global scope, then a variable is        --   created at the top level (using decl_global_storage). @@ -550,6 +555,10 @@ package body Translation is        procedure Elab_Package_Body (Spec : Iir_Package_Declaration; Bod : Iir); +      --  Add info for an interface_package_declaration or a +      --  package_instantiation_declaration +      procedure Instantiate_Info_Package (Inst : Iir); +        --  Elaborate packages that DESIGN_UNIT depends on (except std.standard).        procedure Elab_Dependence (Design_Unit: Iir_Design_Unit); @@ -4873,11 +4882,11 @@ package body Translation is           Tinfo : constant Type_Info_Acc := Get_Info (Get_Type (Inter));        begin           case Get_Kind (Inter) is -            when Iir_Kind_Constant_Interface_Declaration -              | Iir_Kind_Variable_Interface_Declaration -              | Iir_Kind_File_Interface_Declaration => +            when Iir_Kind_Interface_Constant_Declaration +              | Iir_Kind_Interface_Variable_Declaration +              | Iir_Kind_Interface_File_Declaration =>                 Mode := Mode_Value; -            when Iir_Kind_Signal_Interface_Declaration => +            when Iir_Kind_Interface_Signal_Declaration =>                 Mode := Mode_Signal;              when others =>                 Error_Kind ("translate_interface_type", Inter); @@ -4970,7 +4979,7 @@ package body Translation is                 Arg_Info := Add_Info (Inter, Kind_Interface);                 Inter_Type := Get_Type (Inter);                 Tinfo := Get_Info (Inter_Type); -               if Get_Kind (Inter) = Iir_Kind_Variable_Interface_Declaration +               if Get_Kind (Inter) = Iir_Kind_Interface_Variable_Declaration                   and then Get_Mode (Inter) in Iir_Out_Modes                   and then Tinfo.Type_Mode not in Type_Mode_By_Ref                   and then Tinfo.Type_Mode /= Type_Mode_File @@ -5296,7 +5305,7 @@ package body Translation is           begin              Inter := Get_Interface_Declaration_Chain (Spec);              while Inter /= Null_Iir loop -               if Get_Kind (Inter) = Iir_Kind_Variable_Interface_Declaration +               if Get_Kind (Inter) = Iir_Kind_Interface_Variable_Declaration                   and then Get_Mode (Inter) = Iir_Out_Mode                 then                    Inter_Type := Get_Type (Inter); @@ -5640,6 +5649,67 @@ package body Translation is           end case;        end Instantiate_Iir_List_Info; +      procedure Copy_Info (Dest : Ortho_Info_Acc; Src : Ortho_Info_Acc) is +      begin +         case Src.Kind is +            when Kind_Type => +               Dest.all := (Kind => Kind_Type, +                            Type_Mode => Src.Type_Mode, +                            Type_Incomplete => Src.Type_Incomplete, +                            Type_Locally_Constrained => +                              Src.Type_Locally_Constrained, +                            C => null, +                            Ortho_Type => Src.Ortho_Type, +                            Ortho_Ptr_Type => Src.Ortho_Ptr_Type, +                            Type_Transient_Chain => Null_Iir, +                            T => Src.T, +                            Type_Rti => Src.Type_Rti); +               pragma Assert (Src.C = null); +               pragma Assert (Src.Type_Transient_Chain = Null_Iir); +            when Kind_Object => +               pragma Assert (Src.Object_Driver = Null_Var); +               pragma Assert (Src.Object_Function = O_Dnode_Null); +               Dest.all := +                 (Kind => Kind_Object, +                  Object_Static => Src.Object_Static, +                  Object_Var => Instantiate_Var (Src.Object_Var), +                  Object_Driver => Null_Var, +                  Object_Rti => Src.Object_Rti, +                  Object_Function => O_Dnode_Null); +            when Kind_Subprg => +               Dest.Subprg_Frame_Scope := +                 Instantiate_Var_Scope (Src.Subprg_Frame_Scope); +               Dest.all := +                 (Kind => Kind_Subprg, +                  Use_Stack2 => Src.Use_Stack2, +                  Ortho_Func => Src.Ortho_Func, +                  Res_Interface => Src.Res_Interface, +                  Res_Record_Var => Instantiate_Var (Src.Res_Record_Var), +                  Res_Record_Type => Src.Res_Record_Type, +                  Res_Record_Ptr => Src.Res_Record_Ptr, +                  Subprg_Frame_Scope => Dest.Subprg_Frame_Scope, +                  Subprg_Instance => Instantiate_Subprg_Instance +                    (Src.Subprg_Instance), +                  Subprg_Resolv => null, +                  Subprg_Local_Id => Src.Subprg_Local_Id, +                  Subprg_Exit => Src.Subprg_Exit, +                  Subprg_Result => Src.Subprg_Result); +            when Kind_Interface => +               Dest.all := (Kind => Kind_Interface, +                            Interface_Node => Src.Interface_Node, +                            Interface_Field => Src.Interface_Field, +                            Interface_Type => Src.Interface_Type); +            when Kind_Index => +               Dest.all := (Kind => Kind_Index, +                            Index_Field => Src.Index_Field); +            when Kind_Expr => +               Dest.all := (Kind => Kind_Expr, +                            Expr_Node => Src.Expr_Node); +            when others => +               raise Internal_Error; +         end case; +      end Copy_Info; +        procedure Instantiate_Iir_Info (N : Iir) is        begin           --  Nothing to do for null node. @@ -5660,63 +5730,15 @@ package body Translation is              if Orig_Info /= null then                 Info := Add_Info (N, Orig_Info.Kind); +               Copy_Info (Info, Orig_Info); +                 case Info.Kind is -                  when Kind_Type => -                     Info.all := (Kind => Kind_Type, -                                  Type_Mode => Orig_Info.Type_Mode, -                                  Type_Incomplete => Orig_Info.Type_Incomplete, -                                  Type_Locally_Constrained => -                                    Orig_Info.Type_Locally_Constrained, -                                  C => null, -                                  Ortho_Type => Orig_Info.Ortho_Type, -                                  Ortho_Ptr_Type => Orig_Info.Ortho_Ptr_Type, -                                  Type_Transient_Chain => Null_Iir, -                                  T => Orig_Info.T, -                                  Type_Rti => Orig_Info.Type_Rti); -                     pragma Assert (Orig_Info.C = null); -                     pragma Assert (Orig_Info.Type_Transient_Chain = Null_Iir); -                  when Kind_Object => -                     pragma Assert (Orig_Info.Object_Driver = Null_Var); -                     pragma Assert (Orig_Info.Object_Function = O_Dnode_Null); -                     Info.all := -                       (Kind => Kind_Object, -                        Object_Static => Orig_Info.Object_Static, -                        Object_Var => Instantiate_Var (Orig_Info.Object_Var), -                        Object_Driver => Null_Var, -                        Object_Rti => Orig_Info.Object_Rti, -                        Object_Function => O_Dnode_Null);                    when Kind_Subprg => -                     Info.Subprg_Frame_Scope := -                       Instantiate_Var_Scope (Orig_Info.Subprg_Frame_Scope);                       Push_Instantiate_Var_Scope                         (Info.Subprg_Frame_Scope'Access,                          Orig_Info.Subprg_Frame_Scope'Access); -                     Info.all := -                       (Kind => Kind_Subprg, -                        Use_Stack2 => Orig_Info.Use_Stack2, -                        Ortho_Func => Orig_Info.Ortho_Func, -                        Res_Interface => Orig_Info.Res_Interface, -                        Res_Record_Var => -                          Instantiate_Var (Orig_Info.Res_Record_Var), -                        Res_Record_Type => Orig_Info.Res_Record_Type, -                        Res_Record_Ptr => Orig_Info.Res_Record_Ptr, -                        Subprg_Frame_Scope => Info.Subprg_Frame_Scope, -                        Subprg_Instance => Instantiate_Subprg_Instance -                          (Orig_Info.Subprg_Instance), -                        Subprg_Resolv => null, -                        Subprg_Local_Id => Orig_Info.Subprg_Local_Id, -                        Subprg_Exit => Orig_Info.Subprg_Exit, -                        Subprg_Result => Orig_Info.Subprg_Result); -                  when Kind_Interface => -                     Info.all := (Kind => Kind_Interface, -                                  Interface_Node => Orig_Info.Interface_Node, -                                  Interface_Field => Orig_Info.Interface_Field, -                                  Interface_Type => Orig_Info.Interface_Type); -                  when Kind_Index => -                     Info.all := (Kind => Kind_Index, -                                  Index_Field => Orig_Info.Index_Field);                    when others => -                     raise Internal_Error; +                     null;                 end case;              end if; @@ -5744,7 +5766,8 @@ package body Translation is                       case Get_Field_Attribute (F) is                          when Attr_None =>                             Instantiate_Iir_List_Info (Get_Iir_List (N, F)); -                        when Attr_Ref => +                        when Attr_Ref +                          | Attr_Of_Ref =>                             null;                          when others =>                             raise Internal_Error; @@ -5797,29 +5820,71 @@ package body Translation is           end;        end Instantiate_Iir_Info; -      procedure Translate_Package_Instantiation_Declaration (Inst : Iir) +      procedure Instantiate_Iir_Generic_Chain_Info (Chain : Iir) +      is +         Inter : Iir; +         Orig : Iir; +         Orig_Info : Ortho_Info_Acc; +         Info : Ortho_Info_Acc; +      begin +         Inter := Chain; +         while Inter /= Null_Iir loop +            case Get_Kind (Inter) is +               when Iir_Kind_Interface_Constant_Declaration => +                  Orig := Sem_Inst.Get_Origin (Inter); +                  Orig_Info := Get_Info (Orig); + +                  Info := Add_Info (Inter, Orig_Info.Kind); +                  Copy_Info (Info, Orig_Info); + +               when Iir_Kind_Interface_Package_Declaration => +                  null; + +               when others => +                  raise Internal_Error; +            end case; + +            Inter := Get_Chain (Inter); +         end loop; +      end Instantiate_Iir_Generic_Chain_Info; + +      --  Add info for an interface_package_declaration or a +      --  package_instantiation_declaration +      procedure Instantiate_Info_Package (Inst : Iir)        is           Spec : constant Iir := -           Get_Named_Entity (Get_Uninstantiated_Name (Inst)); +           Get_Named_Entity (Get_Uninstantiated_Package_Name (Inst));           Pkg_Info : constant Ortho_Info_Acc := Get_Info (Spec);           Info : Ortho_Info_Acc; -         Interface_List : O_Inter_List; -         Constr : O_Assoc_List;        begin           Info := Add_Info (Inst, Kind_Package_Instance); +         --  Create the info instances.           Push_Instantiate_Var_Scope             (Info.Package_Instance_Spec_Scope'Access,              Pkg_Info.Package_Spec_Scope'Access);           Push_Instantiate_Var_Scope             (Info.Package_Instance_Body_Scope'Access,              Pkg_Info.Package_Body_Scope'Access); -         Instantiate_Iir_Chain_Info (Get_Generic_Chain (Inst)); +         Instantiate_Iir_Generic_Chain_Info (Get_Generic_Chain (Inst));           Instantiate_Iir_Chain_Info (Get_Declaration_Chain (Inst));           Pop_Instantiate_Var_Scope             (Info.Package_Instance_Body_Scope'Access);           Pop_Instantiate_Var_Scope             (Info.Package_Instance_Spec_Scope'Access); +      end Instantiate_Info_Package; + +      procedure Translate_Package_Instantiation_Declaration (Inst : Iir) +      is +         Spec : constant Iir := +           Get_Named_Entity (Get_Uninstantiated_Package_Name (Inst)); +         Pkg_Info : constant Ortho_Info_Acc := Get_Info (Spec); +         Info : Ortho_Info_Acc; +         Interface_List : O_Inter_List; +         Constr : O_Assoc_List; +      begin +         Instantiate_Info_Package (Inst); +         Info := Get_Info (Inst);           --  FIXME: if the instantiation occurs within a package declaration,           --  the variable must be declared extern (and public in the body). @@ -5854,7 +5919,14 @@ package body Translation is           Elab_Dependence (Get_Design_Unit (Inst)); +         Set_Scope_Via_Decl (Pkg_Info.Package_Body_Scope, +                             Get_Var_Label (Info.Package_Instance_Var)); +         Set_Scope_Via_Field (Pkg_Info.Package_Spec_Scope, +                              Pkg_Info.Package_Spec_Field, +                              Pkg_Info.Package_Body_Scope'Access);           Chap5.Elab_Generic_Map_Aspect (Inst); +         Clear_Scope (Pkg_Info.Package_Spec_Scope); +         Clear_Scope (Pkg_Info.Package_Body_Scope);           --  Call the elaborator of the generic.  The generic must be           --  temporary associated with the instance variable. @@ -9503,7 +9575,7 @@ package body Translation is           case Get_Kind (El) is              when Iir_Kind_Variable_Declaration -              | Iir_Kind_Constant_Interface_Declaration => +              | Iir_Kind_Interface_Constant_Declaration =>                 Info.Object_Var :=                   Create_Var (Create_Var_Identifier (El), Obj_Type);              when Iir_Kind_Constant_Declaration => @@ -9569,7 +9641,7 @@ package body Translation is           case Get_Kind (Decl) is              when Iir_Kind_Signal_Declaration -              | Iir_Kind_Signal_Interface_Declaration => +              | Iir_Kind_Interface_Signal_Declaration =>                 Rtis.Generate_Signal_Rti (Decl);              when Iir_Kind_Guard_Signal_Declaration =>                 --  No name created for guard signal. @@ -9617,6 +9689,27 @@ package body Translation is           Info.Object_Var := Create_Var (Create_Var_Identifier (El), Obj_Type);        end Create_File_Object; +      procedure Create_Package_Interface (Inter : Iir) +      is +         Info : Ortho_Info_Acc; +         Pkg : constant Iir := Get_Named_Entity +           (Get_Uninstantiated_Package_Name (Inter)); +         Pkg_Info : constant Ortho_Info_Acc := Get_Info (Pkg); +      begin +         Chap2.Instantiate_Info_Package (Inter); +         Info := Get_Info (Inter); +         Info.Package_Instance_Var := +           Create_Var (Create_Var_Identifier (Inter), +                       Pkg_Info.Package_Body_Ptr_Type); +         Set_Scope_Via_Var_Ptr +           (Info.Package_Instance_Body_Scope, +            Info.Package_Instance_Var); +         Set_Scope_Via_Field +           (Info.Package_Instance_Spec_Scope, +            Pkg_Info.Package_Spec_Field, +            Info.Package_Instance_Body_Scope'Access); +      end Create_Package_Interface; +        procedure Allocate_Complex_Object (Obj_Type : Iir;                                           Alloc_Kind : Allocation_Kind;                                           Var : in out Mnode) @@ -10794,7 +10887,7 @@ package body Translation is           Info := Add_Info (Decl, Kind_Alias);           case Get_Kind (Get_Object_Prefix (Decl)) is              when Iir_Kind_Signal_Declaration -              | Iir_Kind_Signal_Interface_Declaration +              | Iir_Kind_Interface_Signal_Declaration                | Iir_Kind_Guard_Signal_Declaration =>                 Info.Alias_Kind := Mode_Signal;              when others => @@ -10915,7 +11008,14 @@ package body Translation is        begin           Decl := Get_Generic_Chain (Parent);           while Decl /= Null_Iir loop -            Create_Object (Decl); +            case Get_Kind (Decl) is +               when Iir_Kinds_Interface_Object_Declaration => +                  Create_Object (Decl); +               when Iir_Kind_Interface_Package_Declaration => +                  Create_Package_Interface (Decl); +               when others => +                  Error_Kind ("translate_generic_chain", Decl); +            end case;              Decl := Get_Chain (Decl);           end loop;        end Translate_Generic_Chain; @@ -10978,7 +11078,7 @@ package body Translation is              --when Iir_Kind_Implicit_Function_Declaration =>              --when Iir_Kind_Signal_Declaration -            --  | Iir_Kind_Signal_Interface_Declaration => +            --  | Iir_Kind_Interface_Signal_Declaration =>                 --   Chap4.Create_Object (Decl);              when Iir_Kind_Variable_Declaration @@ -12622,7 +12722,6 @@ package body Translation is        is           Assoc : Iir;           Formal : Iir; -         Targ : Mnode;        begin           --  Elab generics, and associate.           Assoc := Get_Generic_Map_Aspect_Chain (Mapping); @@ -12634,35 +12733,37 @@ package body Translation is              end if;              case Get_Kind (Assoc) is                 when Iir_Kind_Association_Element_By_Expression => -                  if Get_Whole_Association_Flag (Assoc) then -                     Chap4.Elab_Object_Storage (Formal); -                     Targ := Chap6.Translate_Name (Formal); -                     Chap4.Elab_Object_Init (Targ, Formal, Get_Actual (Assoc)); -                  else -                     Targ := Chap6.Translate_Name (Formal); -                     Chap7.Translate_Assign -                       (Targ, Get_Actual (Assoc), Get_Type (Formal)); -                  end if; +                  declare +                     Targ : Mnode; +                  begin +                     if Get_Whole_Association_Flag (Assoc) then +                        Chap4.Elab_Object_Storage (Formal); +                        Targ := Chap6.Translate_Name (Formal); +                        Chap4.Elab_Object_Init +                          (Targ, Formal, Get_Actual (Assoc)); +                     else +                        Targ := Chap6.Translate_Name (Formal); +                        Chap7.Translate_Assign +                          (Targ, Get_Actual (Assoc), Get_Type (Formal)); +                     end if; +                  end;                 when Iir_Kind_Association_Element_Open =>                    Chap4.Elab_Object_Value (Formal, Get_Default_Value (Formal));                 when Iir_Kind_Association_Element_By_Individual =>                    --  Create the object.                    declare +                     Formal_Type : constant Iir := Get_Type (Formal); +                     Obj_Info : constant Object_Info_Acc := Get_Info (Formal); +                     Obj_Type : constant Iir := Get_Actual_Type (Assoc);                       Formal_Node : Mnode; -                     Formal_Type : Iir; -                     Obj_Info : Object_Info_Acc; -                     Obj_Type : Iir;                       Type_Info : Type_Info_Acc;                       Bounds : Mnode;                    begin -                     Formal_Type := Get_Type (Formal);                       Chap3.Elab_Object_Subtype (Formal_Type);                       Type_Info := Get_Info (Formal_Type); -                     Obj_Info := Get_Info (Formal);                       Formal_Node := Get_Var                         (Obj_Info.Object_Var, Type_Info, Mode_Value);                       Stabilize (Formal_Node); -                     Obj_Type := Get_Actual_Type (Assoc);                       if Obj_Type = Null_Iir then                          Chap4.Allocate_Complex_Object                            (Formal_Type, Alloc_System, Formal_Node); @@ -12673,8 +12774,30 @@ package body Translation is                            (Formal_Node, Alloc_System, Formal_Type, Bounds);                       end if;                    end; +               when Iir_Kind_Association_Element_Package => +                  pragma Assert (Get_Kind (Formal) = +                                   Iir_Kind_Interface_Package_Declaration); +                  declare +                     Uninst_Pkg : constant Iir := Get_Named_Entity +                       (Get_Uninstantiated_Package_Name (Formal)); +                     Uninst_Info : constant Ortho_Info_Acc := +                       Get_Info (Uninst_Pkg); +                     Formal_Info : constant Ortho_Info_Acc := +                       Get_Info (Formal); +                     Actual : constant Iir := Get_Named_Entity +                       (Get_Actual (Assoc)); +                     Actual_Info : constant Ortho_Info_Acc := +                       Get_Info (Actual); +                  begin +                     New_Assign_Stmt +                       (Get_Var (Formal_Info.Package_Instance_Var), +                        New_Address +                          (Get_Instance_Ref +                             (Actual_Info.Package_Instance_Body_Scope), +                           Uninst_Info.Package_Body_Ptr_Type)); +                  end;                 when others => -                  Error_Kind ("elab_map_aspect(1)", Assoc); +                  Error_Kind ("elab_generic_map_aspect(1)", Assoc);              end case;              Close_Temp;              Assoc := Get_Chain (Assoc); @@ -13651,11 +13774,11 @@ package body Translation is  --          Prefix_Name : Mnode;  --       begin  --          case Get_Kind (Name) is ---             when Iir_Kind_Constant_Interface_Declaration => +--             when Iir_Kind_Interface_Constant_Declaration =>  --                return Translate_Formal_Interface_Name  --                  (Scope_Type, Scope_Param, Name, Mode_Value); ---             when Iir_Kind_Signal_Interface_Declaration => +--             when Iir_Kind_Interface_Signal_Declaration =>  --                return Translate_Formal_Interface_Name  --                  (Scope_Type, Scope_Param, Name, Mode_Signal); @@ -13739,16 +13862,16 @@ package body Translation is                | Iir_Kind_Guard_Signal_Declaration =>                 return Get_Var (Name_Info.Object_Var, Type_Info, Mode_Signal); -            when Iir_Kind_Constant_Interface_Declaration => +            when Iir_Kind_Interface_Constant_Declaration =>                 return Translate_Interface_Name (Name, Name_Info, Mode_Value); -            when Iir_Kind_File_Interface_Declaration => +            when Iir_Kind_Interface_File_Declaration =>                 return Translate_Interface_Name (Name, Name_Info, Mode_Value); -            when Iir_Kind_Variable_Interface_Declaration => +            when Iir_Kind_Interface_Variable_Declaration =>                 return Translate_Interface_Name (Name, Name_Info, Mode_Value); -            when Iir_Kind_Signal_Interface_Declaration => +            when Iir_Kind_Interface_Signal_Declaration =>                 return Translate_Interface_Name (Name, Name_Info, Mode_Signal);              when Iir_Kind_Indexed_Name => @@ -13825,7 +13948,7 @@ package body Translation is              when Iir_Kind_Object_Alias_Declaration =>                 Translate_Direct_Driver (Get_Name (Name), Sig, Drv);              when Iir_Kind_Signal_Declaration -              | Iir_Kind_Signal_Interface_Declaration => +              | Iir_Kind_Interface_Signal_Declaration =>                 Sig := Get_Var (Name_Info.Object_Var, Type_Info, Mode_Signal);                 Drv := Get_Var (Name_Info.Object_Driver, Type_Info, Mode_Value);              when Iir_Kind_Slice_Name => @@ -14612,12 +14735,12 @@ package body Translation is           end case;           case Get_Kind (Formal_Base) is -            when Iir_Kind_Constant_Interface_Declaration -              | Iir_Kind_File_Interface_Declaration => +            when Iir_Kind_Interface_Constant_Declaration +              | Iir_Kind_Interface_File_Declaration =>                 return Chap3.Maybe_Insert_Scalar_Check                   (Translate_Expression (Actual, Get_Type (Formal)),                    Actual, Get_Type (Formal)); -            when Iir_Kind_Signal_Interface_Declaration => +            when Iir_Kind_Interface_Signal_Declaration =>                 return Translate_Implicit_Conv                   (M2E (Chap6.Translate_Name (Actual)),                    Get_Type (Actual), @@ -17422,10 +17545,10 @@ package body Translation is                | Iir_Kind_Signal_Declaration                | Iir_Kind_File_Declaration                | Iir_Kind_Object_Alias_Declaration -              | Iir_Kind_Constant_Interface_Declaration -              | Iir_Kind_Variable_Interface_Declaration -              | Iir_Kind_Signal_Interface_Declaration -              | Iir_Kind_File_Interface_Declaration +              | Iir_Kind_Interface_Constant_Declaration +              | Iir_Kind_Interface_Variable_Declaration +              | Iir_Kind_Interface_Signal_Declaration +              | Iir_Kind_Interface_File_Declaration                | Iir_Kind_Indexed_Name                | Iir_Kind_Slice_Name                | Iir_Kind_Selected_Element @@ -21316,7 +21439,7 @@ package body Translation is              Base_Formal := Get_Association_Interface (El);              Formal_Type := Get_Type (Formal);              Formal_Info := Get_Info (Base_Formal); -            if Get_Kind (Base_Formal) = Iir_Kind_Signal_Interface_Declaration +            if Get_Kind (Base_Formal) = Iir_Kind_Interface_Signal_Declaration              then                 Formal_Object_Kind := Mode_Signal;              else @@ -21387,13 +21510,13 @@ package body Translation is              elsif Ftype_Info.Type_Mode not in Type_Mode_By_Value then                 --  Passed by reference.                 case Get_Kind (Base_Formal) is -                  when Iir_Kind_Constant_Interface_Declaration -                    | Iir_Kind_File_Interface_Declaration => +                  when Iir_Kind_Interface_Constant_Declaration +                    | Iir_Kind_Interface_File_Declaration =>                       --  No conversion here.                       E_Params (Pos) := Chap7.Translate_Expression                         (Act, Formal_Type); -                  when Iir_Kind_Variable_Interface_Declaration -                    | Iir_Kind_Signal_Interface_Declaration => +                  when Iir_Kind_Interface_Variable_Declaration +                    | Iir_Kind_Interface_Signal_Declaration =>                       Param := Chap6.Translate_Name (Act);                       --  Atype may not have been set (eg: slice).                       if Base_Formal /= Formal then @@ -21420,7 +21543,7 @@ package body Translation is                    --  By value association.                    Act := Get_Actual (El);                    if Get_Kind (Base_Formal) -                    = Iir_Kind_Constant_Interface_Declaration +                    = Iir_Kind_Interface_Constant_Declaration                    then                       Val := Chap7.Translate_Expression (Act, Formal_Type);                    else @@ -21505,7 +21628,7 @@ package body Translation is                             Error_Kind ("translate_procedure_call(2)", El);                       end case;                       case Get_Kind (Formal) is -                        when Iir_Kind_Signal_Interface_Declaration => +                        when Iir_Kind_Interface_Signal_Declaration =>                             Param := Chap6.Translate_Name (Act);                             --  This is a scalar.                             Val := M2E (Param); @@ -21546,7 +21669,7 @@ package body Translation is              Formal_Type := Get_Type (Formal);              Ftype_Info := Get_Info (Formal_Type);              Formal_Info := Get_Info (Base_Formal); -            if Get_Kind (Base_Formal) = Iir_Kind_Variable_Interface_Declaration +            if Get_Kind (Base_Formal) = Iir_Kind_Interface_Variable_Declaration                and then Get_Mode (Base_Formal) in Iir_Out_Modes                and then Params (Pos) /= Mnode_Null              then @@ -23454,7 +23577,7 @@ package body Translation is                   | Iir_Kind_Transaction_Attribute =>                    El := Get_Prefix (El);                 when Iir_Kind_Signal_Declaration -                 | Iir_Kind_Signal_Interface_Declaration +                 | Iir_Kind_Interface_Signal_Declaration                   | Iir_Kind_Guard_Signal_Declaration =>                    exit;                 when Iir_Kinds_Denoting_Name => @@ -24654,6 +24777,16 @@ package body Translation is                     Field => Scope_Field, Up_Link => Scope_Parent);        end Set_Scope_Via_Field_Ptr; +      procedure Set_Scope_Via_Var_Ptr +        (Scope : in out Var_Scope_Type; Var : Var_Type) is +      begin +         pragma Assert (Scope.Kind = Var_Scope_None); +         pragma Assert (Var.Kind = Var_Scope); +         Scope := (Scope_Type => Scope.Scope_Type, +                   Kind => Var_Scope_Field_Ptr, +                   Field => Var.I_Field, Up_Link => Var.I_Scope); +      end Set_Scope_Via_Var_Ptr; +        procedure Set_Scope_Via_Param_Ptr          (Scope : in out Var_Scope_Type; Scope_Param : O_Dnode) is        begin @@ -27924,14 +28057,14 @@ package body Translation is                 when Iir_Kind_Signal_Declaration =>                    Comm := Ghdl_Rtik_Signal;                    Var := Info.Object_Var; -               when Iir_Kind_Signal_Interface_Declaration => +               when Iir_Kind_Interface_Signal_Declaration =>                    Comm := Ghdl_Rtik_Port;                    Var := Info.Object_Var;                    Mode := Iir_Mode'Pos (Get_Mode (Decl));                 when Iir_Kind_Constant_Declaration =>                    Comm := Ghdl_Rtik_Constant;                    Var := Info.Object_Var; -               when Iir_Kind_Constant_Interface_Declaration => +               when Iir_Kind_Interface_Constant_Declaration =>                    Comm := Ghdl_Rtik_Generic;                    Var := Info.Object_Var;                 when Iir_Kind_Variable_Declaration => @@ -27967,7 +28100,7 @@ package body Translation is              end case;              case Get_Kind (Decl) is                 when Iir_Kind_Signal_Declaration -                 | Iir_Kind_Signal_Interface_Declaration => +                 | Iir_Kind_Interface_Signal_Declaration =>                    Mode := Mode                      + 16 * Iir_Signal_Kind'Pos (Get_Signal_Kind (Decl));                 when others => @@ -27975,7 +28108,7 @@ package body Translation is              end case;              case Get_Kind (Decl) is                 when Iir_Kind_Signal_Declaration -                 | Iir_Kind_Signal_Interface_Declaration +                 | Iir_Kind_Interface_Signal_Declaration                   | Iir_Kind_Guard_Signal_Declaration                   | Iir_Kind_Transaction_Attribute                   | Iir_Kind_Stable_Attribute @@ -28072,9 +28205,9 @@ package body Translation is                    --  Eg: array subtypes.                    null;                 when Iir_Kind_Signal_Declaration -                 | Iir_Kind_Signal_Interface_Declaration +                 | Iir_Kind_Interface_Signal_Declaration                   | Iir_Kind_Constant_Declaration -                 | Iir_Kind_Constant_Interface_Declaration +                 | Iir_Kind_Interface_Constant_Declaration                   | Iir_Kind_Variable_Declaration                   | Iir_Kind_File_Declaration                   | Iir_Kind_Transaction_Attribute @@ -28228,8 +28361,8 @@ package body Translation is                       end;                    end if;                 when Iir_Kind_Signal_Declaration -                 | Iir_Kind_Signal_Interface_Declaration -                 | Iir_Kind_Constant_Interface_Declaration +                 | Iir_Kind_Interface_Signal_Declaration +                 | Iir_Kind_Interface_Constant_Declaration                   | Iir_Kind_Variable_Declaration                   | Iir_Kind_File_Declaration                   | Iir_Kind_Transaction_Attribute @@ -31077,10 +31210,9 @@ package body Translation is              for I in Design_Units.First .. Design_Units.Last loop                 Unit := Design_Units.Table (I);                 Sem.Sem_Analysis_Checks_List (Unit, False); -               if Get_Analysis_Checks_List (Unit) /= Null_Iir_List then -                  --  There cannot be remaining checks to do. -                  raise Internal_Error; -               end if; +               --  There cannot be remaining checks to do. +               pragma Assert +                 (Get_Analysis_Checks_List (Unit) = Null_Iir_List);              end loop;           end if; diff --git a/xtools/pnodes.py b/xtools/pnodes.py index c6f67f656..364f1254e 100755 --- a/xtools/pnodes.py +++ b/xtools/pnodes.py @@ -104,41 +104,48 @@ def read_fields(file):      pat_field_desc = re.compile('   --   (\w+) : (\w+).*\n')      format_name = ''      common_desc = {} -    try: -        while True: -            # 1) Search for description -            while True: -                # The common one -                if l == '   -- Common fields are:\n': -                    format_name = 'Common' -                    break -                # One for a format -                m = pat_fields.match(l) -                if m != None: -                    format_name = m.group(1) -                    if not format_name in fields: -                        raise ParseError( -                            lr, 'Format ' + format_name + ' is unknown'); -                    break -                l = lr.get() -            # 2) Read field description +    # Read until common fields. +    while l != '   -- Common fields are:\n': +        l = lr.get() +    format_name = 'Common' +    nbr_formats = 0 + +    while True: +        # 1) Read field description +        l = lr.get() +        desc = common_desc.copy() +        while True: +            m = pat_field_desc.match(l) +            if m == None: +                break +            desc[m.group(1)] = m.group(2)              l = lr.get() -            desc = common_desc -            while True: -                m = pat_field_desc.match(l) -                if m == None: -                    break -                desc[m.group(1)] = m.group(2) -                l = lr.get() +            # print 'For: ' + format_name + ': ' + m.group(1) -            # 3) Disp -            if format_name == 'Common': -                common_desc = desc +        # 2) Disp +        if format_name == 'Common': +            common_desc = desc +        else: +            fields[format_name] = desc + +        # 3) Read next format +        if l == '\n': +            if nbr_formats == len(fields): +                break              else: -                fields[format_name] = desc -    except EndOfFile: -        pass +                l = lr.get() + +        # One for a format +        m = pat_fields.match(l) +        if m != None: +            format_name = m.group(1) +            if not format_name in fields: +                raise ParseError( +                    lr, 'Format ' + format_name + ' is unknown') +            nbr_formats = nbr_formats + 1 +        else: +            raise ParseError(lr, 'unhandled format line')      return (formats, fields) @@ -321,7 +328,8 @@ def read_nodes_fields(lr, names, fields, nodes, funcs_dict):                  raise ParseError(lr, 'field mismatch')              for c in only_nodes:                  if field not in c.fields: -                    raise ParseError(lr, 'field does not exist in node') +                    raise ParseError(lr, 'field ' + field + \ +                                     ' does not exist in node')                  if not alias:                      if c.fields[field]:                          raise ParseError(lr, 'field already used') @@ -335,7 +343,7 @@ def read_nodes_fields(lr, names, fields, nodes, funcs_dict):          l = lr.get()  # Read description for all nodes -def read_nodes(filename, kinds_ranges, fields, funcs): +def read_nodes(filename, kinds, kinds_ranges, fields, funcs):      lr = linereader(filename)      funcs_dict = {x.name:x for x in funcs}      nodes = {} @@ -362,6 +370,8 @@ def read_nodes(filename, kinds_ranges, fields, funcs):              # Declaration of the first node              while True:                  name=m.group(1) +                if not name in kinds: +                    raise ParseError(lr, 'unknown node')                  fmt=m.group(2)                  names.append((name,fmt))                  # There might be several nodes described at once. @@ -487,7 +497,7 @@ args = parser.parse_args()  try:      (formats, fields) = read_fields(field_file)      (kinds, kinds_ranges, funcs) = read_kinds(spec_file) -    nodes = read_nodes(spec_file,kinds_ranges,fields,funcs) +    nodes = read_nodes(spec_file,kinds,kinds_ranges,fields,funcs)  except ParseError as e:      print >> sys.stderr, e | 
