summaryrefslogtreecommitdiff
path: root/src/vhdl/translate
diff options
context:
space:
mode:
Diffstat (limited to 'src/vhdl/translate')
-rw-r--r--src/vhdl/translate/trans-chap8.adb59
-rw-r--r--src/vhdl/translate/trans.ads2
2 files changed, 32 insertions, 29 deletions
diff --git a/src/vhdl/translate/trans-chap8.adb b/src/vhdl/translate/trans-chap8.adb
index 07bf43c..22292dd 100644
--- a/src/vhdl/translate/trans-chap8.adb
+++ b/src/vhdl/translate/trans-chap8.adb
@@ -1606,13 +1606,8 @@ package body Trans.Chap8 is
end case;
end Translate_Implicit_Procedure_Call;
- function Do_Conversion (Conv : Iir; Expr : Iir; Src : Mnode)
- return O_Enode
+ function Do_Conversion (Conv : Iir; Expr : Iir; Src : Mnode) return O_Enode
is
- Constr : O_Assoc_List;
- Conv_Info : Subprg_Info_Acc;
- Res : O_Dnode;
- Imp : Iir;
begin
if Conv = Null_Iir then
return M2E (Src);
@@ -1628,31 +1623,39 @@ package body Trans.Chap8 is
case Get_Kind (Conv) is
when Iir_Kind_Function_Call =>
-- Call conversion function.
- Imp := Get_Implementation (Conv);
- Conv_Info := Get_Info (Imp);
- Start_Association (Constr, Conv_Info.Ortho_Func);
-
- if Conv_Info.Res_Interface /= O_Dnode_Null then
- Res := Create_Temp (Conv_Info.Res_Record_Type);
- -- Composite result.
- New_Association
- (Constr,
- New_Address (New_Obj (Res), Conv_Info.Res_Record_Ptr));
- end if;
+ declare
+ Imp : constant Iir := Get_Implementation (Conv);
+ Conv_Info : constant Subprg_Info_Acc := Get_Info (Imp);
+ Constr : O_Assoc_List;
+ Res_Otype : Type_Info_Acc;
+ Res : O_Dnode;
+ begin
+ Start_Association (Constr, Conv_Info.Ortho_Func);
+
+ if Conv_Info.Res_Interface /= O_Dnode_Null then
+ Res_Otype := Get_Info (Get_Return_Type (Imp));
+ Res := Create_Temp (Res_Otype.Ortho_Type (Mode_Value));
+ -- Composite result.
+ New_Association
+ (Constr,
+ New_Address (New_Obj (Res),
+ Res_Otype.Ortho_Ptr_Type (Mode_Value)));
+ end if;
- Subprgs.Add_Subprg_Instance_Assoc
- (Constr, Conv_Info.Subprg_Instance);
+ Subprgs.Add_Subprg_Instance_Assoc
+ (Constr, Conv_Info.Subprg_Instance);
- New_Association (Constr, M2E (Src));
+ New_Association (Constr, M2E (Src));
- if Conv_Info.Res_Interface /= O_Dnode_Null then
- -- Composite result.
- New_Procedure_Call (Constr);
- return New_Address (New_Obj (Res),
- Conv_Info.Res_Record_Ptr);
- else
- return New_Function_Call (Constr);
- end if;
+ if Conv_Info.Res_Interface /= O_Dnode_Null then
+ -- Composite result.
+ New_Procedure_Call (Constr);
+ return New_Address
+ (New_Obj (Res), Res_Otype.Ortho_Ptr_Type (Mode_Value));
+ else
+ return New_Function_Call (Constr);
+ end if;
+ end;
when Iir_Kind_Type_Conversion =>
return Chap7.Translate_Type_Conversion
(M2E (Src), Get_Type (Expr),
diff --git a/src/vhdl/translate/trans.ads b/src/vhdl/translate/trans.ads
index 9a10b65..dd1e508 100644
--- a/src/vhdl/translate/trans.ads
+++ b/src/vhdl/translate/trans.ads
@@ -1106,7 +1106,7 @@ package Trans is
-- Field in the frame for a pointer to the RESULT structure.
Res_Record_Var : Var_Type := Null_Var;
- -- For a subprogram with a result interface:
+ -- For a procedure: record containing inout/out scalar parameters.
-- Type definition for the record.
Res_Record_Type : O_Tnode := O_Tnode_Null;
-- Type definition for access to the record.