]> git.ipfire.org Git - thirdparty/gcc.git/commitdiff
decl.c (elaborate_expression_1): Use the variable for bounds of loop iteraration...
authorEric Botcazou <ebotcazou@adacore.com>
Tue, 2 Oct 2012 10:34:44 +0000 (10:34 +0000)
committerEric Botcazou <ebotcazou@gcc.gnu.org>
Tue, 2 Oct 2012 10:34:44 +0000 (10:34 +0000)
* gcc-interfaces/decl.c (elaborate_expression_1): Use the variable for
bounds of loop iteraration scheme only for locally defined subtypes.

* gcc-interface/trans.c (gigi): Fix formatting.
(build_return_expr): Apply the NRV optimization only for BLKmode.

From-SVN: r191971

gcc/ada/ChangeLog
gcc/ada/gcc-interface/decl.c
gcc/ada/gcc-interface/trans.c

index 8fd7724cb8570fa035d4c867b5d67526125f11c1..cddd55b7801f5919ac42e6a94aad8de6d07c5f7d 100644 (file)
@@ -1,3 +1,11 @@
+2012-10-02  Eric Botcazou  <ebotcazou@adacore.com>
+
+       * gcc-interfaces/decl.c (elaborate_expression_1): Use the variable for
+       bounds of loop iteraration scheme only for locally defined subtypes.
+
+       * gcc-interface/trans.c (gigi): Fix formatting.
+       (build_return_expr): Apply the NRV optimization only for BLKmode.
+
 2012-10-02  Robert Dewar  <dewar@adacore.com>
 
        * par_sco.adb, sem_ch3.adb, layout.adb, exp_ch7.adb, exp_imgv.adb,
index 9e14d8af1bf87be585c726cb2b7455f65311ec29..3935bb33e054a9ded98b170a0b67d85abfb4050f 100644 (file)
@@ -6165,6 +6165,7 @@ elaborate_expression_1 (tree gnu_expr, Entity_Id gnat_entity, tree gnu_name,
   use_variable = expr_variable_p
                 && (expr_global_p
                     || (!optimize
+                        && definition
                         && Is_Itype (gnat_entity)
                         && Nkind (Associated_Node_For_Itype (gnat_entity))
                            == N_Loop_Parameter_Specification));
index c3e833e408aed48b5b28e3ce36e935e3f462a247..d88f6bafcda36669f84153127de99eed121f7003 100644 (file)
@@ -332,7 +332,7 @@ gigi (Node_Id gnat_root, int max_gnat_node, int number_name ATTRIBUTE_UNUSED,
 #ifdef ORDINARY_MAP_INSTANCE
       map = LINEMAPS_ORDINARY_MAP_AT (line_table, i);
       if (flag_debug_instances)
-        ORDINARY_MAP_INSTANCE(map) = file_info_ptr[i].Instance;
+       ORDINARY_MAP_INSTANCE (map) = file_info_ptr[i].Instance;
 #endif
       linemap_line_start (line_table, file_info_ptr[i].Num_Source_Lines, 252);
       linemap_position_for_column (line_table, 252 - 1);
@@ -3158,6 +3158,7 @@ build_return_expr (tree ret_obj, tree ret_val)
       if (optimize
          && AGGREGATE_TYPE_P (operation_type)
          && !TYPE_IS_FAT_POINTER_P (operation_type)
+         && TYPE_MODE (operation_type) == BLKmode
          && aggregate_value_p (operation_type, current_function_decl))
        {
          /* Recognize the temporary created for a return value with variable