1. 26 Nov, 2018 9 commits
  2. 25 Nov, 2018 6 commits
  3. 24 Nov, 2018 5 commits
  4. 23 Nov, 2018 20 commits
    • re PR bootstrap/88157 (ICE when building libgo encoding/gob.lo starting with r266385) · 795a6c67
      2018-11-23  Vladimir Makarov  <vmakarov@redhat.com>
      
      	PR bootstrap/88157
      	* ira-costs.c (record_operand_costs): Use bigger hard reg class if
      	its mode does not fit to the original class.
      
      From-SVN: r266422
      Vladimir Makarov committed
    • pr70669.c: Use unary minus instead of addition. · 1b8ccb9d
      2018-11-23  Vladimir Makarov  <vmakarov@redhat.com>
      
      	* gcc.target/powerpc/pr70669.c: Use unary minus instead of
      	addition.
      
      From-SVN: r266421
      Vladimir Makarov committed
    • re PR tree-optimization/87756 (missing unterminated argument warning using… · 0c3aba0c
      re PR tree-optimization/87756 (missing unterminated argument warning using address of a constant character)
      
      	PR tree-optimization/87756
      	* gcc.dg/builtin-memchr-2.c: Scan the gimple dump instead of
      	optimized.
      	* gcc.dg/builtin-memchr-3.c: Likewise.
      
      From-SVN: r266420
      Jakub Jelinek committed
    • Make recursion_check work for multiple threads · f4c0f888
      With multiple threads, using an unprotected static variable to check
      whether recursion has occured isn't valid, as one thread might have
      modified the variable, thus causing another thread to incorrectly
      conclude that recursion has occured.  This patch avoids this problem
      by using a thread-specific variable for the recursion check.
      
      Regtested on x86_64-pc-linux-gnu.
      
      libgfortran/ChangeLog:
      
      2018-11-23  Janne Blomqvist  <jb@gcc.gnu.org>
      
      	* runtime/error.c (MAGIC): Remove.
      	(recursion_key): New variable.
      	(recursion_check): Use thread-specific variable for recursion
      	check if threads are active.
      	(constructor_recursion_check): New function.
      	(destructor_recursion_check): New funcion.
      
      From-SVN: r266419
      Janne Blomqvist committed
    • PR tree-optimization/87756 - missing unterminated argument warning using address… · 70c70369
      PR tree-optimization/87756 - missing unterminated argument warning using address of a constant character
      
      gcc/ChangeLog:
      
      	PR tree-optimization/87756
      	* expr.c (string_constant): Synthesize a string literal from
      	the address of a constant character.
      	* tree.c (build_string_literal): Add an argument.
      	* tree.h (build_string_literal): Same.
      
      gcc/testsuite/ChangeLog:
      
      	PR tree-optimization/87756
      	* gcc.dg/builtin-memchr-2.c: New test.
      	* gcc.dg/builtin-memchr-3.c: Same.
      	* gcc.dg/warn-sprintf-no-nul-2.c: Same.
      
      From-SVN: r266418
      Martin Sebor committed
    • PR testsuite/88098 - FAIL: gcc.dg/Wbuiltin-declaration-mismatch-4.c · db1d09b0
      gcc/c/ChangeLog:
      
      	PR testsuite/88098
      	* c-typeck.c (convert_arguments): Call builtin_decl_explicit instead.
      	(maybe_warn_builtin_no_proto_arg): Handle short enum to int promotion.
      
      gcc/testsuite/ChangeLog:
      
      	PR testsuite/88098
      	* gcc.dg/Wbuiltin-declaration-mismatch-4.c: Adjust.
      	* gcc.dg/Wbuiltin-declaration-mismatch-5.c: New test.
      	* gcc.dg/torture/pr67222.c: Adjust.
      
      From-SVN: r266417
      Martin Sebor committed
    • Implement P0415 More constexpr for std::complex. · e987fb1e
      
      2018-11-23  Edward Smith-Rowland  <3dw4rd@verizon.net>
      
      	Implement P0415 More constexpr for std::complex.
      	* include/std/complex (conj(complex<Tp>), norm(complex<Tp>)): Constexpr;
      	(real(Tp), imag(Tp)): Constexpr;
      	(operator@=(Tp), operator@=(complex<Tp>)): Constexpr;
      	(operator@(Tp,complex<Tp>), operator@(complex<Tp>,Tp)
      	operator@(complex<Tp>,complex<Tp>)): Constexpr.
      	* testsuite/26_numerics/complex/comparison_operators/
      	more_constexpr.cc: New test.
      	* testsuite/26_numerics/complex/operators/more_constexpr.cc: New test.
      	* testsuite/26_numerics/complex/requirements/
      	more_constexpr.cc: New test.
      	* testsuite/26_numerics/complex/value_operations/
      	more_constexpr.cc: New test.
      	* testsuite/26_numerics/headers/complex/synopsis.cc:
      	Add _GLIBCXX20_CONSTEXPR to applicable operators; Add missing proj().
      	* testsuite/26_numerics/headers/complex/synopsis.cc:
      	Add _GLIBCXX20_CONSTEXPR to relevant decls.
      
      From-SVN: r266416
      Edward Smith-Rowland committed
    • [aarch64] Add CPU support for Ampere Computing's eMAG. · e02669db
      2018-11-23  Christoph Muellner <christoph.muellner@theobroma-system.com>
      
      	* config/aarch64/aarch64-cores.def: Define emag.
      	* config/aarch64/aarch64-tune.md: Regenerated with emag.
      	* config/aarch64/aarch64.c (emag_tunings): New struct.
      	* doc/invoke.texi: Document mtune value.
      
      From-SVN: r266415
      Christoph Muellner committed
    • [aarch64] Update xgene1 tuning struct. · cf28c77e
      2018-11-23  Christoph Muellner  <christoph.muellner@theobroma-systems.com>
      	    Philipp Tomsich <philipp.tomsich@theobroma-systems.com>
      
      	* config/aarch64/aarch64.c (xgene1_tunings): Optimize Xgene1 tunings
      	for GCC 9.
      
      Co-Authored-By: Philipp Tomsich <philipp.tomsich@theobroma-systems.com>
      
      From-SVN: r266414
      Christoph Muellner committed
    • [aarch64] Add xgene1 prefetch tunings. · d5e9851e
      2018-11-23  Christoph Muellner  <christoph.muellner@theobroma-systems.com>
                  Philipp Tomsich <philipp.tomsich@theobroma-systems.com>
      
      	* config/aarch64/aarch64.c (xgene1_tunings): Add Xgene1 specific
      	prefetch tunings.
      
      Co-Authored-By: Philipp Tomsich <philipp.tomsich@theobroma-systems.com>
      
      From-SVN: r266413
      Christoph Muellner committed
    • [aarch64] Update xgene1_addrcost_table. · 52ddefd8
      2018-11-23  Christoph Muellner  <christoph.muellner@theobroma-systems.com>
                  Philipp Tomsich <philipp.tomsich@theobroma-systems.com>
      
      	* config/aarch64/aarch64.c (xgene1_addrcost_table): Correct the post modify
      	costs.
      
      Co-Authored-By: Philipp Tomsich <philipp.tomsich@theobroma-systems.com>
      
      From-SVN: r266412
      Christoph Muellner committed
    • [aarch64/arm] Updating the cost table for xgene1. · 221e1f30
      2018-11-23  Christoph Muellner <christoph.muellner@theobroma-system.com>
      
      	* config/arm/aarch-cost-tables.h (xgene1_extra_costs): Update the cost table
      	for Xgene1.
      
      From-SVN: r266411
      Christoph Muellner committed
    • PR libstdc++/65229 fix pretty printer for std::bitset<0> · 14a9206d
      2018-11-23  Martin Sebor  <msebor@redhat.com>
      	    Jonathan Wakely  <jwakely@redhat.com>
      
      	PR libstdc++/65229
      	* python/libstdcxx/v6/printers.py (StdBitsetPrinter): Handle
      	exception thrown for std::bitset<0>.
      	* testsuite/libstdc++-prettyprinters/simple.cc: Test std::bitset<0>.
      
      Co-Authored-By: Jonathan Wakely <jwakely@redhat.com>
      
      From-SVN: r266409
      Martin Sebor committed
    • PR libstdc++/87308 adjust regex used in std::any pretty printer · 11aa881f
      The pretty printer for std::any fails when the contained value is a
      locally-defined type, because the name in the debuginfo has
      cv-qualifiers and ptr-declarators in different positions. The unexpected
      format confuses the printer. This makes the printer's regex handle
      either format.
      
      This isn't a complete fix because looking up the contained type fails
      when there are two types with the same name (defined in different local
      scopes). This applies to all closure types defined in a given function,
      as they all appear as "func()::lambda" in the debuginfo names.
      
      	PR libstdc++/87308 (partial)
      	* python/libstdcxx/v6/printers.py (StdExpAnyPrinter): Adjust regex to
      	work around PR 88166.
      	* testsuite/libstdc++-prettyprinters/cxx17.cc: Test std::any
      	containing a local type.
      
      From-SVN: r266408
      Jonathan Wakely committed
    • re PR tree-optimization/88149 (ICE in vect_transform_stmt since r265959) · f7b94dec
      2018-11-23  Richard Biener  <rguenther@suse.de>
      
      	PR tree-optimization/88149
      	* tree-vect-slp.c (vect_slp_analyze_node_operations): Detect
      	the case where there are two different def types for the
      	same operand at different operand position in the same stmt.
      
      	* g++.dg/torture/pr88149.C: New testcase.
      
      From-SVN: r266406
      Richard Biener committed
    • [PATCH, ARM] Clean up arm backend using the @ construct for MD patterns · ff03f2d1
      This patch removes some of the machine mode checks from the arm backend when
      emitting instructions by using the '@' construct (Parameterized Names[2]). It
      is based on the previous AArch64 patch[1].
      
      [1] https://gcc.gnu.org/ml/gcc-patches/2018-07/msg00673.html
      [2] https://gcc.gnu.org/onlinedocs/gccint/Parameterized-Names.html#Parameterized-Names
      
      
      2018-23-11  Mihail Ionescu  <mihail.ionescu@arm.com>
      
      	* config/arm/arm.c (arm_expand_compare_and_swap): Simplify and call
      	gen_atomic_compare_swap_1.
      	(arm_evpc_neon_vuzp): Likewise gen_neon_vuzp_internal.
      	(arm_evpc_neon_vtrn): Likewise gen_neon_vtrn_internal.
      	(arm_evpc_neon_vext): Likewise gen_neon_vext_internal.
      	(arm_evpc_neon_vzip): Likewise gen_neon_vzip_internal.
      	(arm_evpc_neon_vrev): Replace the function pointer and simplify the mode
      	checks.
      	* config/arm/arm.md (neon_vext<mode>),
      	(neon_vrev64<mode>, neon_vrev32<mode>),
      	(neon_vrev16<mode>, neon_vtrn<mode>_internal),
      	(neon_vzip<mode>_internal, neon_vuzp<mode>_internal): Add an '@'character
      	before the pattern name.
      	* config/arm/sync.md:
      	(atomic_compare_and_swap<CCSI:arch><NARROW:mode>_1),
      	(atomic_compare_and_swap<CCSI:arch><SIDI:mode>_1): Likewise.
      
      From-SVN: r266404
      Mihail Ionescu committed
    • re PR tree-optimization/86614 (duplicate -Warray-bounds for a strncpy call with… · 21150aba
      re PR tree-optimization/86614 (duplicate -Warray-bounds for a strncpy  call with out-of-bounds offset)
      
      	PR tree-optimization/86614
      	* gimple-ssa-warn-restrict.c (maybe_diag_offset_bounds): Return early
      	if TREE_NO_WARNING is set on ref.ref.
      
      	* c-c++-common/Warray-bounds-2.c (wrap_strncpy_dstarray_diff_neg,
      	call_strncpy_dstarray_diff_neg): Don't expect late -Warray-bounds
      	warnings, just early ones from FE.  Remove dg-prune-output.
      	* c-c++-common/Warray-bounds-6.c: New test.
      
      From-SVN: r266403
      Jakub Jelinek committed
    • re PR c/53608 (Documentation could be clearer about designated initializers of unions) · e0a35f9b
      2018-11-22  Sandra Loosemore  <sandra@codesourcery.com>
      	    Alan Coopersmith  <alan.coopersmith@oracle.com>
      
      	PR c/53608
      
      	gcc/
      	* doc/extend.texi (Designated Inits): Clarify handling of multiple
      	initializers for unions.
      
      Co-Authored-By: Alan Coopersmith <alan.coopersmith@oracle.com>
      
      From-SVN: r266402
      Sandra Loosemore committed
    • Daily bump. · 3f317614
      From-SVN: r266400
      GCC Administrator committed
    • lang.opt (fpad-source): New option. · f03d260a
      	* lang.opt (fpad-source): New option.
      	* scanner.c (load_line): Don't pad fixed form lines if
      	!flag_pad_source.
      	* invoke.texi (-fno-pad-source): Document.
      
      	* gfortran.dg/pad_source_1.f: New test.
      	* gfortran.dg/pad_source_2.f: New test.
      	* gfortran.dg/pad_source_3.f: New test.
      	* gfortran.dg/pad_source_4.f: New test.
      	* gfortran.dg/pad_source_5.f: New test.
      
      From-SVN: r266397
      Jakub Jelinek committed