1. 06 Aug, 2018 16 commits
    • re PR c++/86767 (continue statements in constexpr functions causes unbounded looping) · 0250ba58
      	PR c++/86767
      	* constexpr.c (cxx_eval_statement_list): Handle continue.
      
      	* g++.dg/cpp1y/constexpr-86767.C: New test.
      
      From-SVN: r263340
      Marek Polacek committed
    • Fix memory leak in selftest::test_expansion_to_rtl · 5242b3cb
      "make selftest-valgrind" shows:
      
      187 bytes in 1 blocks are definitely lost in loss record 567 of 669
          at 0x4A081D4: calloc (in /usr/lib64/valgrind/vgpreload_memcheck-amd64-linux.so)
          by 0x1F08260: xcalloc (xmalloc.c:162)
          by 0xB24F32: init_emit() (emit-rtl.c:5843)
          by 0xC10080: prepare_function_start() (function.c:4803)
          by 0xC10254: init_function_start(tree_node*) (function.c:4877)
          by 0x1CDF92A: selftest::test_expansion_to_rtl() (function-tests.c:595)
          by 0x1CE007C: selftest::function_tests_c_tests() (function-tests.c:676)
          by 0x1E010E7: selftest::run_tests() (selftest-run-tests.c:98)
          by 0x1062D1E: toplev::run_self_tests() (toplev.c:2225)
          by 0x1062F40: toplev::main(int, char**) (toplev.c:2303)
          by 0x1E5B90A: main (main.c:39)
      
      The allocation in question is:
      
        crtl->emit.regno_pointer_align
          = XCNEWVEC (unsigned char, crtl->emit.regno_pointer_align_length);
      
      This patch fixes this leak (and makes the output of
      "make selftest-valgrind" clean) by calling free_after_compilation at the
      end of the selftest in question.
      
      gcc/ChangeLog:
      	* function-tests.c (selftest::test_expansion_to_rtl): Call
      	free_after_compilation.
      
      From-SVN: r263339
      David Malcolm committed
    • pr86763.C (dg-additional-options): Add -lrt for target *-*-linux-gnu. · 27ee6398
      	* g++.dg/torture/pr86763.C (dg-additional-options): Add -lrt
      	for target *-*-linux-gnu.
      
      From-SVN: r263338
      Uros Bizjak committed
    • Enable clobber high for tls descs on Aarch64 · 234c9000
      gcc/
      	* config/aarch64/aarch64.md: Add clobber highs to tls_desc.
      
      gcc/testsuite/
      	* gcc.target/aarch64/sve/tls_preserve_1.c: New test.
      	* gcc.target/aarch64/sve/tls_preserve_2.c: New test.
      	* gcc.target/aarch64/sve/tls_preserve_3.c: New test.
      
      From-SVN: r263337
      Alan Hayward committed
    • S/390: Don't unroll memory blk op loops · 8eed4721
      gcc/ChangeLog:
      
      2018-08-06  Andreas Krebbel  <krebbel@linux.ibm.com>
      
      	* config/s390/s390.c (s390_loop_unroll_adjust): Prevent small
      	loops with memory block operations from getting unrolled.
      
      gcc/testsuite/ChangeLog:
      
      2018-08-06  Andreas Krebbel  <krebbel@linux.ibm.com>
      
      	* gcc.target/s390/nomemloopunroll-1.c: New test.
      
      From-SVN: r263336
      Andreas Krebbel committed
    • [spu, commit] Define TARGET_HAVE_SPECULATION_SAFE_VALUE · 2f171da9
      The SPU processor is not affected by speculation, so this macro can
      safely be defined as speculation_safe_value_not_needed.
      
      gcc/ChangeLog:
      
      	PR target/86807
      	* config/spu/spu.c (TARGET_HAVE_SPECULATION_SAFE_VALUE):
      	Define to speculation_safe_value_not_needed.
      
      From-SVN: r263335
      Ulrich Weigand committed
    • reload1.c (forget_old_reloads_1): Adjust CLOBBER_HIGH assert. · 5dc09626
      	* reload1.c (forget_old_reloads_1): Adjust CLOBBER_HIGH
      	assert.
      
      From-SVN: r263333
      Jeff Law committed
    • re PR target/86662 (msp430-elf segfault with -flto and -mlarge) · edbbb166
      PR target/86662
      
              * gcc/tree.c (build_common_tree_nodes): Initialize integer_types array
              with all enabled __intN types.
      
              * gcc/testsuite/gcc.target/msp430/pr86662.c: New test.
      
      From-SVN: r263332
      Jozef Lawrynowicz committed
    • Remaining support for clobber high · 8df47bdf
      gcc/
      	* alias.c (record_set): Check for clobber high.
      	* cfgexpand.c (expand_gimple_stmt): Likewise.
      	* combine-stack-adj.c (single_set_for_csa): Likewise.
      	* combine.c (find_single_use_1): Likewise.
      	(set_nonzero_bits_and_sign_copies): Likewise.
      	(get_combine_src_dest): Likewise.
      	(is_parallel_of_n_reg_sets): Likewise.
      	(try_combine): Likewise.
      	(record_dead_and_set_regs_1): Likewise.
      	(reg_dead_at_p_1): Likewise.
      	(reg_dead_at_p): Likewise.
      	* dce.c (deletable_insn_p): Likewise.
      	(mark_nonreg_stores_1): Likewise.
      	(mark_nonreg_stores_2): Likewise.
      	* df-scan.c (df_find_hard_reg_defs): Likewise.
      	(df_uses_record): Likewise.
      	(df_get_call_refs): Likewise.
      	* dwarf2out.c (mem_loc_descriptor): Likewise.
      	* haifa-sched.c (haifa_classify_rtx): Likewise.
      	* ira-build.c (create_insn_allocnos): Likewise.
      	* ira-costs.c (scan_one_insn): Likewise.
      	* ira.c (equiv_init_movable_p): Likewise.
      	(rtx_moveable_p): Likewise.
      	(interesting_dest_for_shprep): Likewise.
      	* jump.c (mark_jump_label_1): Likewise.
      	* postreload-gcse.c (record_opr_changes): Likewise.
      	* postreload.c (reload_cse_simplify): Likewise.
      	(struct reg_use): Add source expr.
      	(reload_combine): Check for clobber high.
      	(reload_combine_note_use): Likewise.
      	(reload_cse_move2add): Likewise.
      	(move2add_note_store): Likewise.
      	* print-rtl.c (print_pattern): Likewise.
      	* recog.c (decode_asm_operands): Likewise.
      	(store_data_bypass_p): Likewise.
      	(if_test_bypass_p): Likewise.
      	* regcprop.c (kill_clobbered_value): Likewise.
      	(kill_set_value): Likewise.
      	* reginfo.c (reg_scan_mark_refs): Likewise.
      	* reload1.c (maybe_fix_stack_asms): Likewise.
      	(eliminate_regs_1): Likewise.
      	(elimination_effects): Likewise.
      	(mark_not_eliminable): Likewise.
      	(scan_paradoxical_subregs): Likewise.
      	(forget_old_reloads_1): Likewise.
      	* reorg.c (find_end_label): Likewise.
      	(try_merge_delay_insns): Likewise.
      	(redundant_insn): Likewise.
      	(own_thread_p): Likewise.
      	(fill_simple_delay_slots): Likewise.
      	(fill_slots_from_thread): Likewise.
      	(dbr_schedule): Likewise.
      	* resource.c (update_live_status): Likewise.
      	(mark_referenced_resources): Likewise.
      	(mark_set_resources): Likewise.
      	* rtl.c (copy_rtx): Likewise.
      	* rtlanal.c (reg_referenced_p): Likewise.
      	(single_set_2): Likewise.
      	(noop_move_p): Likewise.
      	(note_stores): Likewise.
      	* sched-deps.c (sched_analyze_reg): Likewise.
      	(sched_analyze_insn): Likewise.
      
      From-SVN: r263331
      Alan Hayward committed
    • cse support for clobber_high · 99788e06
      gcc/
      	* cse.c (invalidate_reg): New function extracted from...
      	(invalidate): ...here.
      	(canonicalize_insn): Check for clobber high.
      	(invalidate_from_clobbers): invalidate clobber highs.
      	(invalidate_from_sets_and_clobbers): Likewise.
      	(count_reg_usage): Check for clobber high.
      	(insn_live_p): Likewise.
      	* cselib.c (cselib_expand_value_rtx_1):Likewise.
      	(cselib_invalidate_regno): Check for clobber in setter.
      	(cselib_invalidate_rtx): Pass through setter.
      	(cselib_invalidate_rtx_note_stores):
      	(cselib_process_insn): Check for clobber high.
      	* cselib.h (cselib_invalidate_rtx): Add operand.
      
      From-SVN: r263330
      Alan Hayward committed
    • lra support for clobber_high · 30dc1902
      gcc/
      	* lra-eliminations.c (lra_eliminate_regs_1): Check for clobber high.
      	(mark_not_eliminable): Likewise.
      	* lra-int.h (struct lra_insn_reg): Add clobber high marker.
      	* lra-lives.c (process_bb_lives): Check for clobber high.
      	* lra.c (new_insn_reg): Remember clobber highs.
      	(collect_non_operand_hard_regs): Check for clobber high.
      	(lra_set_insn_recog_data): Likewise.
      	(add_regs_to_insn_regno_info): Likewise.
      	(lra_update_insn_regno_info): Likewise.
      
      From-SVN: r263329
      Alan Hayward committed
    • Add func to check if register is clobbered by clobber_high · 6a7fa0c2
      gcc/
      	* rtl.h (reg_is_clobbered_by_clobber_high): Add declarations.
      	* rtlanal.c (reg_is_clobbered_by_clobber_high): Add function.
      
      From-SVN: r263328
      Alan Hayward committed
    • Generation support for CLOBBER_HIGH · 14196e02
      Ensure clobber high is a register expression.
      Info is passed through for the error case.
      
      gcc/
      	* emit-rtl.c (verify_rtx_sharing): Check for CLOBBER_HIGH.
      	(copy_insn_1): Likewise.
      	(gen_hard_reg_clobber_high): New gen function.
      	* genconfig.c (walk_insn_part): Check for CLOBBER_HIGH.
      	* genemit.c (gen_exp): Likewise.
      	(gen_emit_seq): Pass through info.
      	(gen_insn): Check for CLOBBER_HIGH.
      	(gen_expand): Pass through info.
      	(gen_split): Likewise.
      	(output_add_clobbers): Likewise.
      	* genrecog.c (validate_pattern): Check for CLOBBER_HIGH.
      	(remove_clobbers): Likewise.
      	* rtl.h (gen_hard_reg_clobber_high): New declaration.
      
      From-SVN: r263327
      Alan Hayward committed
    • Add CLOBBER_HIGH expression · 601e86a5
      Includes documentation.
      
      2018-08-06  Alan Hayward  <alan.hayward@arm.com>
      
      	* doc/rtl.texi (clobber_high): Add.
      	(parallel): Add in clobber high
      	* rtl.c (rtl_check_failed_code3): Add function.
      	* rtl.def (CLOBBER_HIGH): Add expression.
      	* rtl.h (RTL_CHECKC3): Add macro.
      	(rtl_check_failed_code3): Add declaration.
      	(XC3EXP): Add macro.
      
      From-SVN: r263326
      Alan Hayward committed
    • MAINTAINERS: Update my email address. · 6e9f49e4
      	* MAINTAINERS: Update my email address.
      
      From-SVN: r263325
      Naveen H.S committed
    • Daily bump. · 7aa6ee2c
      From-SVN: r263324
      GCC Administrator committed
  2. 05 Aug, 2018 4 commits
  3. 04 Aug, 2018 7 commits
  4. 03 Aug, 2018 13 commits
    • nios2.c (TARGET_HAVE_SPECULATION_SAFE_VALUE): Define. · e23f3619
      2018-08-03  Sandra Loosemore  <sandra@codesourcery.com>
      
      	gcc/
      	* config/nios2/nios2.c (TARGET_HAVE_SPECULATION_SAFE_VALUE):
      	Define.
      
      From-SVN: r263301
      Sandra Loosemore committed
    • Remove nfs bogon · 5ae10dba
      From-SVN: r263300
      Jeff Law committed
    • sjlj.S: Adjust to use PIC vs normal code to avoid absolute relocation in a shared library. · f6a9dfd3
      	* config/sh/sjlj.S: Adjust to use PIC vs normal code to avoid
      	absolute relocation in a shared library.
      
      From-SVN: r263299
      Sergei Trofimovich committed
    • Add fix-it hint for missing return statement in assignment operators (PR c++/85523) · bc31a87a
      gcc/cp/ChangeLog:
      
      	PR c++/85523
      	* decl.c: Include "gcc-rich-location.h".
      	(add_return_star_this_fixit): New function.
      	(finish_function): When warning about missing return statements in
      	functions returning non-void, add a "return *this;" fix-it hint for
      	assignment operators.
      
      gcc/testsuite/ChangeLog:
      
      	PR c++/85523
      	* g++.dg/pr85523.C: New test.
      
      
      Co-Authored-By: Jonathan Wakely <jwakely@redhat.com>
      
      From-SVN: r263298
      David Malcolm committed
    • re PR target/86795 (mn10300 port needs updating for CVE-2017-5753) · 2e2bd24b
      	PR target/86795
      	* config/mn10300/mn10300.c (TARGET_HAVE_SPECULATION_SAFE_VALUE):
      	Define to speculation_safe_value_not_needed.
      
      From-SVN: r263296
      Jeff Law committed
    • docs: fix stray duplicated words · c64f2af3
      gcc/ChangeLog:
      	* doc/gcov.texi (-x): Remove duplicate "to".
      	* doc/invoke.texi (-Wnoexcept-type): Remove duplicate "calls".
      	(-Wif-not-aligned): Remove duplicate "is".
      	(-flto): Remove duplicate "the".
      	(MicroBlaze Options): In examples of "-mcpu=cpu-type", remove
      	duplicate "v5.00.b".
      	(MSP430 Options): Remove duplicate "and" from the description
      	of "-mgprel-sec=regexp".
      	(x86 Options): Remove duplicate copies of "vmldLog102" and
      	vmlsLog104 from description of "-mveclibabi=type".
      
      From-SVN: r263295
      David Malcolm committed
    • Avoid infinite loop with duplicate anonymous union fields (PR c/86690). · e5e7e50d
      If a struct contains an anonymous union and both have a field with the
      same name, detect_field_duplicates_hash() will replace one of them
      with NULL.  If compilation doesn't stop immediately, it may later call
      lookup_field() on the union, which falsely assumes the union's
      LANG_SPECIFIC array is sorted, and may loop indefinitely because of
      this.
      
      2018-08-03  Bogdan Harjoc  <harjoc@gmail.com>
      
      	PR c/86690
      gcc/c:
      	* c-typeck.c (lookup_field): Do not use TYPE_LANG_SPECIFIC after
      	errors.
      
      gcc/testsuite:
      	* gcc.dg/union-duplicate-field.c: New test.
      
      From-SVN: r263294
      Bogdan Harjoc committed
    • re PR c++/86706 (ICE in build_base_path, at cp/class.c:294) · d198fc5a
      	PR c++/86706
      	* class.c (build_base_path): Use currently_open_class.
      
      	* g++.dg/template/pr86706.C: New test.
      
      From-SVN: r263293
      Jason Merrill committed
    • ChangeLog: Move entry ... · 0b0c7dc6
      	* ChangeLog: Move entry ...
      	* cp/ChangeLog: ... here.
      
      From-SVN: r263292
      Uros Bizjak committed
    • [Ada] Partially revert "Makefile patches from initial RISC-V cross/native build." · 1ae45251
      This partially reverts r262482, at it broke canadian builds.
      
      2018-08-03  Pierre-Marie de Rodat  <derodat@adacore.com>
      
      gcc/ada/
      
      	Reverts
      	2018-07-06  Jim Wilson  <jimw@sifive.com>
      
      	* Make-generated.in (treeprs.ads): Use $(GNATMAKE) instead of gnatmake.
      	(einfo.h, sinfo.h, stamp-snames, stamp-nmake): Likewise.
      	* gcc-interface/Makefile.in (xoscons): Likewise.
      
      From-SVN: r263291
      Pierre-Marie de Rodat committed
    • Handle SLP of call pattern statements · 0246112a
      We couldn't vectorise:
      
        for (int j = 0; j < n; ++j)
          {
            for (int i = 0; i < 16; ++i)
      	a[i] = (b[i] + c[i]) >> 1;
            a += step;
            b += step;
            c += step;
          }
      
      at -O3 because cunrolli unrolled the inner loop and SLP couldn't handle
      AVG_FLOOR patterns (see also PR86504).  The problem was some overly
      strict checking of pattern statements compared to normal statements
      in vect_get_and_check_slp_defs:
      
                switch (gimple_code (def_stmt))
                  {
                  case GIMPLE_PHI:
                  case GIMPLE_ASSIGN:
      	      break;
      
      	    default:
      	      if (dump_enabled_p ())
      		dump_printf_loc (MSG_MISSED_OPTIMIZATION, vect_location,
      				 "unsupported defining stmt:\n");
      	      return -1;
                  }
      
      The easy fix would have been to add GIMPLE_CALL to the switch,
      but I don't think the switch is doing anything useful.  We only create
      pattern statements that the rest of the vectoriser can handle, and the
      other checks in this function and elsewhere check whether SLP is possible.
      
      I'm also not sure why:
      
                if (!first && !oprnd_info->first_pattern
      	      /* Allow different pattern state for the defs of the
      		 first stmt in reduction chains.  */
      	      && (oprnd_info->first_dt != vect_reduction_def
      
      is necessary.  All that should matter is that the statements in the
      node are "similar enough".  It turned out to be quite hard to find a
      convincing example that used a mixture of pattern and non-pattern
      statements, so bb-slp-pow-1.c is the best I could come up with.
      But it does show that the combination of "xi * xi" statements and
      "pow (xj, 2) -> xj * xj" patterns are handled correctly.
      
      The patch therefore just removes the whole if block.
      
      The loop also needed commutative swapping to be extended to at least
      AVG_FLOOR.
      
      This gives +3.9% on 525.x264_r at -O3.
      
      2018-08-03  Richard Sandiford  <richard.sandiford@arm.com>
      
      gcc/
      	* internal-fn.h (first_commutative_argument): Declare.
      	* internal-fn.c (first_commutative_argument): New function.
      	* tree-vect-slp.c (vect_get_and_check_slp_defs): Remove extra
      	restrictions for pattern statements.  Use first_commutative_argument
      	to look for commutative operands in calls to internal functions.
      
      gcc/testsuite/
      	* gcc.dg/vect/bb-slp-over-widen-1.c: Expect AVG_FLOOR to be used
      	on vect_avg_qi targets.
      	* gcc.dg/vect/bb-slp-over-widen-2.c: Likewise.
      	* gcc.dg/vect/bb-slp-pow-1.c: New test.
      	* gcc.dg/vect/vect-avg-15.c: Likewise.
      
      From-SVN: r263290
      Richard Sandiford committed
    • Add workaround for non-unique errno values on AIX · d7487e2a
      	* src/c++11/system_error.cc
      	(system_error_category::default_error_condition): Add workaround for
      	ENOTEMPTY and EEXIST having the same value on AIX.
      	* testsuite/19_diagnostics/error_category/system_category.cc: Add
      	extra testcases for EDOM, EILSEQ, ERANGE, EEXIST and ENOTEMPTY.
      
      From-SVN: r263289
      Jonathan Wakely committed
    • Makefile.in (wide-int-range.o): New. · c9f8fca6
      	* Makefile.in (wide-int-range.o): New.
      	* tree-vrp.c: Move all the wide_int_* functions to...
      	* wide-int-range.cc: ...here.
      	* tree-vrp.h: Move all the wide_int_* prototypes to...
      	* wide-int-range.h: ...here.
      
      From-SVN: r263288
      Aldy Hernandez committed