+2019-09-23 Eric Botcazou <ebotcazou@adacore.com>
+
+ * gcc-interface/trans.c (Regular_Loop_to_gnu): Do not rotate the loop
+ if -Og is enabled.
+ (build_return_expr): Do not perform NRV if -Og is enabled.
+ (Subprogram_Body_to_gnu): Likewise.
+ (gnat_to_gnu) <N_Simple_Return_Statement>: Likewise.
+ (Handled_Sequence_Of_Statements_to_gnu): Do not inline finalizers if
+ -Og is enabled.
+ * gcc-interface/utils.c (convert_to_index_type): Return early if -Og
+ is enabled.
+
2019-09-23 Eric Botcazou <ebotcazou@adacore.com>
* gcc-interface/trans.c (gnat_compile_time_expr_list): New variable.
which works in all cases. */
- if (optimize)
+ if (optimize && !optimize_debug)
{
/* We can use the do-while form directly if GNU_FIRST-1 doesn't
overflow. */
a candidate for Named Return Value. If so, record it. Otherwise,
if this is an expression of some kind, record it elsewhere. */
if (optimize
+ && !optimize_debug
&& AGGREGATE_TYPE_P (operation_type)
&& !TYPE_IS_FAT_POINTER_P (operation_type)
&& TYPE_MODE (operation_type) == BLKmode
/* If the function returns an aggregate type and we have candidates for
a Named Return Value, finalize the optimization. */
- if (optimize && gnu_subprog_language->named_ret_val)
+ if (optimize && !optimize_debug && gnu_subprog_language->named_ret_val)
{
finalize_nrv (gnu_subprog_decl,
gnu_subprog_language->named_ret_val,
/* When not optimizing, disable inlining of finalizers as this can
create a more complex CFG in the parent function. */
- if (!optimize)
+ if (!optimize || optimize_debug)
DECL_DECLARED_INLINE_P (proc_decl) = 0;
/* If there is no end label attached, we use the location of the At_End
/* And find out whether this is a candidate for Named Return
Value. If so, record it. */
- if (!TYPE_CI_CO_LIST (gnu_subprog_type) && optimize)
+ if (optimize
+ && !optimize_debug
+ && !TYPE_CI_CO_LIST (gnu_subprog_type))
{
tree ret_val = gnu_ret_val;
/* If the type is unsigned, overflow is allowed so we cannot be sure that
EXPR doesn't overflow. Keep it simple if optimization is disabled. */
- if (TYPE_UNSIGNED (type) || !optimize)
+ if (TYPE_UNSIGNED (type) || !optimize || optimize_debug)
return convert (sizetype, expr);
switch (code)