1. 10 Sep, 2018 2 commits
  2. 09 Sep, 2018 8 commits
  3. 08 Sep, 2018 6 commits
  4. 07 Sep, 2018 6 commits
    • Remove unused init_unsigned_integer function. · d4c0eb58
      As pointed out by Bernhard Reutner-Fischer, this function is unused
      since the fix for PR 53796 in November 2017.
      
      2018-09-07  Janne Blomqvist  <jb@gcc.gnu.org>
      
              * runtime/environ.c (init_unsigned_integer): Remove.
      
      From-SVN: r264163
      Janne Blomqvist committed
    • * config/i386/i386.md (float<SWI48x:mode><MODEF:mode>2) Enable · 785425e1
      	DImode for x87 on 32bit targets.  Conditionally disable x87 modes
      	with X87_ENABLE_FLOAT.  Remove preparation code.
      	(*float<SWI48:mode><MODEF:mode>2): Rename from
      	*float<SWI48:mode><MODEF:mode>2_mixed.  Handle x87, SSE and mixed
      	math using "enabled" attribute.
      	(*floatdi<MODEF:mode>2_i387): Rename from
      	*float<SWI48x:mode><MODEF:mode>2_i387.  Handle only DImode and
      	enable for 32bit targets only.
      	(floatdi<X87MODEF:mode>2_i387_with_xmm pre-reload splitter): New
      	splitter.
      	(floatdi<X87MODEF:mode>2_i387_with_xmm): Use register_operand
      	as operand 1 predicate.  Rewrite as define_insn_and_split.
      	(floatdi<X87MODEF:mode>2_i387_with_xmm memory input splitter): Remove.
      
      From-SVN: r264160
      Uros Bizjak committed
    • direct-enum-init1.C: Remove "inside" from diagnostic messages. · 6435284e
      	* g++.dg/cpp1z/direct-enum-init1.C: Remove "inside" from diagnostic
      	messages.
      
      From-SVN: r264159
      Marek Polacek committed
    • PR c++/87152 - range-based for loops with initializer broken in templates. · 8112667c
      	* constexpr.c (potential_constant_expression_1) <case RANGE_FOR_STMT>:
      	Recur into RANGE_FOR_INIT_STMT.
      	* cp-tree.def: Add RANGE_FOR_INIT_STMT to RANGE_FOR_STMT.
      	* cp-tree.h (RANGE_FOR_INIT_STMT): Define.
      	* dump.c (cp_dump_tree) <case RANGE_FOR_STMT>: Also dump
      	RANGE_FOR_INIT_STMT.
      	* pt.c (tsubst_expr) <case RANGE_FOR_STMT>: Recur into
      	RANGE_FOR_INIT_STMT.
      	* semantics.c (begin_range_for_stmt): Adjust call to build_stmt.
      	Do put the init statement in RANGE_FOR_INIT_STMT.
      	(finish_range_for_decl): Pop it for templates.
      
      	* g++.dg/cpp2a/range-for11.C: New test.
      	* g++.dg/cpp2a/range-for12.C: New test.
      	* g++.dg/cpp2a/range-for13.C: New test.
      	* g++.dg/cpp2a/range-for14.C: New test.
      	* g++.dg/cpp2a/range-for15.C: New test.
      	* g++.dg/cpp2a/range-for16.C: New test.
      	* g++.dg/cpp2a/range-for17.C: New test.
      	* g++.dg/cpp2a/range-for18.C: New test.
      	* g++.dg/parse/error61.C (foo): Adjust dg-error.
      
      From-SVN: r264158
      Marek Polacek committed
    • Fix C++17 expected errors for pointer to member function template args. · 6bf9284f
      * g++.dg/template/ptrmem20.C: Adjust expected diagnostic.
      * g++.dg/template/ptrmem8.C: Likewise.
      
      From-SVN: r264157
      Jason Merrill committed
    • Daily bump. · 446a6651
      From-SVN: r264155
      GCC Administrator committed
  5. 06 Sep, 2018 11 commits
    • reg-stack.c (get_true_reg): Reorder to fallthru to FLOAT case. · b3892454
      	* reg-stack.c (get_true_reg) <case FLOAT_TRUNCATE>: Reorder
      	to fallthru to FLOAT case.
      
      From-SVN: r264151
      Uros Bizjak committed
    • re PR target/86731 (Miscompiles vec_sl at -O3 with -fwrapv on ppc64el) · bd46d32c
      [gcc]
      
      2018-09-06  Will Schmidt  <will_schmidt@vnet.ibm.com>
      
      	PR target/86731
      	* config/rs6000/rs6000.c (rs6000_gimple_fold_builtin): Update logic
      	around folding of vec_sl to handle out of range shift values.
      
      [testsuite]
      
      2018-08-15  Will Schmidt  <will_schmidt@vnet.ibm.com>
      
      	PR target/86731
      	* gcc.target/powerpc/pr86731.c: New test.
      	* gcc.target/powerpc/pr86731-longlong.c: New test.
      	* gcc.target/powerpc/pr86731-fwrapv.c: New test.
      	* gcc.target/powerpc/pr86731-fwrapv-longlong.c: New test.
      	* gcc.target/powerpc/pr86731-nogimplefold.c: New test.
      	* gcc.target/powerpc/pr86731-nogimplefold-longlong.c: New test.
      
      From-SVN: r264150
      Will Schmidt committed
    • i386.md (fix_trunc<mode>_fisttp_i387_1): Remove. · 423c2a26
      	* config/i386/i386.md (fix_trunc<mode>_fisttp_i387_1): Remove.
      	Update callers to gen_fix_trunc<mode>_i387_fisttp
      	(fix_trunc<mode>_i387_fisttp): Change operand 0 predicate to
      	nonimmediate_operand.
      	(fix_trunc<mode>_i387_fisttp_with_temp): Remove insn pattern
      	and corresponding splitters.
      	(*fix_trunc<mode>_i387_1): Always expand with fix_trunc<mode>_i387.
      	(fix_truncdi_i387): Change operand 0 predicate to nonimmediate_operand.
      	(fix_truncdi_i387_with_temp): Remove insn pattern
      	and corresponding splitters.
      	(fix_trunc<mode>_i387): Change operand 0 predicate to
      	nonimmediate_operand.
      	(fix_trunc<mode>_i387_with_temp): Remove insn pattern
      	and corresponding splitters.
      	(*fistdi2_1): Remove.
      	(fistdi2): Ditto.
      	(fistdi2_with_temp): Remove insn pattern and corresponding splitters.
      	(lrintxfdi2): Remove expander.  Reimplement as define_insn.
      	(*fist<mode>2_1): Remove.
      	(fist<mode>2): Ditto.
      	(fist<mode>2_with_temp): Remove insn pattern and corresponding
      	splitters.
      	(lrintxf<mode>2): Remove expander.  Reimplement as define_insn.
      	(*fist<mode>2_<rounding>_1): Always expand with fist<mode>2_<rounding>.
      	(fistdi2_<rounding>): Change operand 0 predicate to
      	nonimmediate_operand.
      	(fistdi2_<rounding>_with_temp): Remove insn pattern
      	and corresponding splitters.
      	(fist<mode>2_<rounding>): Change operand 0 predicate to
      	nonimmediate_operand.
      	(fist<mode>2_<rounding>_with_temp): Remove insn pattern
      	and corresponding splitters.
      
      	(*fixuns_trunc<mode>si2_avx512f_zext): Depend on TARGET_SSE_MATH.
      
      From-SVN: r264148
      Uros Bizjak committed
    • varasm.c (output_constructor_regular_field): Check TYPE_SIZE_UNIT of the init value. · 6d900107
      	* varasm.c (output_constructor_regular_field): Check TYPE_SIZE_UNIT of
      	the init value.
      
      	* c-common.c (complete_flexible_array_elts): New helper function.
      	* c-common.h (complete_flexible_array_elts): Declare.
      
      	* c-decl.c (finish_decl): Call complete_flexible_array_elts.
      
      	* decl.c (check_initializer): Call cp_complete_array_type.
      
      From-SVN: r264147
      Bernd Edlinger committed
    • rs6000.c (rs6000_gimple_fold_builtin): Add support for early gimple folding of vec_splat(). · 6847c656
      [gcc]
      
      2018-09-06  Will Schmidt  <will_schmidt@vnet.ibm.com>
      
      	* config/rs6000/rs6000.c (rs6000_gimple_fold_builtin): Add support for
      	early gimple folding of vec_splat().
      	* tree-vect-generic.c: Remove static from tree_vec_extract() definition.
      	* gimple-fold.h: Add an extern define for tree_vec_extract().
      
      From-SVN: r264146
      Will Schmidt committed
    • rs6000.c (fold_mergehl_helper): Add types_compatible_p wrappers around TREE_TYPE comparisons. · 84bde0bf
      [gcc]
      
      2018-08-20  Will Schmidt  <will_schmidt@vnet.ibm.com>
      
      	* config/rs6000/rs6000.c (fold_mergehl_helper): Add types_compatible_p
      	wrappers around TREE_TYPE comparisons.
      
      From-SVN: r264145
      Will Schmidt committed
    • S/390: Prohibit SYMBOL_REF in UNSPECV_CAS · bdb57bcb
      Inhibit constant propagation inlining SYMBOL_REF loads into
      UNSPECV_CAS.  Even though reload can later undo it, the resulting
      code will be less efficient.
      
      gcc/ChangeLog:
      
      2018-09-06  Ilya Leoshkevich  <iii@linux.ibm.com>
      
      	PR target/80080
      	* config/s390/predicates.md: Add nonsym_memory_operand.
      	* config/s390/s390.c (s390_legitimize_cs_operand): If operand
      	contains a SYMBOL_REF, load it into an intermediate pseudo.
      	(s390_emit_compare_and_swap): Legitimize operand.
      	* config/s390/s390.md: Use the new nonsym_memory_operand
      	with UNSPECV_CAS patterns.
      
      gcc/testsuite/ChangeLog:
      
      2018-09-06  Ilya Leoshkevich  <iii@linux.ibm.com>
      
      	PR target/80080
      	* gcc.target/s390/pr80080-3.c: New test.
      	* gcc.target/s390/s390.exp: Make sure the new test passes
      	on all optimization levels.
      
      From-SVN: r264143
      Ilya Leoshkevich committed
    • S/390: Register pass_s390_early_mach statically · d7252499
      The dump file used to come at the end of the sorted dump file list,
      because the pass was registered dynamically. This did not reflect the
      order in which passes are executed. Static registration fixes this:
      
      * foo4.c.277r.split2
      * foo4.c.281r.early_mach
      * foo4.c.282r.pro_and_epilogue
      
      gcc/ChangeLog:
      
      2018-09-06  Ilya Leoshkevich  <iii@linux.ibm.com>
      
      	PR target/80080
      	* config/s390/s390-passes.def: New file.
      	* config/s390/s390-protos.h (class rtl_opt_pass): Add forward
      	declaration.
      	(make_pass_s390_early_mach): Add declaration.
      	* config/s390/s390.c (make_pass_s390_early_mach):
      	(s390_option_override): Remove dynamic registration.
      	* config/s390/t-s390: Add s390-passes.def.
      
      From-SVN: r264142
      Ilya Leoshkevich committed
    • S/390: Remove UNSPEC_LTREL_BASE · f0d20631
      It was needed only for g5/g6 machines, which are now gone.
      
      gcc/ChangeLog:
      
      2018-09-06  Ilya Leoshkevich  <iii@linux.ibm.com>
      
      	* config/s390/s390.c (s390_decompose_constant_pool_ref):
      	Remove UNSPEC_LTREL_BASE check.
      	(annotate_constant_pool_refs): Likewise.
      	(find_constant_pool_ref): Likewise.
      	(find_ltrel_base): Removed.
      	(replace_ltrel_base): Removed.
      	(s390_mainpool_finish): Remove replace_ltrel_base call.
      	(s390_chunkify_start): Remove pending LTREL_BASE logic.
      	(s390_chunkify_finish): Remove replace_ltrel_base call.
      	* config/s390/s390.md: Remove UNSPEC_LTREL_BASE.
      
      From-SVN: r264141
      Ilya Leoshkevich committed
    • PR c++/86982, -Wreturn-local-addr and std::move and std::forward. · 308d9cda
      	* typeck.c (maybe_warn_about_returning_address_of_local): Handle calls
      	to std::move or std::forward.
      	(is_std_forward_p): New function.
      
      	* g++.dg/warn/Wreturn-local-addr-5.C: New test.
      
      From-SVN: r264139
      Marek Polacek committed
    • Daily bump. · 4497d88f
      From-SVN: r264138
      GCC Administrator committed
  6. 05 Sep, 2018 7 commits
    • re PR target/86779 (Cris port needs updating for CVE-2017-5753) · c53e89f4
      	PR target/86779
      	* config/cris/cris.c (TARGET_HAVE_SPECULATION_SAFE_VALUE): Redefine
      	to speculation_safe_value_not_needed.
      
      From-SVN: r264134
      Hans-Peter Nilsson committed
    • [nvptx] Basic -misa support for nvptx · 53ceb8b5
      	gcc/
      	* config/nvptx/nvptx-opts.h: New file.
      	* config/nvptx/nvptx.c (nvptx_file_start): Print the correct .target.
      	* config/nvptx/nvptx.h: Include "nvptx-opts.h".
      	(ASM_SPEC): Define.
      	(TARGET_SM35): New macro.
      	* config/nvptx/nvptx.md (atomic_fetch_<logic><mode>): Enable with the
      	correct predicate.
      	* config/nvptx/nvptx.opt (ptx_isa, sm_30, sm_35): New enum and its
      	values.
      	(misa=): New option.
      	* doc/invoke.texi (Nvidia PTX Options): Document -misa.
      
      	gcc/testsuite/
      	* gcc.target/nvptx/atomic_fetch-1.c: New test.
      	* gcc.target/nvptx/atomic_fetch-1.c: New test.
      
      
      Co-Authored-By: Bernd Schmidt <bernds_cb1@t-online.de>
      
      From-SVN: r264133
      Cesar Philippidis committed
    • PR c++/87109, wrong overload with ref-qualifiers. · 62c21cee
      	* call.c (build_user_type_conversion_1): Use NULL instead of 0.  Bail
      	out if performing the maybe-rvalue overload resolution and a conversion
      	function is getting called.
      
      	* g++.dg/cpp0x/ref-qual19.C: New test.
      
      From-SVN: r264132
      Marek Polacek committed
    • i386.md (truncdfsf2): Remove expander. · f6b95f78
      	* config/i386/i386.md (truncdfsf2): Remove expander.
      	(truncdfsf2_with_temp): Ditto.
      	(truncxf<mode>2): Ditto.
      	(*truncdfsf_fast_mixed): Remove insn pattern.
      	(*truncdfsf_fast_i387): Ditto.
      	(*truncdfsf_mixed): Ditto.
      	(*truncdfsf_i387): Ditto.
      	(*truncdfsf2_i387_1): Ditto.
      	(*truncxfsf2_mixed): Ditto.
      	(*truncxfdf2_mixed): Ditto.
      	(*truncxf<mode>2_i387_noop): Ditto. Update callers
      	to call gen_truncxf<mode>2 instead.
      	(*truncxf<mode>2_i387): Remove.
      	(reg->reg splitters): Remove splitter pattern.
      	(reg->mem splitters): Ditto.
      
      	(truncdfsf2): New insn pattern.
      	(truncxf<mode>2): Ditto.
      
      From-SVN: r264130
      Uros Bizjak committed
    • PR52665 do not let .ident confuse assembler scan tests · eb6ffc66
      A branch with a name matching scan-assembler pattern triggers
      inappropriate FAIL.
      
      E.g. branch fixups-testsuite and
      - gcc.target/i386/pr65871-?.c (scan-assembler-not "test")
      - gcc.target/i386/pr41442.c (scan-assembler-times "test|cmp" 2)
      etc.
      
      This is a recurring problem as can be seen by some -fno-ident additions
      by commits from e.g. Michael Meissner over the years: builtins-58.c,
      powerpc/pr46728-?.c
      
      The patch below adds -fno-ident if a testcase contains one of
      scan-assembler, scan-assembler-not or scan-assembler-times.
      
      Regression tested on x86_64-unknown-linux on a fixups-testsuite branch
      where it fixes several false FAILs without regressions.
      
      gcc/testsuite/ChangeLog
      
      2016-06-18  Bernhard Reutner-Fischer  <aldot@gcc.gnu.org>
      
              PR testsuite/52665
              * lib/gcc-dg.exp (gcc-dg-test-1): Iterate over _required_options.
              * lib/target-supports.exp (scan-assembler_required_options,
              scan-assembler-not_required_options,
              scan-assembler-times_required_options): Add -fno-ident.
              * lib/scanasm.exp (scan-assembler-times): Fix error message.
              * c-c++-common/ident-0a.c: New test.
              * c-c++-common/ident-0b.c: New test.
              * c-c++-common/ident-1a.c: New test.
              * c-c++-common/ident-1b.c: New test.
              * c-c++-common/ident-2a.c: New test.
              * c-c++-common/ident-2b.c: New test.
      
      From-SVN: r264128
      Bernhard Reutner-Fischer committed
    • Optimise sqrt reciprocal multiplications · 24c49431
      This patch aims to optimise sequences involving uses of 1.0 / sqrt (a) under -freciprocal-math and -funsafe-math-optimizations.
      In particular consider:
      
      x = 1.0 / sqrt (a);
      r1 = x * x;  // same as 1.0 / a
      r2 = a * x; // same as sqrt (a)
      
      If x, r1 and r2 are all used further on in the code, this can be transformed into:
      tmp1 = 1.0 / a
      tmp2 = sqrt (a)
      tmp3 = tmp1 * tmp2
      x = tmp3
      r1 = tmp1
      r2 = tmp2
      
      A bit convoluted, but this saves us one multiplication and, more importantly, the sqrt and division are now independent.
      This also allows optimisation of a subset of these expressions.
      For example:
      x = 1.0 / sqrt (a)
      r1 = x * x
      
      can be transformed to r1 = 1.0 / a, eliminating the sqrt if x is not used anywhere else.
      And similarly:
      x = 1.0 / sqrt (a)
      r1 = a * x
      
      can be transformed to sqrt (a) eliminating the division.
      
      For the testcase:
      double res, res2, tmp;
      void
      foo (double a, double b)
      {
        tmp = 1.0 / __builtin_sqrt (a);
        res = tmp * tmp;
        res2 = a * tmp;
      }
      
      We now generate for aarch64 with -Ofast:
      foo:
              fmov    d2, 1.0e+0
              adrp    x2, res2
              fsqrt   d1, d0
              adrp    x1, res
              fdiv    d0, d2, d0
              adrp    x0, tmp
              str     d1, [x2, #:lo12:res2]
              fmul    d1, d1, d0
              str     d0, [x1, #:lo12:res]
              str     d1, [x0, #:lo12:tmp]
              ret
      
      where before it generated:
      foo:
              fsqrt   d2, d0
              fmov    d1, 1.0e+0
              adrp    x1, res2
              adrp    x2, tmp
              adrp    x0, res
              fdiv    d1, d1, d2
              fmul    d0, d1, d0
              fmul    d2, d1, d1
              str     d1, [x2, #:lo12:tmp]
              str     d0, [x1, #:lo12:res2]
              str     d2, [x0, #:lo12:res]
              ret
      
      As you can see, the new sequence has one fewer multiply and the fsqrt and fdiv are independent. 
      
      	* tree-ssa-math-opts.c (is_mult_by): New function.
      	(is_square_of): Use the above.
      	(optimize_recip_sqrt): New function.
      	(pass_cse_reciprocals::execute): Use the above.
      
      	* gcc.dg/recip_sqrt_mult_1.c: New test.
      	* gcc.dg/recip_sqrt_mult_2.c: Likewise.
      	* gcc.dg/recip_sqrt_mult_3.c: Likewise.
      	* gcc.dg/recip_sqrt_mult_4.c: Likewise.
      	* gcc.dg/recip_sqrt_mult_5.c: Likewise.
      	* g++.dg/recip_sqrt_mult_1.C: Likewise.
      	* g++.dg/recip_sqrt_mult_2.C: Likewise.
      
      From-SVN: r264126
      Kyrylo Tkachov committed