1. 23 Sep, 2015 4 commits
  2. 22 Sep, 2015 22 commits
    • Fix -Wmisleading-indentation false-positive · d5398058
      gcc/c-family/ChangeLog:
      
      	* c-indentation.c (should_warn_for_misleading_indentation):
      	Float out and consolidate the calls to get_visual_column that
      	are passed guard_exploc as an argument.  Compare
      	next_stmt_vis_column with guard_line_first_nws instead of with
      	body_line_first_nws.
      
      gcc/testsuite/ChangeLog:
      
      	* c-c++-common/Wmisleading-indentation.c: Augment test.
      
      From-SVN: r228027
      Patrick Palka committed
    • shrink-wrap: Handle multiple predecessors of prologue · 6c98d499
      The caller of try_shrink_wrapping wants to be returned a single edge to
      put the prologue on.  To make that work even if there are multiple edges
      (all pointing to the PRO block) that need the prologue, add a new block
      that becomes the destination of all such edges, and then jumps to PRO.
      
      In the general case, some edges to PRO will need to be redirected, and
      not all edges *can* be redirected.  This adds a can_get_prologue function
      that detects such cases.  This then happily can also handle the "prologue
      clobbers some reg that is live on the edge we want to insert it on" case.
      
      Not all EDGE_CROSSING edges can be redirected, so handle those the same
      as EDGE_COMPLEX edges.
      
      
      2015-09-22  Segher Boessenkool  <segher@kernel.crashing.org>
      
      	* function.c (thread_prologue_and_epilogue_insns): Delete
      	orig_entry_edge argument to try_shrink_wrapping.
      	* shrink-wrap.c (can_get_prologue): New function.
      	(can_dup_for_shrink_wrapping): Also handle EDGE_CROSSING.
      	(try_shrink_wrapping): Delete orig_entry_edge argument.  Use
      	can_get_prologue where needed.  Remove code that finds a single
      	edge for the prologue.  Remove code that tests if any reg clobbered
      	by the prologue is live on the prologue edge.  Remove code that finds
      	the new prologue edge after duplicating blocks.  Make a new prologue
      	block and edge.
      	* shrink-wrap.h (try_shrink_wrapping): Delete orig_entry_edge argument.
      
      From-SVN: r228022
      Segher Boessenkool committed
    • [PATCH] Remove undefined behaviour from hppa backend · 50fa47d9
      	* config/pa/pa.h (MIN_LEGIT_64BIT_CONST_INT: Avoid undefined
      	behavior.
      
      From-SVN: r228021
      Jeff Law committed
    • c.opt (Wmultiple-inheritance, [...]): New C++ warnings. · 6b333269
      	c-family/
      	* c.opt (Wmultiple-inheritance, Wvirtual-inheritance, Wtemplates,
      	Wnamespaces): New C++ warnings.
      
      	cp/
      	* decl.c (xref_basetypes): Check virtual and/or multiple
      	inheritance warning.
      	* parser.c (cp_parser_namespace_definition): Check namespaces
      	warning.
      	* pt.c (push_template_decl_real): Check templates warning.
      
      	* doc/invoke.texi  (-Wmultiple-inheritance, -Wvirtual-inheritance,
      	-Wtemplates, -Wnamespaces): Document.
      
      	testsuite/
      	* g++.dg/diagostic/disable.C: New.
      
      From-SVN: r228019
      Nathan Sidwell committed
    • Disconnect -Wabi=<n> from -fabi-compat-version=<n>. · a75f1574
      gcc/c-family/
      	* c-common.h (abi_compat_version_crosses): New.
      	(warn_abi_version): Declare.
      	* c-common.c: Define it.
      	* c-opts.c (c_common_post_options): Handle it.
      	flag_abi_compat_version defaults to 8.
      gcc/cp/
      	* mangle.c (abi_warn_or_compat_version_crosses): New.
      	Use it instead of abi_version_crosses.
      	(mangle_decl): Deal with -fabi-compat-version and -Wabi separately.
      
      From-SVN: r228017
      Jason Merrill committed
    • Handle restrict pointer references as restrict in AA · 8013b816
      2015-09-22  Tom de Vries  <tom@codesourcery.com>
      
      	PR tree-optimization/67671
      	* tree-ssa-structalias.c (create_variable_info_for_1): Handle restrict
      	pointer references as restrict.
      
      	* g++.dg/pr67671.C: New test.
      
      From-SVN: r228015
      Tom de Vries committed
    • Update Andrew Cagney's address. · 0854c7f1
      From-SVN: r228014
      Jason Merrill committed
    • nios2.c (nios2_legitimize_address): When handling 'reg + reloc' cases... · b062ae05
      2015-09-22  Chung-Lin Tang  <cltang@codesourcery.com>
      
      	* config/nios2/nios2.c (nios2_legitimize_address): When handling
      	'reg + reloc' cases, allow first operand to be non-REG, and use
      	force_reg() to enforce address pattern.
      
      From-SVN: r228012
      Chung-Lin Tang committed
    • re PR target/67480 (AVX512 bitwise logic operations pattern is incorrect) · 01c102a6
      PR target/67480
      
      gcc/
      	* config/i386/sse.md (define_mode_iterator VI48_AVX_AVX512F): New.
      	(define_mode_iterator VI12_AVX_AVX512F): New.
      	(define_insn "<mask_codefor><code><mode>3<mask_name>"): Change
      	all iterators to VI48_AVX_AVX512F. Extract remaining modes ...
      	(define_insn "*<code><mode>3"): ... Into new pattern using
      	VI12_AVX_AVX512F iterators without masking.
      
      gcc/testsuite/
      	* gcc.target/i386/pr67480.c: New test.
      
      From-SVN: r228010
      Alexander Fomin committed
    • AVX-512. Introduce SKylake server CPU. · 06caf59d
      gcc/
      	* config.gcc: Support "skylake-avx512".
              * config/i386/i386-c.c (ix86_target_macros_internal): Handle
              PROCESSOR_SKYLAKE_AVX512.
              * config/i386/i386.c (m_SKYLAKE_AVX512): Define.
              (processor_target_table): Add "skylake-avx512".
              (PTA_SKYLAKE_AVX512): Define.
      	(ix86_option_override_internal): Add "skylake_avx512".
              (fold_builtin_cpu): Handle "skylake_avx512", add F_AVX512VL
      	F_AVX512BW, F_AVX512DQ, F_AVX512ER, F_AVX512PF, F_AVX512CD.
              * config/i386/i386.h (TARGET_SKYLAKE_AVX512): Define.
              (processor_type): Add PROCESSOR_SKYLAKE_AVX512.
      	* doc/invoke.texi (skylake-avx512): New.
      
      libgcc/
      	* libgcc/config/i386/cpuinfo.c (enum processor_features): Add
      	FEATURE_AVX512VL, FEATURE_AVX512BW, FEATURE_AVX512DQ,
      	FEATURE_AVX512CD, FEATURE_AVX512ER, FEATURE_AVX512PF.
      	(get_available_features): Habdle new features.
      
      gcc/testsuite/
              * gcc.target/i386/funcspec-5.c: Test avx512vl, avx512bw,
      	avx512dq, avx512cd, avx512er, avx512pf and skylake-avx512.
      	* gcc.target/i386/builtin_target.c: Test  avx512vl, avx512bw,
      	avx512dq, avx512cd, avx512er and avx512pf.
      
      From-SVN: r228009
      Kirill Yukhin committed
    • AVX-512. Fix patterns for kunpck insns. · 7095d6f2
      gcc/
      	* gcc/config/i386/i386.md (define_insn "kunpckhi"): Fix
      	operand in pattern.
      	(define_insn "kunpcksi"): Ditto. 
      	(define_insn "kunpckdi"): Ditto.
      
      From-SVN: r228005
      Kirill Yukhin committed
    • AVX-512. Fix kxnor insn split. · 5febdf54
      gcc/
      	* gcc/config/i386/i386.md (define_split not/xor SWI1248x): Use
      	iterator instead of fixed modes.
      
      From-SVN: r228003
      Kirill Yukhin committed
    • [AArch64] Use atomic load-operate instructions for update-fetch patterns. · 68729b06
      2015-09-22  Matthew Wahab  <matthew.wahab@arm.com>
      
      	* config/aarch64/aarch64-protos.h (aarch64_gen_atomic_ldop):
      	Adjust declaration.
      	* config/aarch64/aarch64.c (aarch64_emit_bic): New.
      	(aarch64_gen_atomic_ldop): Adjust comment.  Add parameter
      	out_result.  Update to support update-fetch operations.
      	* config/aarch64/atomics.md (aarch64_atomic_exchange<mode>_lse):
      	Adjust for change to aarch64_gen_atomic_ldop.
      	(aarch64_atomic_<atomic_optab><mode>_lse): Likewise.
      	(aarch64_atomic_fetch_<atomic_optab><mode>_lse): Likewise.
      	(atomic_<atomic_optab>_fetch<mode>): Change to an expander.
      	(aarch64_atomic_<atomic_optab>_fetch<mode>): New.
      	(aarch64_atomic_<atomic_optab>_fetch<mode>_lse): New.
      
      gcc/testsuite
      2015-09-22  Matthew Wahab  <matthew.wahab@arm.com>
      
      	* gcc.target/aarch64/atomic-inst-ldadd.c: Add tests for
      	update-fetch operations.
      	* gcc.target/aarch64/atomic-inst-ldlogic.c: Likewise.
      
      From-SVN: r228002
      Matthew Wahab committed
    • [AArch64] Use atomic load-operate instructions for fetch-update patterns. · 641c2f8b
      gcc/
      2015-09-22  Matthew Wahab  <matthew.wahab@arm.com>
      
      	* config/aarch64/aarch64-protos.h
      	(aarch64_atomic_ldop_supported_p): Declare.
      	* config/aarch64/aarch64.c (aarch64_atomic_ldop_supported_p): New.
      	(enum aarch64_atomic_load_op_code): New.
      	(aarch64_emit_atomic_load_op): New.
      	(aarch64_gen_atomic_ldop): Update to support load-operate
      	patterns.
      	* config/aarch64/atomics.md (atomic_<atomic_optab><mode>): Change
      	to an expander.
      	(aarch64_atomic_<atomic_optab><mode>): New.
      	(aarch64_atomic_<atomic_optab><mode>_lse): New.
      	(atomic_fetch_<atomic_optab><mode>): Change to an expander.
      	(aarch64_atomic_fetch_<atomic_optab><mode>): New.
      	(aarch64_atomic_fetch_<atomic_optab><mode>_lse): New.
      
      gcc/testsuite/
      2015-09-22  Matthew Wahab  <matthew.wahab@arm.com>
      
      	* gcc.target/aarch64/atomic-inst-ldadd.c: New.
      	* gcc.target/aarch64/atomic-inst-ldlogic.c: New.
      
      From-SVN: r228001
      Matthew Wahab committed
    • [AArch64] Add atomic load-operate instructions. · 6380d2bc
      2015-09-22  Matthew Wahab  <matthew.wahab@arm.com>
      
      	* config/aarch64/aarch64/atomics.md (UNSPECV_ATOMIC_LDOP): New.
      	(UNSPECV_ATOMIC_LDOP_OR): New.
      	(UNSPECV_ATOMIC_LDOP_BIC): New.
      	(UNSPECV_ATOMIC_LDOP_XOR): New.
      	(UNSPECV_ATOMIC_LDOP_PLUS): New.
      	(ATOMIC_LDOP): New.
      	(atomic_ldop): New.
      	(aarch64_atomic_load<atomic_ldop><mode>): New.
      
      From-SVN: r228000
      Matthew Wahab committed
    • [AArch64] Make BIC, other logical instructions, available. · cc05c2c3
      2015-09-22  Matthew Wahab  <matthew.wahab@arm.com>
      
      	* config/aarch64/aarch64.md
      	(<LOGICAL:optab>_one_cmpl_<SHIFT:optab><mode>3): Make a named
      	pattern.
      
      From-SVN: r227999
      Matthew Wahab committed
    • [AArch64] Use atomic instructions for swap and fetch-update operations. · 9cd7b720
      gcc/
      2015-09-22  Matthew Wahab  <matthew.wahab@arm.com>
      
      	* config/aarch64/aarch64-protos.h (aarch64_gen_atomic_ldop):
      	Declare.
      	* config/aarch64/aarch64.c (aarch64_emit_atomic_swap): New.
      	(aarch64_gen_atomic_ldop): New.
      	(aarch64_split_atomic_op): Fix whitespace and add a comment.
      	* config/aarch64/atomics.md (UNSPECV_ATOMIC_SWP): New.
      	(aarch64_compare_and_swap<mode>_lse): Fix some whitespace.
      	(atomic_exchange<mode>): Replace with an expander.
      	(aarch64_atomic_exchange<mode>): New.
      	(aarch64_atomic_exchange<mode>_lse): New.
      	(aarch64_atomic_<atomic_optab><mode>): Fix some whitespace.
      	(aarch64_atomic_swp<mode>): New.
      
      gcc/testsuite/
      2015-09-22  Matthew Wahab  <matthew.wahab@arm.com>
      
      	* gcc.target/aarch64/atomic-inst-ops.inc: (TEST_MODEL): New.
      	(TEST_ONE): New.
              * gcc.target/aarch64/atomic-inst-swap.c: New.
      
      From-SVN: r227998
      Matthew Wahab committed
    • [PATCH tree-inline] Do not say "called from here" with UNKNOWN_LOCATION · 9915b1c9
      In https://sourceware.org/ml/libc-alpha/2014-12/msg00300.html, we give a
      "called from here" note without actually having a location, which looks
      strange. I haven't been able to generate such a testcase. If this happens,
      try to at least point to the current function being called. If that location is
      also unknown, skip the extra note.
      
      gcc/ChangeLog:
      
      2015-09-22  Manuel López-Ibáñez  <manu@gcc.gnu.org>
      
      	* tree-inline.c (expand_call_inline): Use inform for extra note.
      	Do not give a note with UNKNOWN_LOCATION.
      	Replace input_location with gimple_location (stmt).
      	Use true/false instead of TRUE/FALSE.
      
      gcc/testsuite/ChangeLog:
      
      2015-09-22  Manuel López-Ibáñez  <manu@gcc.gnu.org>
      
      	* gcc.target/i386/inline_error.c (int bar): Use dg-message for note.
      	* gcc.target/i386/pr57756.c (static __inline int caller): Likewise.
      	* gcc.target/i386/pr59789.c (f1): Likewise.
      	* gcc.target/i386/intrinsics_5.c (__m128i foo): Likewise.
      	* gcc.target/i386/intrinsics_6.c: Likewise.
      	* gcc.dg/winline-5.c (int t): Likewise.
      	* gcc.dg/winline-9.c (t): Likewise.
      	* gcc.dg/always_inline2.c (q): Likewise.
      	* gcc.dg/winline-2.c (inline int t): Likewise.
      	* gcc.dg/winline-6.c: Likewise.
      	* gcc.dg/winline-10.c (void g): Likewise.
      	* gcc.dg/pr49243.c (void parse): Likewise.
      	* gcc.dg/always_inline3.c (q2): Likewise.
      	* gcc.dg/winline-3.c: Likewise.
      	* gcc.dg/winline-7.c (inline void *t): Likewise.
      
      From-SVN: r227997
      Manuel López-Ibáñez committed
    • Handle single restrict pointer in struct in create_variable_info_for_1 · 50b4b446
      2015-09-22  Tom de Vries  <tom@codesourcery.com>
      
      	PR tree-optimization/67666
      	* tree-ssa-structalias.c (create_variable_info_for_1): Handle struct
      	with single field non-conservative.
      
      	* g++.dg/pr67666.C: New test.
      
      From-SVN: r227996
      Tom de Vries committed
    • re PR libgomp/67141 (wrong libgomp mutex initialisation order) · 6bb4c3e2
      2015-09-22  Chung-Lin Tang  <cltang@codesourcery.com>
      
      	PR libgomp/67141
      	* oacc-int.h (goacc_host_init): Add declaration.
      	* oacc-host.c (goacc_host_init): Remove static and constructor attribute.
      	* oacc-init.c (goacc_runtime_initialize): Call goacc_host_init() at end.
      
      From-SVN: r227994
      Chung-Lin Tang committed
    • Revert LRA SPARC changes for now. · dc2a24ed
      gcc/
      
      	PR/67622
      	Revert:
      	2015-09-11  David S. Miller  <davem@davemloft.net>
      
      		* config/sparc/constraints.md: Make "U" constraint a real register
      		constraint.
      		* config/sparc/sparc.c (TARGET_LRA_P): Define.
      		(D_MODES, DF_MODES): Add missing cast.
      		(TF_MODES, TF_MODES_NO_S): Include T_MODE.
      		(OF_MODES, OF_MODES_NO_S): Include O_MODE.
      		(sparc_register_move_cost): Decrease Niagara/UltrsSPARC memory
      		cost to 8.
      		* config/sparc/sparc.h (PROMOTE_MODE): Define.
      		* config/sparc/sparc.md (*movsi_lo_sum, *movsi_high): Do not
      		provide these insn when flag_pic.
      
      	2015-09-17  David S. Miller  <davem@davemloft.net>
      
      		* config/sparc/sparc-protos.h (sparc_secondary_memory_needed):
      		Declare.
      		* config/sparc/sparc.c (sparc_secondary_memory_needed): New
      		function.
      		* config/sparc/sparc.h (SECONDARY_MEMORY_NEEDED): Use it.
      		(HARD_REGNO_CALLER_SAVE_MODE): Define.
      		* config/sparc/sparc.md (sethi_di_medlow, losum_di_medlow, seth44)
      		(setm44, setl44, sethh, setlm, sethm, setlo, embmedany_sethi)
      		(embmedany_losum, embmedany_brsum, embmedany_textuhi)
      		(embmedany_texthi, embmedany_textulo, embmedany_textlo): Do not
      		provide when flag_pic.
      
      From-SVN: r227993
      David S. Miller committed
    • Daily bump. · 36d0586f
      From-SVN: r227992
      GCC Administrator committed
  3. 21 Sep, 2015 14 commits