1. 24 Dec, 2015 5 commits
    • Fix computation of single entry/exit of a region. · 402cab17
      For basic block with two preds, allow (as single entry) only when the other
      edge is a backedge. Similarly for basic block with two succs,
      allow (as single exit) only when the other edge is a back edge.
      
      2015-12-21  Aditya Kumar  <hiraditya@msn.com>
      
              * graphite-scop-detection.c (scop_detection::get_nearest_dom_with_single_entry): Check l == l2.
              (scop_detection::get_nearest_pdom_with_single_exit): Same.
              (scop_detection::merge_sese): Whitespace.
              (scop_detection::add_scop): Comment.
              (build_scops): Whitespace.
      
      From-SVN: r231946
      Aditya Kumar committed
    • Add missing intrinsic file. · 8e64f018
      From-SVN: r231945
      Kirill Yukhin committed
    • Introduce support for PKU instructions. · 41a4ef22
      gcc/
      	* common/config/i386/i386-common.c (OPTION_MASK_ISA_PKU_SET): New.
      	(OPTION_MASK_ISA_PKU_UNSET): Ditto.
      	(ix86_handle_option): Handle OPT_mpku.
      	* config.gcc: Add pkuintrin.h to i[34567]86-*-* and x86_64-*-*
      	targets.
      	* config/i386/cpuid.h (host_detect_local_cpu): Detect PKU feature.
      	* config/i386/i386-c.c (ix86_target_macros_internal): Handle PKU ISA
      	flag.
      	* config/i386/i386.c (ix86_target_string): Add "-mpku" to
      	ix86_target_opts.
      	(ix86_option_override_internal): Define PTA_PKU, mention new key
      	in skylake-avx512. Handle new ISA bits.
      	(ix86_valid_target_attribute_inner_p): Add "pku".
      	(enum ix86_builtins): Add IX86_BUILTIN_RDPKRU and IX86_BUILTIN_WRPKRU.
      	(builtin_description bdesc_special_args[]): Add new built-ins.
      	* config/i386/i386.h (define TARGET_PKU): New.
      	(define TARGET_PKU_P): Ditto.
      	* config/i386/i386.md (define_c_enum "unspecv"): Add UNSPEC_PKU.
      	(define_expand "rdpkru"): New.
      	(define_insn "*rdpkru"): Ditto.
      	(define_expand "wrpkru"): Ditto.
      	(define_insn "*wrpkru"): Ditto.
      	* config/i386/i386.opt (mpku): Ditto.
      	* config/i386/pkuintrin.h: New file.
      	* config/i386/x86intrin.h: Include pkuintrin.h
      	* doc/extend.texi: Describe new built-ins.
      	* doc/invoke.texi: Describe new switches.
      gcc/testsuite/
      	* g++.dg/other/i386-2.C: Add -mpku.
      	* g++.dg/other/i386-3.C: Ditto.
      	* gcc.target/i386/rdpku-1.c: New test.
      	* gcc.target/i386/sse-12.c: Add -mpku.
      	* gcc.target/i386/sse-13.c: Ditto.
      	* gcc.target/i386/sse-22.c: Ditto.
      	* gcc.target/i386/sse-33.c: Ditto.
      	* gcc.target/i386/wrpku-1.c: New test.
      
      From-SVN: r231944
      Kirill Yukhin committed
    • re PR ipa/67811 ([TM] ICE with try-block in transaction) · 6549bdc6
      PR ipa/67811
      
       * tree-cfg.c (make_edges_bb): Add abort edge for outer transactions.
      
      From-SVN: r231943
      Richard Henderson committed
    • Daily bump. · f89fc5c4
      From-SVN: r231942
      GCC Administrator committed
  2. 23 Dec, 2015 11 commits
  3. 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
  4. 21 Dec, 2015 1 commit