1. 23 Dec, 2015 7 commits
    • alias.c (compare_base_decls): Simplify in-symtab check. · 7ec4f343
      	gcc/
      	* alias.c (compare_base_decls): Simplify in-symtab check.
      	* cgraph.h (decl_in_symtab_p): Check DECL_IN_CONSTANT_POOL.
      
      	testsuite/
      	* gcc.dg/alias-15.c: New.
      
      From-SVN: r231928
      Nathan Sidwell committed
    • Fix broken handling of LABEL_REF in genrecog + genpreds. · 986e29bc
      gcc/ChangeLog
      
      	* config/s390/predicates.md ("larl_operand"): Remove now superfluous
      	const_int and const_double.
      	* genrecog.c (safe_predicate_mode): Return false for VOIDmode
      	LABEL_REFs even if the predicate does not handle const_int,
      	const_double or const_wide_int.
      	* genpreds.c (add_mode_tests): Treat LABEL_REF like CONST_INT.
      
      From-SVN: r231927
      Dominik Vogt committed
    • Merge OMP_CLAUSE_USE_DEVICE into OMP_CLAUSE_USE_DEVICE_PTR · c7b48c8a
      	gcc/c/
      	* c-parser.c (c_parser_oacc_clause_use_device): Merge function
      	into...
      	(c_parser_omp_clause_use_device_ptr): ... this function.  Adjust
      	all users.
      	gcc/
      	* tree-core.h (enum omp_clause_code): Merge OMP_CLAUSE_USE_DEVICE
      	into OMP_CLAUSE_USE_DEVICE_PTR.  Adjust all users.
      
      From-SVN: r231926
      Thomas Schwinge committed
    • Don't run OpenACC C++ test twice · e013d90c
      	gcc/testsuite/
      	* g++.dg/dg.exp (tests): Prune "goacc/*" and "goacc-gomp/*" files.
      
      From-SVN: r231925
      Thomas Schwinge committed
    • iterators.md (VMAXMINFNM): New int iterator. · 0a18c19f
      2015-12-23  David Sherwood  <david.sherwood@arm.com>
      
          gcc/
              * config/arm/iterators.md (VMAXMINFNM): New int iterator.
              (fmaxmin): New int attribute.
              (fmaxmin_op): Likewise.
              * config/arm/unspecs.md (UNSPEC_VMAXNM): New unspec.
              (UNSPEC_VMINNM): Likewise.
              * config/arm/neon.md (fmaxmin): New pattern.
              * config/arm/vfp.md (fmaxmin): Likewise.
          gcc/testsuite
              * gcc.target/arm/fmaxmin.x: New file used by tests below.
              * gcc.target/arm/fmaxmin.c: New test.
              * gcc.target/arm/vect-fmaxmin.c: Likewise.
      
      From-SVN: r231924
      David Sherwood committed
    • [PATCH] Allow indirect call via GOT for 64-bit Pmode x32 · fa87d16d
      From: H.J. Lu  <hongjiu.lu@intel.com>
      
      Since Pmode is 64-bit with -maddress-mode=long for x32, indirect call
      via GOT slot doesn't need zero_extend.  This patch enables indirect call
      via GOT for x32 with 64-bit Pmode.
      
      gcc/
      
      	PR target/66232
      	* config/i386/constraints.md (Bs): Allow GOT slot for x32 with
      	64-bit Pmode.
      	(Bw): Likewise.
      	(Bz): Likewise.
      	* config/i386/predicates.md (call_insn_operand): Likewise.
      	(sibcall_insn_operand): Likewise.
      
      gcc/testsuite/
      
      	PR target/66232
      	* gcc.target/i386/pr66232-10.c: New test.
      	* gcc.target/i386/pr66232-11.c: Likewise.
      	* gcc.target/i386/pr66232-12.c: Likewise.
      	* gcc.target/i386/pr66232-13.c: Likewise.
      
      From-SVN: r231923
      H.J. Lu committed
    • Daily bump. · fc9ca1a0
      From-SVN: r231922
      GCC Administrator committed
  2. 22 Dec, 2015 23 commits
    • PR c/68473: sanitize source range-printing within certain macro expansions · 070856cc
      gcc/ChangeLog:
      	PR c/68473
      	* diagnostic-show-locus.c (layout::layout): Make loc_range const.
      	Sanitize the layout_range against ranges that finish before they
      	start.
      
      gcc/testsuite/ChangeLog:
      	PR c/68473
      	* gcc.dg/plugin/diagnostic-test-expressions-1.c (fminl): New decl.
      	(TEST_EQ): New macro.
      	(test_macro): New function.
      	* gcc.target/i386/pr68473-1.c: New test case.
      
      From-SVN: r231919
      David Malcolm committed
    • libcpp: Avoid unnecessary ad-hoc uses for large source files · 329590d7
      libcpp/ChangeLog:
      	* line-map.c (get_combined_adhoc_loc): Remove condition
      	on locus < RESERVED_LOCATION_COUNT when considering
      	whether a caret == start == finish location can be
      	simply stored as the caret location.
      
      From-SVN: r231918
      David Malcolm committed
    • [PATCH] Avoid unnecessary block copying in path splitting · 9edb6bb8
      	* gimple-ssa-split-paths.c (split_paths): Avoid unnecessary block
      	copying.
      
      From-SVN: r231915
      Jeff Law committed
    • re PR c++/66921 (failure to determine size of static constexpr array that is… · 56343945
      re PR c++/66921 (failure to determine size of static constexpr array that is nested within a templated class)
      
      	PR c++/66921
      	* decl.c (cp_complete_array_type): Allow an initializer that
      	already has array type.
      
      From-SVN: r231914
      Jason Merrill committed
    • re PR c++/67257 (Internal compiler error in retrieve_specialization) · dfc9c481
      	PR c++/67257
      	* parser.c (cp_parser_single_declaration): Reject a class template
      	that also declares a variable.
      
      From-SVN: r231913
      Jason Merrill committed
    • re PR c++/67339 (Segfault when parsing a typename involving a template-alias) · d2889b14
      	PR c++/67339
      	* parser.c (cp_parser_elaborated_type_specifier): Use CLASS_TYPE_P
      	rather than check for RECORD_TYPE.
      
      From-SVN: r231912
      Jason Merrill committed
    • re PR c++/67376 (Comparison with pointer to past-the-end of array fails inside constant expression) · d6dd2c8e
      	PR c++/67376
      	* fold-const.c (size_low_cst): Removed.
      	(fold_comparison): For POINTER_PLUS_EXPR where base is ADDR_EXPR
      	call get_inner_reference and handle INDIRECT_REF base of it.  Use
      	offset_int for computation of the bitpos.
      	(fold_binary_loc) <case EQ_EXPR, NE_EXPR>: Formatting
      	fixes for X +- Y CMP X and C - X CMP X folding.  Add X CMP X +- Y
      	and X CMP C - X folding.
      
      	* g++.dg/cpp0x/constexpr-67376.C: New test.
      
      From-SVN: r231909
      Jakub Jelinek committed
    • Give EH_ELSE access to __builtin_eh_pointer · b5c4bc31
      The must-not-throw wrapper for protect_cleanup_actions gets in
      the way of being able to access __builtin_eh_pointer without
      confusion as the identit of the exception to which we are
      referring (b_eh_p has no usable argument up to this point).
      
      Since EH_ELSE never comes from user derived code, let's drop
      the c++ specific wrapping.
      
      	* tree-eh.c (honor_protect_cleanup_actions): Do not wrap
      	eh_else in a must-not-throw; set ehp_region for it too.
      
      From-SVN: r231908
      Richard Henderson committed
    • re PR ipa/67811 ([TM] ICE with try-block in transaction) · 7c11b0fe
      PR ipa/67811
      
      	* gimple.h (struct gtransaction): Add label_norm, label_uninst;
      	replace label with label_over.
      	(gimple_build_transaction): Remove label parameter.
      	(gimple_transaction_label_norm): New.
      	(gimple_transaction_label_uninst): New.
      	(gimple_transaction_label_over): Rename from gimple_transaction_label.
      	(gimple_transaction_label_norm_ptr): New.
      	(gimple_transaction_label_uninst_ptr): New.
      	(gimple_transaction_label_over_ptr): Rename from
      	gimple_transaction_label_ptr.
      	(gimple_transaction_set_label_norm): New.
      	(gimple_transaction_set_label_uninst): New.
      	(gimple_transaction_set_label_over): Rename from
      	gimple_transaction_set_label.
      	* gimple-pretty-print.c (dump_gimple_transaction): Update.
      	* gimple-streamer-in.c (input_gimple_stmt) [GIMPLE_TRANSACTION]: Same.
      	* gimple-streamer-out.c (output_gimple_stmt) [GIMPLE_TRANSACTION]: Same.
      	* gimple-walk.c (walk_gimple_op) [GIMPLE_TRANSACTION]: Same.
      	* tree-cfg.c (make_edges_bb) [GIMPLE_TRANSACTION]: Same.
      	(cleanup_dead_labels) [GIMPLE_TRANSACTION]: Same.
      	(verify_gimple_transaction): Same.
      	(gimple_redirect_edge_and_branch) [GIMPLE_TRANSACTION]: Same.
      	* tree-inline.c (remap_gimple_stmt) [GIMPLE_TRANSACTION]: Same.
      	* gimple.c (gimple_build_transaction): Remove label parameter;
      	initialize all three label memebers.
      	* gimplify.c (gimplify_transaction): Update call
      	to gimple_build_transaction.
      	* trans-mem.c (make_tm_uninst): New.
      	(lower_transaction): Create uninstrumented code path here...
      	(ipa_tm_scan_calls_transaction): ... not here.
      	(ipa_uninstrument_transaction): Remove.
      
      testsuite/
      	* g++.dg/tm/noexcept-1.C: Update expected must_not_throw count.
      	* g++.dg/tm/noexcept-4.C: Likewise.
      	* g++.dg/tm/noexcept-5.C: Likewise.
      	* g++.dg/tm/pr67811.C: New.
      
      From-SVN: r231907
      Richard Henderson committed
    • Fix previous ChangeLog entry · ebe9921f
      From-SVN: r231906
      Peter Bergner committed
    • re PR target/68772 (Many -gstabs tests FAIL with Xcode 7 as) · fa17b3db
      gcc/
      	PR target/68772
      	* config/rs6000/rs6000.h (ASM_CPU_SPEC): For -mcpu=powerpc64le,
      	pass %(asm_cpu_power8)/-mpwr8.
      	* config/rs6000/aix53.h: Likewise.
      	* config/rs6000/aix61.h: Likewise.
      	* config/rs6000/aix71.h: Likewise.
      
      gcc/testsuite/
      	PR target/68772
      	* gcc.target/powerpc/pr68872.c: New test.
      
      From-SVN: r231905
      Peter Bergner committed
    • Fix read of uninitialized value in make_pack_expansion() · 6be02822
      gcc/cp/ChangeLog:
      
      	* pt.c (make_pack_expansion): Make sure to initialize
      	ppd.type_pack_expansion_p.
      
      From-SVN: r231904
      Patrick Palka committed
    • [PATCH] Use call-clobbered register for sibcall via GOT · af9345d7
      From: H.J. Lu  <hongjiu.lu@intel.com>
      
      Since sibcall never returns, we can only use call-clobbered register as
      GOT base.  Otherwise, callee-saved register used as GOT base won't be
      properly restored.  sibcall_memory_operand is changed to allow 32-bit
      GOT slot only with pseudo register as GOT base for RTL expansion.  2
      new patterns, *sibcall_GOT_32 and *sibcall_value_GOT_32, are added to
      expose GOT base register to register allocator so that call-clobbered
      register will be used for GOT base.
      
      gcc/
      
      	PR target/68937
      	* config/i386/i386.c (ix86_function_ok_for_sibcall): Count
      	call to global function via GOT slot as indirect call.
      	* config/i386/i386.md (*sibcall_GOT_32): New pattern.
      	(*sibcall_value_GOT_32): Likewise.
      	* config/i386/predicates.md (sibcall_memory_operand): Rewrite.
      	Allow 32-bit GOT slot only with pseudo register as GOT base.
      	(GOT32_symbol_operand): New predicate.
      
      gcc/testsuite/
      
      	PR target/68937
      	* gcc.target/i386/pr68937-1.c: New test.
      	* gcc.target/i386/pr68937-2.c: Likewise.
      	* gcc.target/i386/pr68937-3.c: Likewise.
      	* gcc.target/i386/pr68937-4.c: Likewise.
      	* gcc.target/i386/pr68937-5.c: Likewise.
      	* gcc.target/i386/pr68937-6.c: Likewise.
      
      From-SVN: r231903
      H.J. Lu committed
    • re PR c/69002 (C front end should warn about undefined access to atomic structure or union) · fda5652f
      	PR c/69002
      	* c-typeck.c (build_component_ref): Warn when acessing elements of
      	atomic structures or unions.
      
      	* gcc.dg/c11-atomic-1.c: Add dg-warnings.
      	* gcc.dg/c11-atomic-4.c: New test.
      
      From-SVN: r231902
      Marek Polacek committed
    • This series of patches fix PR61441. · 5a00b0aa
      This series of patches fix PR61441. This patch avoids various transformations
      with signaling NaN operands when flag_signaling_nans is on, to avoid folding
      which would lose exceptions.
      
      Bootstrapped & regression-tested on x86_64-linux-gnu.
      
      gcc/
      	* fold-const.c (const_binop): Convert sNaN to qNaN when
      	flag_signaling_nans is off.
      	(const_unop): Avoid the operation, other than NEGATE and
      	ABS, if flag_signaling_nans is on and the operand is an sNaN.
      	(fold_convert_const_real_from_real): Avoid the operation if
      	flag_signaling_nans is on and the operand is an sNaN.
      	(integer_valued_real_unary_p): Update comment stating it
      	returns false for sNaN values.
      	(integer_valued_real_binary_p, integer_valued_real_call_p): Same.
      	(integer_valued_real_single_p): Same.
      	(integer_valued_real_invalid_p, integer_valued_real_p): Same.
      	* fold-const-call.c (fold_const_pow): Avoid the operation
      	if flag_signaling_nans is on and the operand is an sNaN.
      	(fold_const_builtin_load_exponent) Same.
      	(fold_const_call_sss): Same for CASE_CFN_POWI.
      	* gimple-fold.c (gimple_assign_integer_valued_real_p): Same.
      	(gimple_call_integer_valued_real_p): Same.
      	(gimple_phi_integer_valued_real_p): Same.
      	(gimple_stmt_integer_valued_real_p): Same.
      	* simplify-rtx.c (simplify_const_unary_operation): Avoid the
      	operation if flag_signaling_nans is on and the operand is an sNaN.
      	(simplify_const_binary_operation): Same.
      	* tree-ssa-math-opts.c (gimple_expand_builtin_pow): Avoid the
      	operation if flag_signaling_nans is on and the operand is an sNaN.
      
      	* gcc.dg/pr61441.c: New testcase.
      
      From-SVN: r231901
      Sujoy Saraswati committed
    • Add inline to std::__invfwd · 9643ce88
      	PR libstdc++/59768
      	* include/std/functional (__invfwd): Add inline specifier.
      
      From-SVN: r231900
      Jonathan Wakely committed
    • [combine] Check WORD_REGISTER_OPERATIONS normally rather than through preprocessor · dda5c831
      	* combine.c (simplify_comparison): Convert preprocessor check of
      	WORD_REGISTER_OPERATIONS into runtime check.
      
      From-SVN: r231899
      Kyrylo Tkachov committed
    • * gcc.dg/torture/pr68264.c: Tweak for Solaris. · 18fccdb4
      From-SVN: r231898
      Eric Botcazou committed
    • re PR debug/60756 (var-tracking selects wrong registers) · f4fd20a2
      	PR debug/60756
      	* var-tracking.c (tracked_record_parameter_p): New predicate.
      	(track_expr_p): Invoke it.
      	(add_stores): Likewise.
      
      From-SVN: r231897
      Eric Botcazou committed
    • dbgcnt.def (dom_unreachable_edges): New debug counter. · 102a9b43
      	* dbgcnt.def (dom_unreachable_edges): New debug counter.
      	* tree-ssa-dom.c: Include dbgcnt.h
      	(dom_opt_dom_walker::before_dom_children): Handle the new counter.
      
      From-SVN: r231896
      Jeff Law committed
    • go-gcc.cc (class Bvariable): Remove Gcc_tree parent class. · 399f5feb
      	* go-gcc.cc (class Bvariable): Remove Gcc_tree parent class.  Add
      	t_ and orig_type_ fields.  Add new two parameter constructor.  Add
      	get_tree and get_decl methods.
      	(Gcc_backend::var_expression): Pass location to var get_tree.
      	(Gcc_backend::global_variable): Don't add VIEW_CONVERT_EXPR.  Use
      	two parameter constructor for Bvariable.
      	(Gcc_backend::global_variable_set_init): Don't remove
      	VIEW_CONVERT_EXPR.  Use var get_decl, not get_tree.
      	(Gcc_backend::write_global_definitions): Likewise.
      	(Gcc_backend::init_statement): Call var get_decl, not get_tree.
      	(Gcc_backend::block): Likewise.
      	(Gcc_backend::implicit_variable_set_init): Likewise.
      	(Gcc_backend::immutable_struct_set_init): Likewise.
      	(Gcc_backend::function_set_parameters): Likewise.
      
      From-SVN: r231894
      Ian Lance Taylor committed
    • Daily bump. · 18fb580c
      From-SVN: r231892
      GCC Administrator committed
    • go-gcc.cc (Gcc_backend::global_variable): If type is zero-sized, add a… · 8fd41e92
      go-gcc.cc (Gcc_backend::global_variable): If type is zero-sized, add a VIEW_CONVERT_EXPR to the tree.
      
      	* go-gcc.cc (Gcc_backend::global_variable): If type is zero-sized,
      	add a VIEW_CONVERT_EXPR to the tree.
      	(Gcc_backend::global_variable_set_init): Remove any
      	VIEW_CONVERT_EXPR.
      	(Gcc_backend::write_global_definitions): Likewise.
      
      From-SVN: r231888
      Ian Lance Taylor committed
  3. 21 Dec, 2015 10 commits
    • aarch64-option-extensions.def (LSE): Change FEAT_STRING to "atomics". · bf507c78
      2015-12-21  Andrew Pinski <apinski@cavium.com>
      
              * config/aarch64/aarch64-option-extensions.def (LSE): Change
              FEAT_STRING to "atomics".
      
      From-SVN: r231887
      Andrew Pinski committed
    • C and C++ FE: fix source ranges for binary ops · 745e411d
      gcc/c-family/ChangeLog:
      	* c-common.c (binary_op_error): Convert first param from
      	location_t to rich_location * and use it when emitting an error.
      	* c-common.h (binary_op_error): Convert first param from
      	location_t to rich_location *.
      
      gcc/c/ChangeLog:
      	* c-typeck.c: Include "gcc-rich-location.h".
      	(build_binary_op): In the two places that call binary_op_error,
      	create a gcc_rich_location and populate it with the location of
      	the binary op and its two operands.
      
      gcc/cp/ChangeLog:
      	* typeck.c (cp_build_binary_op): Update for change in signature
      	of build_binary_op.  Use error_at to replace an implicit use
      	of input_location with param "location" in "invalid operands"
      	error.
      	(cp_build_binary_op): Replace an error with an error_at, using
      	"location", rather than implicitly using input_location.
      
      gcc/testsuite/ChangeLog:
      	* g++.dg/diagnostic/bad-binary-ops.C: New test case.
      	* gcc.dg/bad-binary-ops.c: New test case.
      	gcc.dg/plugin/diagnostic_plugin_show_trees.c (get_range_for_expr):
      	Remove material copied from gcc-rich-location.c
      	(gcc_rich_location::add_expr): Likewise.
      
      From-SVN: r231884
      David Malcolm committed
    • DWARF: allow dynamic data member offsets for inheritance info · 7c154ecc
      An unintended effect of the recently introduced machinery to handle
      dynamic data member offsets in variable-length records (when
      -fgnat-encodings=minimal) prevented GCC from describing correctly
      inheritance information for classes in C++, which is a regression.
      
      This change rectifies this machinery in this case.
      
      gcc/ChangeLog:
      
      	* dwarf2out.c (add_data_member_location_attribute): Do not
      	disable dynamic data member offsets descriptions for TREE_BINFO
      	members.
      
      From-SVN: r231883
      Pierre-Marie de Rodat committed
    • re PR tree-optimization/65337 (LTO bootstrap failure with Ada enabled) · 059fbfa8
      	PR tree-optimization/65337
      	* tree-ssa-pre.c (eliminate): Also clean up abnormal edges if need be.
      
      From-SVN: r231882
      Eric Botcazou committed
    • Rename test file that had incorrect bug number · 989d4a86
      	PR libstdc++/68982
      	testsuite/20_util/function_objects/mem_fn/68276.cc: Rename to ...
      	testsuite/20_util/function_objects/mem_fn/68982.cc: Correct bug number.
      
      From-SVN: r231881
      Jonathan Wakely committed
    • libstdc++/68995 qualify calls to __callable_functor · a716d11a
      	PR libstdc++/68995
      	* include/std/functional (_function_handler, function): Qualify
      	__callable_functor.
      	* testsuite/20_util/function/68995.cc: New.
      
      From-SVN: r231880
      Jonathan Wakely committed
    • libstdc++/68276 consistently qualify std::forward · e9e6a995
      	PR libstdc++/68276
      	* include/std/functional (__invoke_impl, _Mem_fn::operator()): Qualify
      	std::forward.
      	testsuite/20_util/function_objects/mem_fn/68276.cc: New.
      
      From-SVN: r231879
      Jonathan Wakely committed
    • Fix typo · c453c551
      From-SVN: r231877
      Eric Botcazou committed
    • S/390: Fix base reg condition. · 0b729f58
      2015-12-21  Dominik Vogt  <vogt@linux.vnet.ibm.com>
      
      	* config/s390/s390.c (s390_emit_prologue): Fix base reg condition.
      
      From-SVN: r231876
      Dominik Vogt committed
    • re PR libstdc++/66693 ([C++17] std::tuple_size fails with const std::array) · de0830e1
      PR libstdc++/66693.
      
      	* include/std/tuple (tuple_element, tuple_size, tuple_element_t,
      	__tuple_element_t): Move to...
      	* include/std/utility: ...here.
      	* testsuite/20_util/pair/astuple/astuple.cc: Adjust.
      	* testsuite/20_util/pair/astuple/astuple_cpp14.cc: New.
      	* testsuite/20_util/tuple/tuple_element.cc: Adjust.
      	* testsuite/20_util/tuple/tuple_element_t.cc: Likewise.
      	* testsuite/20_util/tuple/tuple_size.cc: Likewise.
      	* testsuite/23_containers/array/tuple_interface/tuple_element.cc:
      	Likewise.
      	* testsuite/23_containers/array/tuple_interface/tuple_element_cpp14.cc:
      	New.
      	* testsuite/23_containers/array/tuple_interface/tuple_size.cc: Adjust.
      
      From-SVN: r231875
      Ville Voutilainen committed