aboutsummaryrefslogtreecommitdiff
diff options
context:
space:
mode:
authorRobert Dewar <dewar@adacore.com>2008-05-28 15:05:55 +0200
committerArnaud Charlet <charlet@gcc.gnu.org>2008-05-28 15:05:55 +0200
commitebd01830cf0a220493054bb5811334b43160e17c (patch)
tree58a1eb09f3817ec5bf0a3c6762a1c3ff29727f7f
parent63bdc3ea178016154ce60cd850dae027f0f54329 (diff)
downloadgcc-ebd01830cf0a220493054bb5811334b43160e17c.zip
gcc-ebd01830cf0a220493054bb5811334b43160e17c.tar.gz
gcc-ebd01830cf0a220493054bb5811334b43160e17c.tar.bz2
2008-05-28 Robert Dewar <dewar@adacore.com>
* exp_ch5.adb: (Expand_Simple_Function_Return): Copy unaligned result into temporary From-SVN: r136080
-rw-r--r--gcc/ada/exp_ch5.adb25
1 files changed, 23 insertions, 2 deletions
diff --git a/gcc/ada/exp_ch5.adb b/gcc/ada/exp_ch5.adb
index 8d8a281..18ea8fe 100644
--- a/gcc/ada/exp_ch5.adb
+++ b/gcc/ada/exp_ch5.adb
@@ -4032,6 +4032,28 @@ package body Exp_Ch5 is
end;
end if;
+ -- If we are returning an object that may not be bit-aligned, then
+ -- copy the value into a temporary first. This copy may need to expand
+ -- to a loop of component operations..
+
+ if Is_Possibly_Unaligned_Slice (Exp)
+ or else Is_Possibly_Unaligned_Object (Exp)
+ then
+ declare
+ Tnn : constant Entity_Id :=
+ Make_Defining_Identifier (Loc, New_Internal_Name ('T'));
+ begin
+ Insert_Action (Exp,
+ Make_Object_Declaration (Loc,
+ Defining_Identifier => Tnn,
+ Constant_Present => True,
+ Object_Definition => New_Occurrence_Of (R_Type, Loc),
+ Expression => Relocate_Node (Exp)),
+ Suppress => All_Checks);
+ Rewrite (Exp, New_Occurrence_Of (Tnn, Loc));
+ end;
+ end if;
+
-- Generate call to postcondition checks if they are present
if Ekind (Scope_Id) = E_Function
@@ -4061,8 +4083,7 @@ package body Exp_Ch5 is
else
declare
Tnn : constant Entity_Id :=
- Make_Defining_Identifier (Loc,
- New_Internal_Name ('T'));
+ Make_Defining_Identifier (Loc, New_Internal_Name ('T'));
begin
-- For a complex expression of an elementary type, capture