1. 07 Mar, 2018 4 commits
  2. 06 Mar, 2018 16 commits
    • re PR fortran/84697 (minloc/maxloc not simplified with zero size) · 5867bb9a
      2017-03-06  Thomas Koenig  <tkoenig@gcc.gnu.org>
      
      	PR fortran/84697
      	PR fortran/66128
      	* expr.c (simplify_parameter_variable): If p is a size zero array
      	and not an ARRAY_EXPR insert an empty array constructor and
      	return.
      	* gfortran.h: Add prototype for gfc_is_size_zero_array.
      	* simplify.c (is_size_zero_array): Make non-static and rename into
      	(gfc_is_size_zero_array):  Check for parameter arrays of zero
      	size by comparing shape and absence of constructor.
      	(gfc_simplify_all): Use gfc_is_size_zero_array instead of
      	is_size_zero_array.
      	(gfc_simplify_count): Likewise.
      	(gfc_simplify_iall): Likewise.
      	(gfc_simplify_iany): Likewise.
      	(gfc_simplify_iparity): Likewise.
      	(gfc_simplify_minval): Likewise.
      	(gfc_simplify_maxval): Likewise.
      	(gfc_simplify_product): Likewise.
      	(gfc_simplify_sum): Likewise.
      
      2017-03-06  Thomas Koenig  <tkoenig@gcc.gnu.org>
      
      	PR fortran/84697
      	PR fortran/66128
      	* gfortran.dg/minmaxloc_zerosize_1.f90: New test.
      
      From-SVN: r258305
      Thomas Koenig committed
    • re PR libstdc++/84601 (std::optional<std::pair<int, int>> is not assignment copyable) · 447346e4
      PR libstdc++/84601
      * include/std/optional (_Optional_payload): Split into multiple
      specializations that can handle different cases of trivial or
      non-trivial assignment operators.
      * testsuite/20_util/optional/84601.cc: New.
      * testsuite/20_util/optional/cons/value_neg.cc: Adjust.
      
      From-SVN: r258304
      Ville Voutilainen committed
    • re PR c++/84684 (inserting random code / flags produces wrong code) · 1dc23505
      	PR c++/84684
      	* constexpr.c (cxx_bind_parameters_in_call): Unshare evaluated
      	arguments.
      
      	* g++.dg/cpp1z/constexpr-84684.C: New test.
      
      From-SVN: r258303
      Marek Polacek committed
    • re PR c/84721 (ICE in c_push_function_context, at c-decl.c:9667) · 849bbdb9
      	PR c/84721
      	* c-parser.c (add_debug_begin_stmt): Don't add DEBUG_BEGIN_STMT if
      	!building_stmt_list_p ().
      
      	* gcc.dg/pr84721.c: New test.
      
      From-SVN: r258302
      Jakub Jelinek committed
    • re PR target/84710 (ICE: RTL check: expected code 'reg', have 'subreg' in… · 2728bf8f
      re PR target/84710 (ICE: RTL check: expected code 'reg', have 'subreg' in rhs_regno, at rtl.h:1896 with -O -fno-forward-propagate)
      
      	PR target/84710
      	* combine.c (try_combine): Use reg_or_subregno instead of handling
      	just paradoxical SUBREGs and REGs.
      
      	* gcc.dg/pr84710.c: New test.
      
      From-SVN: r258301
      Jakub Jelinek committed
    • re PR fortran/56667 (Syntax error causes misleading message: "Expected PARAMETER… · 284ee475
      re PR fortran/56667 (Syntax error causes misleading message: "Expected PARAMETER symbol in complex constant")
      
      2018-03-06  Steven G. Kargl  <kargl@gcc.gnu.org>
      
      	PR fortran/56667
      	* primary.c (match_sym_complex_part): Give the matcher for an implied
      	do-loop a chance to run.
      
      2018-03-06  Steven G. Kargl  <kargl@gcc.gnu.org>
      
      	PR fortran/56667
      	* gfortran.dg/implied_do_2.f90: New test.
      	* gfortran.dg/coarray_8.f90: Update for new error message.
      
      From-SVN: r258281
      Steven G. Kargl committed
    • trans.c (convert_with_check): Fix typo in the condition guarding the overflow… · 21288963
      trans.c (convert_with_check): Fix typo in the condition guarding the overflow check emitted for the upper...
      
      	* gcc-interface/trans.c (convert_with_check): Fix typo in the condition
      	guarding the overflow check emitted for the upper bound of a floating-
      	point conversion.
      
      From-SVN: r258277
      Eric Botcazou committed
    • [ARC] Cleanup unused functions. · b51addd6
      Remove unused pieces of code.
      
      gcc/
      2018-03-06  Claudiu Zissulescu  <claziss@synopsys.com>
      
      	* config/arc/arc.c (arc_finalize_pic): Remove function.
      	(arc_must_save_register): We use single base PIC register, remove
      	checks to save/restore the PIC register.
      	(arc_expand_prologue): Likewise.
      	* config/arc/arc-protos.h (arc_set_default_type_attributes):
      	Remove.
      	(arc_verify_short): Likewise.
      	(arc_attr_type): Likewise.
      	* config/arc/arc.c (arc_set_default_type_attributes): Remove.
      	(walk_stores): Likewise.
      	(arc_address_cost): Make it static.
      	(arc_verify_short): Likewise.
      	(branch_dest): Likewise.
      	(arc_attr_type): Likewise.
      	* config/arc/arc.c (TARGET_ADJUST_INSN_LENGTH): Remove.
      	(TARGET_INSN_LENGTH_PARAMETERS): Likewise.
      	(arc_final_prescan_insn): Remove inserting the nops due to
      	hardware hazards.  It is done in reorg step.
      	(insn_length_variant_t): Remove.
      	(insn_length_parameters_t): Likewise.
      	(arc_insn_length_parameters): Likewise.
      	(arc_get_insn_variants): Likewise.
      	* config/arc/arc.h (TARGET_UPSIZE_DBR): Remove.
      
      From-SVN: r258275
      Claudiu Zissulescu committed
    • re PR inline-asm/84683 (internal compiler error: in move_for_stack_reg, at reg-stack.c:1173) · 155958dd
      	PR inline-asm/84683
      	* reg-stack.c (move_for_stack_reg): If any_malformed_asm, avoid
      	assertion failure.
      
      	* g++.dg/ext/pr84683.C: New test.
      
      From-SVN: r258273
      Jakub Jelinek committed
    • re PR tree-optimization/84687 (error: invalid conversion in gimple call with -O3 and -ffast-math) · 16ef0a8c
      	PR tree-optimization/84687
      	* omp-simd-clone.c (simd_clone_create): Clear DECL_BUILT_IN_CLASS
      	on new_node->decl.
      	* match.pd (pow(C,x)*expN(y) -> expN(logN(C)*x+y)): New optimization.
      
      	* gcc.dg/pr84687.c: New test.
      
      From-SVN: r258272
      Jakub Jelinek committed
    • [C++] [PR84231] overload on cond_expr in template · 23d63b45
      A non-type-dependent COND_EXPR within a template is reconstructed with
      the original operands, after one with non-dependent proxies is built to
      determine its result type.  This is problematic because the operands of
      a COND_EXPR determined to be an rvalue may have been converted to denote
      their rvalue nature.  The reconstructed one, however, won't have such
      conversions, so lvalue_kind may not recognize it as an rvalue, which may
      lead to e.g. incorrect overload resolution decisions.
      
      If we mistake such a COND_EXPR for an lvalue, overload resolution might
      regard a conversion sequence that binds it to a non-const reference as
      viable, and then select that over one that binds it to a const
      reference.  Only after template substitution would we rebuild the
      COND_EXPR, realize it is an rvalue, and conclude the reference binding
      is ill-formed, but at that point we'd have long discarded any alternate
      candidates we could have used.
      
      This patch modifies the logic that determines whether a
      (non-type-dependent) COND_EXPR in a template is an lvalue, to rely on
      its type, more specifically, on the presence of a REFERENCE_TYPE
      wrapper.  In order to avoid a type bootstrapping problem, the
      REFERENCE_TYPE that wraps the type of some such COND_EXPRs is
      introduced earlier, so that we don't have to test for lvalueness of
      the expression using the very code that we wish to change.
      
      
      for  gcc/cp/ChangeLog
      
      	PR c++/84231
      	* tree.c (lvalue_kind): Use presence/absence of REFERENCE_TYPE
      	only while processing template decls.
      	* typeck.c (build_x_conditional_expr): Move wrapping of
      	reference type around type...
      	* call.c (build_conditional_expr_1): ... here.  Rename
      	is_lvalue to is_glvalue.
      	* parser.c (cp_parser_fold_expression): Catch REFERENCE_REF_P
      	INDIRECT_REF of COND_EXPR too.
      
      for  gcc/testsuite/ChangeLog
      
      	PR c++/84231
      	* g++.dg/pr84231.C: New.
      
      From-SVN: r258271
      Alexandre Oliva committed
    • [PR c++/84593] ice on braced init with uninit ref field · 2e1a7ecb
      If an initializer expr is to be NULL in a ctor initializer list, we
      ICE in picflag_from_initializer and elsewhere.
      
      If we're missing an initializer for a reference field, we report the
      error, but then build a zero initializer to avoid the ICE.
      
      for  gcc/cp/ChangeLog
      
      	PR c++/84593
      	* init.c (build_zero_init_1): Zero-initialize references.
      
      for  gcc/testsuite/ChangeLog
      
      	PR c++/84593
      	* g++.dg/cpp1y/pr84593.C: New.
      
      From-SVN: r258270
      Alexandre Oliva committed
    • [PR c++/84492] stmt expr ending with overload · 1ea71a82
      We ICEd when returning a stmt expr that ends with an overloaded
      function, because instantiate_type did not know what to do with
      STMT_EXPRs.  And it shouldn't have to: the expected type of a stmt
      expr cannot be used to resolve its value: an unresolved overload
      cannot supply the result of a stmt expr.  Catch that and report the
      error in the stmt expr before we have a chance to instantiate it.
      
      for  gcc/cp/ChangeLog
      
      	PR c++/84492
      	* semantics.c (finish_stmt_expr_expr): Reject unresolved
      	overloads used as stmt expr values.
      
      for  gcc/testsuite/ChangeLog
      
      	PR c++/84492
      	* g++.dg/pr84492.C: New.
      
      From-SVN: r258269
      Alexandre Oliva committed
    • rs6000-builtin.def (rs6000_speculation_barrier): Rename to ppc_speculation_barrier. · 4900146c
      [gcc]
      
      2018-03-05  Bill Schmidt  <wschmidt@linux.vnet.ibm.com>
      
      	* config/rs6000/rs6000-builtin.def (rs6000_speculation_barrier):
      	Rename to ppc_speculation_barrier.
      	* config/rs6000/rs6000.c (rs6000_init_builtins): Rename builtin to
      	__builtin_ppc_speculation_barrier.
      
      [gcc/testsuite]
      
      2018-03-05  Bill Schmidt  <wschmidt@linux.vnet.ibm.com>
      
      	* gcc.target/powerpc/spec-barr-1.c: Change called function name to
      	__builtin_ppc_speculation_barrier.
      
      From-SVN: r258268
      Bill Schmidt committed
    • Daily bump. · f75fbd29
      From-SVN: r258267
      GCC Administrator committed
  3. 05 Mar, 2018 20 commits