1. 12 Oct, 2017 26 commits
    • Clobbers and Scratch Registers · 806aa9b2
      	* doc/extend.texi (Extended Asm <Clobbers>): Rename to
      	"Clobbers and Scratch Registers".  Add paragraph on
      	alternative to clobbers for scratch registers and OpenBLAS
      	example.
      
      From-SVN: r253701
      Alan Modra committed
    • Asm memory constraints · 7ff5eac3
      	* doc/extend.texi (Clobbers): Correct vax example.  Delete old
      	example of a memory input for a string of known length.  Move
      	commentary out of table.  Add a number of new examples
      	covering array memory inputs.
      testsuite/
      	* gcc.target/i386/asm-mem.c: New test.
      
      From-SVN: r253700
      Alan Modra committed
    • re PR tree-optimization/82493 (UBSAN in gcc/sbitmap.c:368:28: runtime error:… · 0af377c1
      re PR tree-optimization/82493 (UBSAN in gcc/sbitmap.c:368:28: runtime error: shift exponent 64 is too large for 64-bit type 'long unsigned int')
      
      	PR tree-optimization/82493
      	* sbitmap.c (bitmap_bit_in_range_p): Fix the implementation.
      	(test_range_functions): New function.
      	(sbitmap_c_tests): Likewise.
      	* selftest-run-tests.c (selftest::run_tests): Run new tests.
      	* selftest.h (sbitmap_c_tests): New function.
      
      	* tree-ssa-dse.c (live_bytes_read): Fix thinko.
      
      From-SVN: r253699
      Martin Liska committed
    • Fix spacing issue. · c64959bd
      From-SVN: r253696
      Michael Meissner committed
    • re PR target/82498 (Missed optimization for x86 rotate instruction) · 912a7ec3
      	PR target/82498
      	* config/i386/i386.md (*ashl<mode>3_mask_1,
      	*<shift_insn><mode>3_mask_1, *<rotate_insn><mode>3_mask_1,
      	*<btsc><mode>_mask_1, *btr<mode>_mask_1): New define_insn_and_split
      	patterns.
      
      	* gcc.target/i386/pr82498-1.c: New test.
      	* gcc.target/i386/pr82498-2.c: New test.
      
      From-SVN: r253695
      Jakub Jelinek committed
    • compiler: fix import of indirectly imported type alias · 1baafc8d
          
          We were looking for the " = " before the optional package name that
          appears for an indirect reference, but the exporter was putting it
          after.
          
          Test is https://golang.org/cl/70290.
          
          Reviewed-on: https://go-review.googlesource.com/70330
      
      From-SVN: r253694
      Ian Lance Taylor committed
    • [C++ PATCH] cp_expr tweak and delete unused enumerations · d89dac36
      https://gcc.gnu.org/ml/gcc-patches/2017-10/msg00784.html
      	* cp-tree.h (cp_expr): Add const operator * and operator->
      	accessors.
      	(cp_tree_node_structure_enum): Delete TS_CP_BINDING,
      	TS_CP_WRAPPER, LAST_TS_CP_ENUM.
      
      From-SVN: r253693
      Nathan Sidwell committed
    • profile-count.c (safe_scale_64bit): Fix GCC4.x path. · 83d502cf
      
      	* profile-count.c (safe_scale_64bit): Fix GCC4.x path.
      	(profile_probability): Set max_probability
      	to (uint32_t) 1 << (n_bits - 2) and update accessors to avoid overlfows
      	in temporaries.
      	* profile-count.c (profile_probability::differs_from_p): Do not
      	rely on max_probaiblity == 10000
      
      	* gcc.dg/predict-13.c: Update template for probaility change.
      	* gcc.dg/predict-8.c: Likewise.
      
      From-SVN: r253692
      Jan Hubicka committed
    • tree-ssa-dse.c (valid_ao_ref_for_dse): Reject ao_refs with negative offsets. · 8b48488f
      	* tree-ssa-dse.c (valid_ao_ref_for_dse): Reject ao_refs with
      	negative offsets.
      
      From-SVN: r253691
      Jeff Law committed
    • C/C++: add fix-it hints for various missing symbols · 62e1c678
      The patch improves our C/C++ frontends' handling of missing
      symbols, by making c_parser_require and cp_parser_require use
      "better" locations for the diagnostic, and insert fix-it hints,
      under certain circumstances (see the comments in the patch for
      full details).
      
      For example, for this code with a missing semicolon:
      
        $ cat test.c
        int missing_semicolon (void)
        {
          return 42
        }
      
        trunk currently emits:
      
        test.c:4:1: error: expected ';' before '}' token
         }
         ^
      
      This patch adds a fix-it hint for the missing semicolon, and puts
      the error at the location of the missing semicolon, printing the
      followup token as a secondary location:
      
        test.c:3:12: error: expected ';' before '}' token
           return 42
                    ^
                    ;
         }
         ~
      
      More examples can be seen in the test cases.
      
      gcc/c-family/ChangeLog:
      	* c-common.c (enum missing_token_insertion_kind): New enum.
      	(get_missing_token_insertion_kind): New function.
      	(maybe_suggest_missing_token_insertion): New function.
      	* c-common.h (maybe_suggest_missing_token_insertion): New decl.
      
      gcc/c/ChangeLog:
      	* c-parser.c (c_parser_require): Add "type_is_unique" param and
      	use it to guard calls to maybe_suggest_missing_token_insertion.
      	(c_parser_parms_list_declarator): Override default value of new
      	"type_is_unique" param to c_parser_require.
      	(c_parser_asm_statement): Likewise.
      	* c-parser.h (c_parser_require): Add "type_is_unique" param,
      	defaulting to true.
      
      gcc/cp/ChangeLog:
      	* parser.c (get_required_cpp_ttype): New function.
      	(cp_parser_error_1): Call it, using the result to call
      	maybe_suggest_missing_token_insertion.
      
      gcc/testsuite/ChangeLog:
      	* c-c++-common/cilk-plus/AN/parser_errors.c: Update expected
      	output to reflect changes to reported locations of missing
      	symbols.
      	* c-c++-common/cilk-plus/AN/parser_errors2.c: Likewise.
      	* c-c++-common/cilk-plus/AN/parser_errors3.c: Likewise.
      	* c-c++-common/cilk-plus/AN/pr61191.c: Likewise.
      	* c-c++-common/gomp/pr63326.c: Likewise.
      	* c-c++-common/missing-close-symbol.c: Likewise, also update for
      	new fix-it hints.
      	* c-c++-common/missing-symbol.c: Likewise, also add test coverage
      	for missing colon in ternary operator.
      	* g++.dg/cpp1y/digit-sep-neg.C: Likewise.
      	* g++.dg/cpp1y/pr65202.C: Likewise.
      	* g++.dg/missing-symbol-2.C: New test case.
      	* g++.dg/other/do1.C: Update expected output to reflect
      	changes to reported locations of missing symbols.
      	* g++.dg/parse/error11.C: Likewise.
      	* g++.dg/template/error11.C: Likewise.
      	* gcc.dg/missing-symbol-2.c: New test case.
      	* gcc.dg/missing-symbol-3.c: New test case.
      	* gcc.dg/noncompile/940112-1.c: Update expected output to reflect
      	changes to reported locations of missing symbols.
      	* gcc.dg/noncompile/971104-1.c: Likewise.
      	* obj-c++.dg/exceptions-6.mm: Likewise.
      	* obj-c++.dg/pr48187.mm: Likewise.
      	* objc.dg/exceptions-6.m: Likewise.
      
      From-SVN: r253690
      David Malcolm committed
    • PR c/82301 - Updated test case g++.dg/ext/attr-ifunc-1.C (and others) in r253041… · 7a866e7e
      PR c/82301 - Updated test case g++.dg/ext/attr-ifunc-1.C (and others) in r253041 segfault on powerpc64
      
      PR c/82301 - Updated test case g++.dg/ext/attr-ifunc-1.C (and others) in r253041 segfault on powerpc64
      PR c/82435 - new __attribute__((alias)) warning gets in the way
      
      gcc/ChangeLog:
      
      	PR other/82301
      	PR c/82435
      	* cgraphunit.c (maybe_diag_incompatible_alias): New function.
      	(handle_alias_pairs): Call it.
      	* common.opt (-Wattribute-alias): New option.
      	* doc/extend.texi (ifunc attribute): Discuss C++ specifics.
      	* doc/invoke.texi (-Wattribute-alias): Document.
      
      gcc/testsuite/ChangeLog:
      
      	PR other/82301
      	PR c/82435
      	* g++.dg/ext/attr-ifunc-1.C: Update.
      	* g++.dg/ext/attr-ifunc-2.C: Same.
      	* g++.dg/ext/attr-ifunc-3.C: Same.
      	* g++.dg/ext/attr-ifunc-4.C: Same.
      	* g++.dg/ext/attr-ifunc-5.C: Same.
      	* g++.dg/ext/attr-ifunc-6.C: New test.
      	* g++.old-deja/g++.abi/vtable2.C: Update.
      	* gcc.dg/attr-ifunc-6.c: New test.
      	* gcc.dg/attr-ifunc-7.c: New test.
      	* gcc.dg/pr81854.c: Update.
      	* lib/target-supports.exp: Update.
      
      From-SVN: r253688
      Martin Sebor committed
    • C++: avoid partial duplicate implementation of cp_parser_error · e95c9129
      In r251026 (aka 3fe34694f0990d1d649711ede0326497f8a849dc,
      "C/C++: show pertinent open token when missing a close token")
      I copied part of cp_parser_error into cp_parser_required_error,
      leading to duplication of code.
      
      This patch eliminates this duplication by merging the two copies of the
      code into a new cp_parser_error_1 subroutine.
      
      Doing so removes an indentation level, making the patch appear to have
      more churn than it really does.
      
      The patch also undoes the change to g++.dg/parse/pragma2.C, as the
      old behavior is restored.
      
      From-SVN: r253686
      David Malcolm committed
    • revert: re PR sanitizer/82353 (runtime ubsan crash) · 2c79bfcf
      2017-10-12  Vladimir Makarov  <vmakarov@redhat.com>
      
      	Revert
      	2017-10-11  Vladimir Makarov  <vmakarov@redhat.com>
      	PR sanitizer/82353
      	* lra.c (collect_non_operand_hard_regs): Don't ignore operator
      	locations.
      	* lra-lives.c (bb_killed_pseudos, bb_gen_pseudos): Move up.
      	(make_hard_regno_born, make_hard_regno_dead): Update
      	bb_killed_pseudos and bb_gen_pseudos.
      
      From-SVN: r253685
      Vladimir Makarov committed
    • * x86-tune-sched.c (ix86_adjust_cost): Fix Zen support. · 3edf8a98
      From-SVN: r253684
      Jan Hubicka committed
    • alpha.c (alpha_split_conditional_move): Use std::swap instead of manually swapping. · 7159f19c
      	* config/alpha/alpha.c (alpha_split_conditional_move):
      	Use std::swap instead of manually swapping.
      	(alpha_stdarg_optimize_hook): Ditto.
      	(alpha_canonicalize_comparison): Ditto.
      
      From-SVN: r253681
      Uros Bizjak committed
    • tree-loop-distribution.c (struct builtin_info): New struct. · 939cf90f
      	* tree-loop-distribution.c (struct builtin_info): New struct.
      	(struct partition): Refactor fields into struct builtin_info.
      	(partition_free): Free struct builtin_info.
      	(build_size_arg_loc, build_addr_arg_loc): Delete.
      	(generate_memset_builtin, generate_memcpy_builtin): Get memory range
      	information from struct builtin_info.
      	(find_single_drs): New function refactored from classify_partition.
      	Also moved builtin validity checks to this function.
      	(compute_access_range, alloc_builtin): New functions.
      	(classify_builtin_st, classify_builtin_ldst): New functions.
      	(classify_partition): Refactor code into functions find_single_drs,
      	classify_builtin_st and classify_builtin_ldst.
      	(distribute_loop): Don't do runtime alias check when distributing
      	loop nest.
      	(find_seed_stmts_for_distribution): New function.
      	(pass_loop_distribution::execute): Refactor code finding seed
      	stmts into above function.  Support distribution for the innermost
      	two-level loop nest.  Adjust dump information.
      
      	gcc/testsuite
      	* gcc.dg/tree-ssa/ldist-28.c: New test.
      	* gcc.dg/tree-ssa/ldist-29.c: New test.
      	* gcc.dg/tree-ssa/ldist-30.c: New test.
      	* gcc.dg/tree-ssa/ldist-31.c: New test.
      
      From-SVN: r253680
      Bin Cheng committed
    • tree-loop-distribution.c: Adjust the general comment. · 163aa51b
      	* tree-loop-distribution.c: Adjust the general comment.
      	(NUM_PARTITION_THRESHOLD): New macro.
      	(ssa_name_has_uses_outside_loop_p): Support loop nest distribution.
      	(classify_partition): Skip builtin pattern of loop nest's inner loop.
      	(merge_dep_scc_partitions): New parameter ignore_alias_p and use it
      	in call to build_partition_graph.
      	(finalize_partitions): New parameter.  Make loop distribution more
      	conservative by fusing more partitions.
      	(distribute_loop): Don't do runtime alias check in case of loop nest
      	distribution.
      	(find_seed_stmts_for_distribution): New function.
      	(prepare_perfect_loop_nest): New function.
      	(pass_loop_distribution::execute): Refactor code finding seed stmts
      	and loop nest into above functions.  Support loop nest distribution.
      	Adjust dump information accordingly.
      
      	gcc/testsuite
      	* gcc.dg/tree-ssa/ldist-7.c: Adjust test string.
      	* gcc.dg/tree-ssa/ldist-16.c: Ditto.
      	* gcc.dg/tree-ssa/ldist-25.c: Ditto.
      	* gcc.dg/tree-ssa/ldist-33.c: New test.
      
      From-SVN: r253679
      Bin Cheng committed
    • tree-loop-distribution.c (break_alias_scc_partitions): Add comment and set… · 6dc29d3a
      tree-loop-distribution.c (break_alias_scc_partitions): Add comment and set PTYPE_SEQUENTIAL for merged partition.
      
      	* tree-loop-distribution.c (break_alias_scc_partitions): Add comment
      	and set PTYPE_SEQUENTIAL for merged partition.
      
      From-SVN: r253678
      Bin Cheng committed
    • re PR tree-optimization/69728 (internal compiler error: in… · f0c216e1
      re PR tree-optimization/69728 (internal compiler error: in outer_projection_mupa, at graphite-sese-to-poly.c:1175)
      
      2017-10-12  Richard Biener  <rguenther@suse.de>
      
      	PR tree-optimization/69728
      	Revert
      	2017-09-19  Richard Biener  <rguenther@suse.de>
      
      	PR tree-optimization/69728
      	* graphite-sese-to-poly.c (schedule_error): New global.
      	(add_loop_schedule): Handle empty domain by failing the
      	schedule.
      	(build_original_schedule): Handle schedule_error.
      
      	* graphite-sese-to-poly.c (add_loop_schedule): Handle empty
      	domain by returning an unchanged schedule.
      
      	* gcc.dg/graphite/pr69728.c: Adjust to reflect we can handle
      	the loop now.  Remove unrelated undefined behavior.
      
      From-SVN: r253677
      Richard Biener committed
    • genrecog.c (validate_pattern): For VEC_SELECT verify that CONST_INT selectors… · b989ffb2
      genrecog.c (validate_pattern): For VEC_SELECT verify that CONST_INT selectors are 0 to GET_MODE_NUNITS (imode) - 1.
      
      	* genrecog.c (validate_pattern): For VEC_SELECT verify that
      	CONST_INT selectors are 0 to GET_MODE_NUNITS (imode) - 1.
      
      From-SVN: r253676
      Jakub Jelinek committed
    • Makefile.in (TAGS): Merge all the *.def files into one pattern. · 712716d2
      	* Makefile.in (TAGS): Merge all the *.def files into one pattern.
      	Handle params.def.
      
      From-SVN: r253674
      Aldy Hernandez committed
    • re PR c++/82159 (ICE: in assign_temp, at function.c:961) · 6089393b
      	PR c++/82159
      	* expr.c (store_field): Don't optimize away bitsize == 0 store
      	from CALL_EXPR with addressable return type.
      
      	* g++.dg/opt/pr82159-2.C: New test.
      
      From-SVN: r253673
      Jakub Jelinek committed
    • re PR sanitizer/82353 (runtime ubsan crash) · 281ff779
      	PR target/82353
      	* gcc.target/i386/i386.exp (tests): Revert the '.C' extension change.
      	* gcc.target/i386/pr82353.C: Moved to ...
      	* g++.dg/ubsan/pr82353.C: ... here.  Restrict to i?86/x86_64 && lp64.
      
      From-SVN: r253672
      Jakub Jelinek committed
    • rs6000: Remove TARGET_ISEL64 · 79f421e1
      TARGET_ISEL64 just means TARGET_ISEL && TARGET_POWERPC64.  Since
      everywhere it is used uses :GPR already, we can just as well use
      TARGET_ISEL always.
      
      
      	* config/rs6000/rs6000.h (TARGET_ISEL64): Delete.
      	* config/rs6000/rs6000.md (sel): Delete mode attribute.
      	(mov<mode>cc, isel_signed_<mode>, isel_unsigned_<mode>,
      	*isel_reversed_signed_<mode>, *isel_reversed_unsigned_<mode>): Use
      	TARGET_ISEL instead of TARGET_ISEL<sel>.
      
      From-SVN: r253671
      Segher Boessenkool committed
    • Daily bump. · 7c754ceb
      From-SVN: r253670
      GCC Administrator committed
  2. 11 Oct, 2017 14 commits