1. 07 Nov, 2019 13 commits
    • Reapply all revisions mentioned in LOCAL_PATCHES. · 21bb1625
      2019-11-07  Martin Liska  <mliska@suse.cz>
      
      	* all source files: Reapply all revisions mentioned in LOCAL_PATCHES.
      
      From-SVN: r277910
      Martin Liska committed
    • Libsanitizer: merge from trunk · cb7dc4da
      2019-11-07  Martin Liska  <mliska@suse.cz>
      
      	* merge.sh: Update to use llvm-project git repository.
      	* all source files: Merge from upstream
      	82588e05cc32bb30807e480abd4e689b0dee132a.
      
      From-SVN: r277909
      Martin Liska committed
    • Support 64-bit double and 64-bit long double configurations. · 29f3def3
      gcc/
      	Support 64-bit double and 64-bit long double configurations.
      
      	PR target/92055
      	* config.gcc (tm_defines) [avr]: Set from --with-double=,
      	--with-long-double=.
      	* config/avr/t-multilib: Remove.
      	* config/avr/t-avr: Output of genmultilib.awk is now fully
      	dynamically generated and no more part of the repo.
      	(HAVE_DOUBLE_MULTILIB, HAVE_LONG_DOUBLE_MULTILIB): New variables.
      	Pass them down to...
      	* config/avr/genmultilib.awk: ...here and handle them.
      	* gcc/config/avr/avr.opt (-mdouble=, avr_double). New option and var.
      	(-mlong-double=, avr_long_double). New option and var.
      	* common/config/avr/avr-common.c (opts.h, diagnostic.h): Include.
      	(TARGET_OPTION_OPTIMIZATION_TABLE) <-mdouble=, -mlong-double=>:
      	Set default as requested by --with-double=
      	(TARGET_HANDLE_OPTION): Define to this...
      	(avr_handle_option): ...new hook worker.
      	* config/avr/avr.h (DOUBLE_TYPE_SIZE): Define to avr_double.
      	(LONG_DOUBLE_TYPE_SIZE): Define to avr_long_double.
      	(avr_double_lib): New proto for spec function.
      	(EXTRA_SPEC_FUNCTIONS) <double-lib>: Add.
      	(DRIVER_SELF_SPECS): Call %:double-lib.
      	* config/avr/avr.c (avr_option_override): Assert
      	sizeof(long double) >= sizeof(double) for the target.
      	* config/avr/avr-c.c (avr_cpu_cpp_builtins)
      	[__HAVE_DOUBLE_MULTILIB__, __HAVE_LONG_DOUBLE_MULTILIB__]
      	[__HAVE_DOUBLE64__, __HAVE_DOUBLE32__, __DEFAULT_DOUBLE__=]
      	[__HAVE_LONG_DOUBLE64__, __HAVE_LONG_DOUBLE32__]
      	[__HAVE_LONG_DOUBLE_IS_DOUBLE__, __DEFAULT_LONG_DOUBLE__=]:
      	New built-in define depending on --with-double=, --with-long-double=.
      	* config/avr/driver-avr.c (avr_double_lib): New spec function.
      	* doc/invoke.tex (AVR Options) <-mdouble=,-mlong-double=>: Doc.
      	* doc/install.texi (Cross-Compiler-Specific Options)
      	<--with-double=, --with-long-double=>: Doc.
      
      libgcc/
      	Support 64-bit double and 64-bit long double configurations.
      
      	PR target/92055
      	* config/avr/t-avr (HOST_LIBGCC2_CFLAGS): Only add -DF=SF if
      	long double is a 32-bit type.
      	* config/avr/t-avrlibc: Copy double64 and long-double64
      	multilib(s) from the vanilla one.
      	* config/avr/t-copy-libgcc: New Makefile snip.
      
      From-SVN: r277908
      Georg-Johann Lay committed
    • dbgcnt.def (gimple_unroll): New. · 76bc24ff
      2019-11-07  Richard Biener  <rguenther@suse.de>
      
      	* dbgcnt.def (gimple_unroll): New.
      	* tree-ssa-loop-ivcanon.c (try_unroll_loop_completely): Check
      	gimple_unroll debug counter before applying transform.
      	(try_peel_loop): Likewise.
      
      From-SVN: r277907
      Richard Biener committed
    • Adjust pr92163.c test to require effective target fopenacc. · f06abe6d
      2019-11-07  Prathamesh Kulkarni  <prathamesh.kulkarni@linaro.org>
      
      testsuite/
      	* gcc.dg/tree-ssa/pr92163.c: Add dg-require-effective-target fopenacc.
      
      From-SVN: r277906
      Prathamesh Kulkarni committed
    • re PR libfortran/90374 (Fortran 2018: Support d0.d, e0.d, es0.d, en0.d, g0.d and… · 67732fbc
      re PR libfortran/90374 (Fortran 2018: Support d0.d, e0.d, es0.d, en0.d, g0.d and ew.d e0 edit descriptors for output)
      
      2019-11-06  Jerry DeLisle  <jvdelisle@gcc.ngu.org>
      
      	PR fortran/90374
      	* io.c (check_format): Allow zero width for D, E, EN, and ES
      	specifiers as default and when -std=F2018 is given. Retain
      	existing errors when using the -fdec family of flags.
      
      	* libgfortran/io/format.c (parse_format_list): Relax format checking for
      	zero width as default and when -std=f2018.
      	io/format.h (format_token): Move definition to io.h.
      	io/io.h (format_token): Add definition here to allow access to
      	this definition at higher levels. Rename the declaration of
      	write_real_g0 to write_real_w0 and add a new format_token
      	argument, allowing higher level functions to pass in the
      	token for handling of g0 vs the other zero width specifiers.
      	io/transfer.c (formatted_transfer_scalar_write): Add checks for
      	zero width and call write_real_w0 to handle it.
      	io/write.c (write_real_g0): Remove.
      	(write_real_w0): Add new, same as previous write_real_g0 except
      	check format token to handle the g0 case.
      
      	* gfortran.dg/fmt_error_10.f: Modify for new constraints.
      	* gfortran.dg/fmt_error_7.f: Add dg-options "-std=f95".
      	* gfortran.dg/fmt_error_9.f: Modify for new constraints.
      	* gfortran.dg/fmt_zero_width.f90: New test.
      
      From-SVN: r277905
      Jerry DeLisle committed
    • Fix copy-paste typo syntax error by r277872 · ce6c0a20
      gcc/testsuite/ChangeLog:
      
      	2019-11-07  Xiong Hu Luo  <luoxhu@linux.ibm.com>
      
      	* gcc.target/powerpc/pr72804.c: Move inline options from
      	dg-require-effective-target to dg-options.
      
      From-SVN: r277904
      Xiong Hu Luo committed
    • Move string concatenation for C into the parser. · 471c5330
      This patch is another piece of preparation for C2x attributes support.
      
      C2x attributes require unbounded lookahead in the parser, because the
      token sequence '[[' that starts a C2x attribute is also valid in
      Objective-C in some of the same contexts, so it is necessary to see
      whether the matching ']]' are consecutive tokens or not to determine
      whether those tokens start an attribute.
      
      Unbounded lookahead means lexing an unbounded number of tokens before
      they are parsed.  c_lex_one_token does various context-sensitive
      processing of tokens that cannot be done at that lookahead time,
      because it depends on information (such as whether particular
      identifiers are typedefs) that may be different at the time it is
      relevant than at the time the lookahead is needed (recall that more or
      less arbitrary C code, including declarations and statements, can
      appear inside expressions in GNU C).
      
      Most of that context-sensitive processing is not a problem, simply
      because it is not needed for lookahead purposes so can be deferred
      until the tokens lexed during lookahead are parsed.  However, the
      earliest piece of context-sensitive processing is the handling of
      string literals based on flags passed to c_lex_with_flags, which
      determine whether adjacent literals are concatenated and whether
      translation to the execution character set occurs.
      
      Because the choice of whether to translate to the execution character
      set is context-sensitive, this means that unbounded lookahead requires
      the C parser to move to the approach used by the C++ parser, where
      string literals are generally not translated or concatenated from
      within c_lex_with_flags, but only later in the parser once it knows
      whether translation is needed.  (Translation requires the tokens in
      their form before concatenation.)
      
      Thus, this patch makes that change to the C parser.  Flags in the
      parser are still used for two special cases similar to C++: the
      handling of an initial #pragma pch_preprocess, and arranging for
      strings inside attributes not to be translated (the latter is made
      more logically correct by saving and restoring the flags, as in the
      C++ parser, rather than assuming that the state outside the attribute
      was always to translate string literals, which might not be the case
      in corner cases involving declarations and attributes inside
      attributes).
      
      The consequent change to pragma_lex to use c_parser_string_literal
      makes it disallow wide strings and disable translation in that
      context, which also follows C++ and is more logically correct than the
      previous state without special handling in that regard.  Translation
      to the execution character set is always disabled when string
      constants are handled in the GIMPLE parser.
      
      Although the handling of strings is now a lot closer to that in C++,
      there are still some differences, in particular regarding the handling
      of locations.  See c-c++-common/Wformat-pr88257.c, which has different
      expected multiline diagnostic output for C and C++, for example; I'm
      not sure whether the C or C++ output is better there (C++ has a more
      complete range than C, C mentions a macro definition location that C++
      doesn't), but I tried to keep the locations the same as those
      previously used by the C front end, as far as possible, to minimize
      the testsuite changes needed, rather than possibly making them closer
      to those used with C++.
      
      The only changes needed for tests of user-visible diagnostics were for
      the wording of one diagnostic changing to match C++ (as a consequence
      of having a check for wide strings based on a flag in a general
      string-handling function rather than in a function specific to asm).
      However, although locations are extremely similar to what they were
      before, I couldn't make them completely identical in all cases.  (My
      understanding of the implementation reason for the differences is as
      follows: lex_string uses src_loc from each cpp_token; the C parser is
      using the virtual location from cpp_get_token_with_location as called
      by c_lex_with_flags, and while passing that through
      linemap_resolve_location with LRK_MACRO_DEFINITION_LOCATION, as this
      patch does, produces something very close to what lex_string uses,
      it's not completely identical in some cases.)
      
      This results in changes being needed to two of the gcc.dg/plugin tests
      that use a plugin to test details of how string locations are handled.
      Because the tests being changed are for ICEs and the only change is to
      the details of the particular non-user-visible error that code gives
      in cases it can't handle (one involving __FILE__, one involving a
      string literal from stringizing), I think it's OK to change that
      non-user-visible error and that the new errors are no worse than the
      old ones.  So these particular errors are now different for C and C++
      (some other messages in those tests already had differences between C
      and C++).
      
      Bootstrapped with no regressions on x86_64-pc-linux-gnu.
      
      gcc/c:
      	* c-parser.c (c_parser): Remove lex_untranslated_string.  Add
      	lex_joined_string and translate_strings_p.
      	(c_lex_one_token): Pass 0 or C_LEX_STRING_NO_JOIN to
      	c_lex_with_flags.
      	(c_parser_string_literal): New function.
      	(c_parser_static_assert_declaration_no_semi): Use
      	c_parser_string_literal.  Do not set lex_untranslated_string.
      	(c_parser_asm_string_literal): Use c_parser_string_literal.
      	(c_parser_simple_asm_expr): Do not set lex_untranslated_string.
      	(c_parser_gnu_attributes): Set and restore translate_strings_p
      	instead of lex_untranslated_string.
      	(c_parser_asm_statement): Do not set lex_untranslated_string.
      	(c_parser_asm_operands): Likewise.
      	(c_parser_has_attribute_expression): Set and restore
      	translate_strings_p instead of lex_untranslated_string.
      	(c_parser_postfix_expression): Use c_parser_string_literal.
      	(pragma_lex): Likewise.
      	(c_parser_pragma_pch_preprocess): Set lex_joined_string.
      	(c_parse_file): Set translate_strings_p.
      	* gimple-parser.c (c_parser_gimple_postfix_expression)
      	(c_parser_gimple_or_rtl_pass_list): Use c_parser_string_literal.
      	* c-parser.c (c_parser_string_literal): Declare function.
      
      gcc/testsuite:
      	* gcc.dg/asm-wide-1.c, gcc.dg/diagnostic-token-ranges.c,
      	gcc.dg/plugin/diagnostic-test-string-literals-1.c,
      	gcc.dg/plugin/diagnostic-test-string-literals-2.c: Update expected
      	diagnostics.
      
      From-SVN: r277903
      Joseph Myers committed
    • Implement D1907R1 "structural type". · 74fa3829
      ISO C++ paper D1907R1 proposes "structural type" as an alternative to the
      current notion of "strong structural equality", which has various problems.
      I'm implementing it to give people a chance to try it.
      
      The build_base_field changes are to make it easier for structural_type_p to
      see whether a base is private or protected.
      
      	* tree.c (structural_type_p): New.
      	* pt.c (invalid_nontype_parm_type_p): Use it.
      	* class.c (build_base_field_1): Take binfo.  Copy TREE_PRIVATE.
      	(build_base_field): Pass binfo.
      
      From-SVN: r277902
      Jason Merrill committed
    • PR c++/92150 - partial specialization with class NTTP. · 951c6f3d
      Here unify was getting confused by the VIEW_CONVERT_EXPR we add in
      finish_id_expression_1 to make class NTTP const when they're used in an
      expression.
      
      Tested x86_64-pc-linux-gnu, applying to trunk.
      
      	* pt.c (unify): Handle VIEW_CONVERT_EXPR.
      
      From-SVN: r277901
      Jason Merrill committed
    • Use satisfaction with nested requirements. · 81a34a6b
      gcc/cp/
      
      2019-11-06  Andrew Sutton  <asutton@lock3software.com>
      
      	* constraint.cc (build_parameter_mapping): Use
      	current_template_parms when the declaration is not available.
      	(norm_info::norm_info) Make explicit.
      	(normalize_constraint_expression): Factor into a separate overload
      	that takes arguments, and use that in the original function.
      	(tsubst_nested_requirement): Use satisfy_constraint instead of
      	trying to evaluate this as a constant expression.
      	(finish_nested_requirement): Keep the normalized constraint and the
      	original normalization arguments with the requirement.
      	(diagnose_nested_requirement): Use satisfy_constraint. Tentatively
      	implement more comprehensive diagnostics, but do not enable.
      	* parser.c (cp_parser_requires_expression): Relax requirement that
      	requires-expressions can live only inside templates.
      	* pt.c (any_template_parm_r): Look into type of PARM_DECL.
      
      2019-11-06  Jason Merrill  <jason@redhat.com>
      
      	* pt.c (use_pack_expansion_extra_args_p): Still do substitution if
      	all packs are simple pack expansions.
      	(add_extra_args): Check that the extra args aren't dependent.
      
      gcc/testsuite/
      	* lib/prune.exp: Ignore "in requirements" in diagnostics.
      	* g++.dg/cpp2a/requires-18.C: New test.
      	* g++.dg/cpp2a/requires-19.C: New test.
      
      From-SVN: r277900
      Jason Merrill committed
    • Daily bump. · 67568e1a
      From-SVN: r277899
      GCC Administrator committed
    • Support using multiple registers to hold the frame pointer · ff33d187
      When multiple hard registers are required to hold the frame pointer,
      ensure that the registers after the first are marked as non-allocatable,
      live and eliminable as well.
      
      2019-11-07  Kwok Cheung Yeung  <kcy@codesourcery.com>
      
      	gcc/
      	* ira.c (setup_alloc_regs): Setup no_unit_alloc_regs for
      	frame pointer in multiple registers.
      	(ira_setup_eliminable_regset): Setup eliminable_regset,
      	ira_no_alloc_regs and regs_ever_live for frame pointer in
      	multiple registers.
      
      From-SVN: r277895
      Kwok Cheung Yeung committed
  2. 06 Nov, 2019 24 commits
    • vsx.md (xxswapd_<mode>): Add support for V2DF and V2DI modes. · 7b88f66d
      gcc/ChangeLog:
      
      2019-11-06  Kelvin Nilsen  <kelvin@gcc.gnu.org>
      
      	* config/rs6000/vsx.md (xxswapd_<mode>): Add support for V2DF and
      	V2DI modes.
      
      From-SVN: r277893
      Kelvin Nilsen committed
    • [Darwin, testsuite] Fix framework-1.c on later Darwin. · e69ed8dc
      The test works by checking that a known framework path is accessible
      when the '-F' option is given.  We need to find a framework path that
      exists across a range of Darwin versions, and parseable by GCC.  This
      adjusts the test to use a header path that exists and is parsable from
      Darwin9 through Darwin19.
      
      gcc/testsuite/ChangeLog:
      
      2019-11-06  Iain Sandoe  <iain@sandoe.co.uk>
      
      	* gcc.dg/framework-1.c: Adjust test header path.
      
      From-SVN: r277892
      Iain Sandoe committed
    • C++20 NB CA378 - Remove constrained non-template functions. · babd71c1
      No real use cases have ever arisen for constraints on non-templated
      functions, and handling of them has never been entirely clear, so the
      committee agreed to accept this national body comment proposing that we
      remove them.
      
      	* decl.c (grokfndecl): Reject constraints on non-templated function.
      
      From-SVN: r277891
      Jason Merrill committed
    • ggc-common.c (ggc_prune_overhead_list): Do not delete surviving allocations. · 5d24b4f2
      	* ggc-common.c (ggc_prune_overhead_list): Do not delete surviving
      	allocations.
      	* mem-stats.h (mem_alloc_description<T>::release_object_overhead):
      	Do not silently ignore summary corruptions.
      
      From-SVN: r277890
      Jan Hubicka committed
    • libstdc++: Add compare_three_way and install <compare> header · 0c92c862
      	* include/Makefile.in: Regenerate.
      	* libsupc++/Makefile.in: Regenerate.
      	* libsupc++/compare (__3way_builtin_ptr_cmp): Define helper.
      	(compare_three_way): Add missing implementation.
      
      From-SVN: r277889
      Jonathan Wakely committed
    • libstdc++: remove redundant equality operators · d37303d1
      Now that operator<=> is supported, these operators can be generated by
      the compiler.
      
      	* include/bits/iterator_concepts.h (unreachable_sentinel_t): Remove
      	redundant equality operators.
      	* testsuite/util/testsuite_iterators.h (test_range::sentinel):
      	Likewise.
      
      From-SVN: r277888
      Jonathan Wakely committed
    • Fix parser to recognize operator?: · 6394a341
      This change lets grok_op_properties print its useful "ISO C++ prohibits
      overloading operator ?:" message instead of the cryptic error message about
      a missing type-specifier before '?' token.
      
      2019-11-06  Matthias Kretz  <m.kretz@gsi.de>
      
      	* parser.c (cp_parser_operator): Parse operator?: as an
      	attempt to overload the conditional operator.
      
      From-SVN: r277887
      Matthias Kretz committed
    • Don't vectorise single-iteration epilogues · 4b205bf8
      With a later patch I saw a case in which we peeled a single iteration
      for gaps but didn't need to peel further iterations to make up a full
      vector.  We then tried to vectorise the single-iteration epilogue.
      
      2019-11-06  Richard Sandiford  <richard.sandiford@arm.com>
      
      gcc/
      	* tree-vect-loop.c (vect_analyze_loop): Only try to vectorize
      	the epilogue if there are peeled iterations for it to handle.
      
      From-SVN: r277886
      Richard Sandiford committed
    • [ARC] Don't split ior/mov predicated insns. · 4653da0b
      Do not split long immediate constants for predicated instructions.
      
      gcc/
      xxxx-xx-xx  Claudiu Zissulescu  <claziss@synopsys.com>
      
      	* config/arc/arc.c (arc_split_ior): Add asserts.
      	(arc_split_mov_const): Likewise.
      	(arc_check_ior_const): Do not match known short immediate values.
      	* config/arc/arc.md (movsi): Don't split predicated instructions.
      	(iorsi): Likewise.
      
      testsuite/
      xxxx-xx-xx  Claudiu Zissulescu  <claziss@synopsys.com>
      	Sahahb Vahedi  <shahab@synopsys.com>
      	Cupertino Miranda  <cmiranda@synopsys.com>
      
      	* gcc.target/arc/or-cnst-size2.c: New test.
      
      Co-Authored-By: Sahahb Vahedi <shahab@synopsys.com>
      
      From-SVN: r277885
      Claudiu Zissulescu committed
    • [ARC] Update mea option documentation · 4d932965
      Update -mea option documentation.
      
      gcc/
      xxxx-xx-xx  Claudiu Zissulescu  <claziss@synopsys.com>
      
      	* config/arc/arc.opt (mea): Update help string.
      	* doc/invoke.texi(ARC): Update mea option info.
      
      From-SVN: r277884
      Claudiu Zissulescu committed
    • [ARC] Cleanup sign/zero extend patterns · cca18f3b
      Clean up sign/zero extend patterns.
      
      gcc/
      xxxx-xx-xx  Claudiu Zissulescu  <claziss@synopsys.com>
      
      	* config/arc/arc.md (zero_extendqihi2_i): Cleanup pattern.
      	(zero_extendqisi2_ac): Likewise.
      	(zero_extendhisi2_i): Likewise.
      	(extendqihi2_i): Likewise.
      	(extendqisi2_ac): Likewise.
      	(extendhisi2_i): Likewise.
      
      From-SVN: r277883
      Claudiu Zissulescu committed
    • tree-vect-loop.c (vectorizable_reduction): Remember reduction PHI. · 06af1f1a
      2019-11-06  Richard Biener  <rguenther@suse.de>
      
      	* tree-vect-loop.c (vectorizable_reduction): Remember reduction
      	PHI.  Use STMT_VINFO_REDUC_IDX to skip the reduction operand.
      	Simplify single_defuse_cycle condition.
      
      From-SVN: r277882
      Richard Biener committed
    • Use scan-tree-dump instead of scan-tree-dump-times for some vect tests · feba3d88
      With later patches, we're able to vectorise the epilogues of these tests
      on AArch64 and so get two instances of "vectorizing stmts using SLP".
      Although it would be possible with a bit of effort to predict when
      this happens, it doesn't seem important whether we get 1 vs. 2
      occurrences.  All that matters is zero vs. nonzero.
      
      2019-11-06  Richard Sandiford  <richard.sandiford@arm.com>
      
      gcc/testsuite/
      	* gcc.dg/vect/slp-9.c: Use scan-tree-dump rather than
      	scan-tree-dump-times.
      	* gcc.dg/vect/slp-widen-mult-s16.c: Likewise.
      	* gcc.dg/vect/slp-widen-mult-u8.c: Likewise.
      
      From-SVN: r277881
      Richard Sandiford committed
    • Check the VF is small enough for an epilogue loop · 8ec5b16a
      The number of iterations of an epilogue loop is always smaller than the
      VF of the main loop.  vect_analyze_loop_costing was taking this into
      account when deciding whether the loop is cheap enough to vectorise,
      but that has no effect with the unlimited cost model.  We need to use
      a separate check for correctness as well.
      
      This can happen if the sizes returned by autovectorize_vector_sizes
      happen to be out of order, e.g. because the target prefers smaller
      vectors.  It can also happen with later patches if two vectorisation
      attempts happen to end up with the same VF.
      
      2019-11-06  Richard Sandiford  <richard.sandiford@arm.com>
      
      gcc/
      	* tree-vect-loop.c (vect_analyze_loop_2): When vectorizing an
      	epilogue loop, make sure that the VF is small enough or that
      	the epilogue loop can be fully-masked.
      
      From-SVN: r277880
      Richard Sandiford committed
    • Restructure vect_analyze_loop · 72d6aeec
      Once vect_analyze_loop has found a valid loop_vec_info X, we carry
      on searching for alternatives if (1) X doesn't satisfy simdlen or
      (2) we want to vectorize the epilogue of X.  I have a patch that
      optionally adds a third reason: we want to see if there are cheaper
      alternatives to X.
      
      This patch restructures vect_analyze_loop so that it's easier
      to add more reasons for continuing.  There's supposed to be no
      behavioural change.
      
      If we wanted to, we could allow vectorisation of epilogues once
      loop->simdlen has been reached by changing "loop->simdlen" to
      "simdlen" in the new vect_epilogues condition.  That should be
      a separate change though.
      
      2019-11-06  Richard Sandiford  <richard.sandiford@arm.com>
      
      gcc/
      	* tree-vect-loop.c (vect_analyze_loop): Break out of the main
      	loop when we've finished, rather than returning directly from
      	the loop.  Use a local variable to track whether we're still
      	searching for the preferred simdlen.  Make vect_epilogues
      	record whether the next iteration should try to treat the
      	loop as an epilogue.
      
      From-SVN: r277879
      Richard Sandiford committed
    • [PATCH] [ARC] Add builtins for identifying floating point support · 756b23a8
      Currently for hard float we need to check for
       __ARC_FPU_SP__ || __ARC_FPU_DP__ and for soft float inverse of that.
      So define single convenience macros for either cases.
      
      gcc/
      xxxx-xx-xx  Vineet Gupta  <vgupta@synopsyscom>
      
      	* config/arc/arc-c.c (arc_cpu_cpp_builtins): Add
                __arc_hard_float__, __ARC_HARD_FLOAT__,
                __arc_soft_float__, __ARC_SOFT_FLOAT__
      
      From-SVN: r277878
      Vineet Gupta committed
    • [vect] PR92317: fix skip_epilogue creation for epilogues · 2e7a4f57
      gcc/ChangeLog:
      2019-11-06  Andre Vieira  <andre.simoesdiasvieira@arm.com>
      
      	PR tree-optimization/92317
      	* tree-vect-loop-manip.c (slpeel_update_phi_nodes_for_guard2): Also
      	update phi's with constant phi arguments.
      
      gcc/testsuite/ChangeLog:
      2019-11-06  Andre Vieira  <andre.simoesdiasvieira@arm.com>
      
      	PR tree-optimization/92317
      	* gcc/testsuite/g++.dg/opt/pr92317.C: New test.
      
      From-SVN: r277877
      Andre Vieira committed
    • introduce -fcallgraph-info option · 3cf3da88
      This was first submitted many years ago
      https://gcc.gnu.org/ml/gcc-patches/2010-10/msg02468.html
      
      The command line option -fcallgraph-info is added and makes the
      compiler generate another output file (xxx.ci) for each compilation
      unit (or LTO partitoin), which is a valid VCG file (you can launch
      your favorite VCG viewer on it unmodified) and contains the "final"
      callgraph of the unit.  "final" is a bit of a misnomer as this is
      actually the callgraph at RTL expansion time, but since most
      high-level optimizations are done at the Tree level and RTL doesn't
      usually fiddle with calls, it's final in almost all cases.  Moreover,
      the nodes can be decorated with additional info: -fcallgraph-info=su
      adds stack usage info and -fcallgraph-info=da dynamic allocation info.
      
      
      for  gcc/ChangeLog
      From  Eric Botcazou  <ebotcazou@adacore.com>, Alexandre Oliva  <oliva@adacore.com>
      
      	* common.opt (-fcallgraph-info[=]): New option.
      	* doc/invoke.texi (Developer options): Document it.
      	* opts.c (common_handle_option): Handle it.
      	* builtins.c (expand_builtin_alloca): Record allocation if
      	-fcallgraph-info=da.
      	* calls.c (expand_call): If -fcallgraph-info, record the call.
      	(emit_library_call_value_1): Likewise.
      	* flag-types.h (enum callgraph_info_type): New type.
      	* explow.c: Include stringpool.h.
      	(set_stack_check_libfunc): Set SET_SYMBOL_REF_DECL on the symbol.
      	* function.c (allocate_stack_usage_info): New.
      	(allocate_struct_function): Call it for -fcallgraph-info.
      	(prepare_function_start): Call it otherwise.
      	(record_final_call, record_dynamic_alloc): New.
      	* function.h (struct callinfo_callee): New.
      	(CALLEE_FROM_CGRAPH_P): New.
      	(struct callinfo_dalloc): New.
      	(struct stack_usage): Add callees and dallocs.
      	(record_final_call, record_dynamic_alloc): Declare.
      	* gimplify.c (gimplify_decl_expr): Record dynamically-allocated
      	object if -fcallgraph-info=da.
      	* optabs-libfuncs.c (build_libfunc_function): Keep SYMBOL_REF_DECL.
      	* print-tree.h (print_decl_identifier): Declare.
      	(PRINT_DECL_ORIGIN, PRINT_DECL_NAME, PRINT_DECL_UNIQUE_NAME): New.
      	* print-tree.c: Include print-tree.h.
      	(print_decl_identifier): New function.
      	* toplev.c: Include print-tree.h.
      	(callgraph_info_file): New global variable.
      	(callgraph_info_external_printed): Likewise.
      	(output_stack_usage): Rename to...
      	(output_stack_usage_1): ... this.  Make it static, add cf
      	parameter.  If -fcallgraph-info=su, print stack usage to cf.
      	If -fstack-usage, use print_decl_identifier for
      	pretty-printing.
      	(INDIRECT_CALL_NAME): New.
      	(dump_final_node_vcg_start): New.
      	(dump_final_callee_vcg, dump_final_node_vcg): New.
      	(output_stack_usage): New.
      	(lang_dependent_init): Open and start file if
      	-fcallgraph-info.  Allocated callgraph_info_external_printed.
      	(finalize): If callgraph_info_file is not null, finish it,
      	close it, and release callgraph_info_external_printed.
      
      for  gcc/ada/ChangeLog
      
      	* gcc-interface/misc.c (callgraph_info_file): Delete.
      
      Co-Authored-By: Alexandre Oliva <oliva@adacore.com>
      
      From-SVN: r277876
      Eric Botcazou committed
    • Warn about inconsistent OpenACC nested reduction clauses · 5d183d17
      	OpenACC (cf. OpenACC 2.7, section 2.9.11. "reduction clause";
      	this was first clarified by OpenACC 2.6) requires that, if a
      	variable is used in reduction clauses on two nested loops, then
      	there must be reduction clauses for that variable on all loops
      	that are nested in between the two loops and all these reduction
      	clauses must use the same operator.
      	This commit introduces a check for that property which reports
      	warnings if it is violated.
      
      	2019-11-06  Gergö Barany  <gergo@codesourcery.com>
      	            Frederik Harwath  <frederik@codesourcery.com>
      	            Thomas Schwinge  <thomas@codesourcery.com>
      
      	gcc/
      	* omp-low.c (struct omp_context): New fields
      	local_reduction_clauses, outer_reduction_clauses.
      	(new_omp_context): Initialize these.
      	(scan_sharing_clauses): Record reduction clauses on OpenACC constructs.
      	(scan_omp_for): Check reduction clauses for incorrect nesting.
      	gcc/testsuite/
      	* c-c++-common/goacc/nested-reductions-warn.c: New test.
      	* c-c++-common/goacc/nested-reductions.c: New test.
      	* gfortran.dg/goacc/nested-reductions-warn.f90: New test.
      	* gfortran.dg/goacc/nested-reductions.f90: New test.
      	libgomp/
      	* testsuite/libgomp.oacc-c-c++-common/par-loop-comb-reduction-1.c:
      	Add expected warnings about missing reduction clauses.
      	* testsuite/libgomp.oacc-c-c++-common/par-loop-comb-reduction-2.c:
      	Likewise.
      	* testsuite/libgomp.oacc-c-c++-common/par-loop-comb-reduction-3.c:
      	Likewise.
      	* testsuite/libgomp.oacc-c-c++-common/par-loop-comb-reduction-4.c:
      	Likewise.
      
      	Reviewed-by: Thomas Schwinge <thomas@codesourcery.com>
      
      From-SVN: r277875
      Frederik Harwath committed
    • re PR inline-asm/92352 (ICE in force_constant_size) · 5f6705b7
      	PR inline-asm/92352
      	* gimplify.c (gimplify_asm_expr): Reject VLA in output or input
      	operands with non-memory constraints.
      
      	* c-c++-common/pr92352.c: New test.
      
      From-SVN: r277873
      Jakub Jelinek committed
    • PR92090: Fix part of testcase failures by r276469 · 8adf3cc4
      -finline-functions is enabled by default for O2 since r276469, update the
      test cases with -fno-inline-functions.
      c11-atomic-exec-5.c stills hit ICE of LRA on BE systems in PR92090.
      This commit is NOT a fix for the bug and so it must NOT be closed.
      
      gcc/testsuite/ChangeLog:
      
      	2019-11-06  Xiong Hu Luo  <luoxhu@linux.ibm.com>
      
      	PR92090
      	* gcc.target/powerpc/pr72804.c: Add -fno-inline-functions --param
      	max-inline-insns-single-O2=200.
      	* gcc.target/powerpc/pr79439-1.c: Add -fno-inline-functions.
      	* gcc.target/powerpc/vsx-builtin-7.c: Likewise.
      
      From-SVN: r277872
      Xiong Hu Luo committed
    • PR tree-optimization/92373 - ICE in -Warray-bounds on access to member array in… · 91eb5fa8
      PR tree-optimization/92373 - ICE in -Warray-bounds on access to member array in an initialized char buffer
      
      gcc/testsuite/ChangeLog:
      
      	PR tree-optimization/92373
      	* gcc.dg/Warray-bounds-55.c: New test.
      	* gcc.dg/Wzero-length-array-bounds-2.c: New test.
      
      gcc/ChangeLog:
      
      	PR tree-optimization/92373
      	* tree.c (component_ref_size): Only consider initializers of objects
      	of matching struct types.
      	Return null for instances of interior zero-length arrays.
      
      From-SVN: r277871
      Martin Sebor committed
    • Daily bump. · eebabc49
      From-SVN: r277870
      GCC Administrator committed
    • doc: Insn splitting by combine · 8cb0906b
      The combine pass is perfectly happy if a splitter splits to just one
      instruction (instead of two).
      
      
      	* doc/md.texi (Insn Splitting): Fix combiner documentation.
      
      From-SVN: r277866
      Segher Boessenkool committed
  3. 05 Nov, 2019 3 commits
    • Implement C++20 operator<=>. · b7689b96
      There are three major pieces to this support: scalar operator<=>,
      synthesis of comparison operators, and rewritten/reversed overload
      resolution (e.g. a < b becomes 0 > b <=> a).
      
      Unlike other defaulted functions, where we use synthesized_method_walk to
      semi-simulate what the definition of the function will be like, this patch
      determines the characteristics of a comparison operator by trying to define
      it.
      
      My handling of non-dependent rewritten operators in templates can still use
      some work: build_min_non_dep_op_overload can't understand the rewrites and
      crashes, so I'm avoiding it for now by clearing *overload.  This means we'll
      do name lookup again at instantiation time, which can incorrectly mean a
      different result.  I'll poke at this more in stage 3.
      
      I'm leaving out a fourth section ("strong structural equality") even though
      I've implemented it, because it seems likely to change radically tomorrow.
      
      Thanks to Tim van Deurzen and Jakub for implementing lexing of the <=>
      operator, and Jonathan for the initial <compare> header.
      
      gcc/cp/
      	* cp-tree.h (struct lang_decl_fn): Add maybe_deleted bitfield.
      	(DECL_MAYBE_DELETED): New.
      	(enum special_function_kind): Add sfk_comparison.
      	(LOOKUP_REWRITTEN, LOOKUP_REVERSED): New.
      	* call.c (struct z_candidate): Add rewritten and reversed methods.
      	(add_builtin_candidate): Handle SPACESHIP_EXPR.
      	(add_builtin_candidates): Likewise.
      	(add_candidates): Don't add a reversed candidate if the parms are
      	the same.
      	(add_operator_candidates): Split out from build_new_op_1.  Handle
      	rewritten and reversed candidates.
      	(add_candidate): Swap conversions of reversed candidate.
      	(build_new_op_1): Swap them back.  Build a second operation for
      	rewritten candidates.
      	(extract_call_expr): Handle rewritten calls.
      	(same_fn_or_template): New.
      	(joust): Handle rewritten and reversed candidates.
      	* class.c (add_implicitly_declared_members): Add implicit op==.
      	(classtype_has_op, classtype_has_defaulted_op): New.
      	* constexpr.c (cxx_eval_binary_expression): Handle SPACESHIP_EXPR.
      	(cxx_eval_constant_expression, potential_constant_expression_1):
      	Likewise.
      	* cp-gimplify.c (genericize_spaceship): New.
      	(cp_genericize_r): Use it.
      	* cp-objcp-common.c (cp_common_init_ts): Handle SPACESHIP_EXPR.
      	* decl.c (finish_function): Handle deleted function.
      	* decl2.c (grokfield): SET_DECL_FRIEND_CONTEXT on defaulted friend.
      	(mark_used): Check DECL_MAYBE_DELETED.  Remove assumption that
      	defaulted functions are non-static members.
      	* error.c (dump_expr): Handle SPACESHIP_EXPR.
      	* method.c (type_has_trivial_fn): False for sfk_comparison.
      	(enum comp_cat_tag, struct comp_cat_info_t): New types.
      	(comp_cat_cache): New array variable.
      	(lookup_comparison_result, lookup_comparison_category)
      	(is_cat, cat_tag_for, spaceship_comp_cat)
      	(spaceship_type, genericize_spaceship)
      	(common_comparison_type, early_check_defaulted_comparison)
      	(comp_info, build_comparison_op): New.
      	(synthesize_method): Handle sfk_comparison.  Handle deleted.
      	(get_defaulted_eh_spec, maybe_explain_implicit_delete)
      	(explain_implicit_non_constexpr, implicitly_declare_fn)
      	(defaulted_late_check, defaultable_fn_check): Handle sfk_comparison.
      	* name-lookup.c (get_std_name_hint): Add comparison categories.
      	* tree.c (special_function_p): Add sfk_comparison.
      	* typeck.c (cp_build_binary_op): Handle SPACESHIP_EXPR.
      
      2019-11-05  Tim van Deurzen  <tim@kompiler.org>
      
      	Add new tree code for the spaceship operator.
      gcc/cp/
      	* cp-tree.def: Add new tree code.
      	* operators.def: New binary operator.
      	* parser.c: Add new token and tree code.
      libcpp/
      	* cpplib.h: Add spaceship operator for C++.
      	* lex.c: Implement conditional lexing of spaceship operator for C++20.
      
      2019-11-05  Jonathan Wakely  <jwakely@redhat.com>
      
      libstdc++-v3/
      	* libsupc++/compare: New header.
      	* libsupc++/Makefile.am (std_HEADERS): Add compare.
      	* include/std/version: Define __cpp_lib_three_way_comparison.
      	* include/std/functional: #include <compare>.
      
      From-SVN: r277865
      Jason Merrill committed
    • Fix conversions for built-in operator overloading candidates. · b63566a4
      While working on C++20 operator<=>, I noticed that build_new_op_1 was doing
      too much conversion when a built-in candidate was selected; the standard
      says it should only perform user-defined conversions, and then leave the
      normal operator semantics to handle any standard conversions.  This is
      important for operator<=> because a comparison of two different unscoped
      enums is ill-formed; if we promote the enums to int here, cp_build_binary_op
      never gets to see the original operand types, so we can't give the error.
      
      I'm also disabling -Wmaybe-uninitialized for expmed.c to avoid the bootstrap
      failure from the last time I applied this patch.
      
      	* call.c (build_new_op_1): Don't apply any standard conversions to
      	the operands of a built-in operator.  Don't suppress conversions in
      	cp_build_unary_op.
      	* typeck.c (cp_build_unary_op): Do integral promotions for enums.
      
      	PR tree-optimization/91825
      	* expmed.c: Reduce -Wmaybe-uninitialized to warning.
      
      From-SVN: r277864
      Jason Merrill committed
    • Use vec instead of raw array for built-in candidates. · 6fda5f49
      My operator<=> patch wants to split up build_new_op_1, which makes using a
      tree array as well as the vec inconvenient.  build_new_op_1 already has a
      vec, and build_conditional_expr_1 can release its vec right away, so this
      doesn't increase garbage at all.
      
      	* call.c (build_builtin_candidate): Take args in a vec.
      	(add_builtin_candidate, add_builtin_candidates): Likewise.
      	(build_conditional_expr_1, build_new_op_1): Adjust.
      
      From-SVN: r277863
      Jason Merrill committed