diff options
Diffstat (limited to 'src')
-rw-r--r-- | src/vhdl/translate/trans-chap8.adb | 18 |
1 files changed, 9 insertions, 9 deletions
diff --git a/src/vhdl/translate/trans-chap8.adb b/src/vhdl/translate/trans-chap8.adb index 22292dd..6f406ba 100644 --- a/src/vhdl/translate/trans-chap8.adb +++ b/src/vhdl/translate/trans-chap8.adb @@ -1687,6 +1687,7 @@ package body Trans.Chap8 is Base_Formal : Iir; Formal_Type : Iir; Ftype_Info : Type_Info_Acc; + Ftype_Binfo : Type_Info_Acc; Formal_Info : Ortho_Info_Acc; Val : O_Enode; Param : Mnode; @@ -1732,6 +1733,7 @@ package body Trans.Chap8 is Formal_Object_Kind := Mode_Value; end if; Ftype_Info := Get_Info (Formal_Type); + Ftype_Binfo := Get_Info (Get_Base_Type (Formal_Type)); case Get_Kind (El) is when Iir_Kind_Association_Element_Open => @@ -1744,10 +1746,10 @@ package body Trans.Chap8 is Out_Conv := Get_Out_Conversion (El); when Iir_Kind_Association_Element_By_Individual => Actual_Type := Get_Actual_Type (El); - if Formal_Info.Interface_Field /= O_Fnode_Null then - -- A non-composite type cannot be associated by element. - raise Internal_Error; - end if; + + -- A non-composite type cannot be associated by element. + pragma Assert (Formal_Info.Interface_Field = O_Fnode_Null); + if Ftype_Info.Type_Mode = Type_Mode_Fat_Array then Chap3.Create_Array_Subtype (Actual_Type, True); Bounds := Chap3.Get_Array_Type_Bounds (Actual_Type); @@ -1771,9 +1773,7 @@ package body Trans.Chap8 is -- Copy-out argument. -- This is not a composite type. Param := Chap6.Translate_Name (Act); - if Get_Object_Kind (Param) /= Mode_Value then - raise Internal_Error; - end if; + pragma Assert (Get_Object_Kind (Param) = Mode_Value); Params (Pos) := Stabilize (Param); if In_Conv /= Null_Iir or else Get_Mode (Formal) = Iir_Inout_Mode @@ -1793,7 +1793,7 @@ package body Trans.Chap8 is In_Expr, Formal_Type, El); end if; - elsif Ftype_Info.Type_Mode not in Type_Mode_By_Value then + elsif Ftype_Binfo.Type_Mode not in Type_Mode_By_Value then -- Passed by reference. case Get_Kind (Base_Formal) is when Iir_Kind_Interface_Constant_Declaration @@ -1822,7 +1822,7 @@ package body Trans.Chap8 is end if; if Base_Formal /= Formal then -- Individual association. - if Ftype_Info.Type_Mode not in Type_Mode_By_Value then + if Ftype_Binfo.Type_Mode not in Type_Mode_By_Value then -- Not by-value actual already translated. Val := E_Params (Pos); else |