Commit Graph

135160 Commits

Author SHA1 Message Date
Ian Lance Taylor 16f72d88dd compiler: More cases that need a temporary for interface conversion.
From-SVN: r218952
2014-12-19 16:14:01 +00:00
Martin Liska 6b0e0695a5 re PR ipa/63569 (Wrong code with volatile and ICF)
Fix for PR ipa/63569.

	PR ipa/63569
	* gcc.dg/ipa/pr63569.c: New test.
	PR ipa/63569
	* ipa-icf-gimple.c (func_checker::compare_operand): Add missing
	comparison for volatile flag.

From-SVN: r218949
2014-12-19 12:40:50 +00:00
Jakub Jelinek 1f8d3e84ee re PR preprocessor/63831 (r217292 causes segfaults with -MM)
PR preprocessor/63831
	* c-cppbuiltin.c (c_cpp_builtins): Don't define __has_attribute
	and __has_cpp_attribute here.
	* c-ppoutput.c (init_pp_output): Set cb->has_attribute to
	c_common_has_attribute.
	* c-common.h (c_common_has_attribute): New prototype.
	* c-lex.c (init_c_lex): Set cb->has_attribute to
	c_common_has_attribute instead of cb_has_attribute.
	(get_token_no_padding): New function.
	(cb_has_attribute): Renamed to ...
	(c_common_has_attribute): ... this.  No longer static.  Use
	get_token_no_padding, require ()s, don't build TREE_LIST
	unnecessarily, fix up formatting, adjust diagnostics, call
	init_attributes.

	* directives.c (lex_macro_node): Remove __has_attribute__ handling.
	* internal.h (struct spec_node): Remove n__has_attribute__ field.
	(struct lexer_state): Remove in__has_attribute__ field.
	* macro.c (_cpp_builtin_macro_text): Handle BT_HAS_ATTRIBUTE.
	* identifiers.c (_cpp_init_hashtable): Remove __has_attribute__
	handling.
	* init.c (builtin_array): Add __has_attribute and __has_cpp_attribute.
	(cpp_init_special_builtins): Don't initialize __has_attribute
	or __has_cpp_attribute if CLK_ASM or pfile->cb.has_attribute is NULL.
	* traditional.c (enum ls): Remove ls_has_attribute,
	ls_has_attribute_close.
	(_cpp_scan_out_logical_line): Remove __has_attribute__ handling.
	* include/cpplib.h (enum cpp_builtin_type): Add BT_HAS_ATTRIBUTE.
	* pch.c (cpp_read_state): Remove __has_attribute__ handling.
	* expr.c (eval_token): Likewise.
	(parse_has_attribute): Removed.

	* c-c++-common/cpp/pr63831-1.c: New test.
	* c-c++-common/cpp/pr63831-2.c: New test.

From-SVN: r218948
2014-12-19 13:20:58 +01:00
Kyrylo Tkachov 8a386c9113 [ARM][doc] Remove mention of Advanced RISC Machines
* doc/invoke.texi (ARM options): Remove mention of Advanced RISC
	Machines.

From-SVN: r218897
2014-12-19 10:20:07 +00:00
James Greenhalgh 827785ddf6 Fix ChangeLog typo in 218895
From-SVN: r218896
2014-12-19 09:41:13 +00:00
Xingxing Pan 85e18759e7 [PATCH][ARM] Fix reservation pattern in cortex-a9-neon.md
gcc/

	* config/arm/cortex-a9-neon.md (cortex_a9_neon_vmov): Change
	reservation to cortex_a9_neon_dp.

From-SVN: r218895
2014-12-19 09:39:55 +00:00
Kaz Kojima 1e3e92b513 * [SH] Split QI/HImode load/store via r0 when LRA is enabled.
From-SVN: r218892
2014-12-19 04:56:26 +00:00
Kaz Kojima 74bd0da1fd * [SH] Add splitter to addsi3_compact.
From-SVN: r218891
2014-12-19 04:53:57 +00:00
Kaz Kojima 6efc6b7f05 * [SH] Modify movsi_ie and movsf_ie patterns for LRA.
From-SVN: r218890
2014-12-19 04:51:53 +00:00
Kaz Kojima fc1fcfa0b6 * [SH] Miscellaneous changes for LRA.
From-SVN: r218889
2014-12-19 04:49:16 +00:00
Kaz Kojima 106a52b7bf * [SH] Add -mlra option.
From-SVN: r218888
2014-12-19 04:47:18 +00:00
Kaz Kojima 14133a4d8a * Add TARGET_LEGITIMIZE_ADDRESS_DISPLACEMENT target macro.
From-SVN: r218887
2014-12-19 04:43:11 +00:00
Kaz Kojima d6220b11a7 * Add TARGET_CANNOT_SUBSTITUTE_MEM_EQUIV target macro.
From-SVN: r218886
2014-12-19 04:40:11 +00:00
Kaz Kojima 70712859a1 lra-constraints.c (process_address_1): Swap base_term and index_term if INDEX_REG_CLASS is assigned to base_term...
* lra-constraints.c (process_address_1): Swap base_term and index_term
  if INDEX_REG_CLASS is assigned to base_term already when INDEX_REG_CLASS
  is a single register class.

From-SVN: r218885
2014-12-19 04:36:54 +00:00
Ian Lance Taylor 47b6f9825f compiler: Avoid multiple evaluations in interface conversions.
Added assertions for cases that might lead to multiple
evaluations, and fixed all the problems I saw.

Test case already in master Go testsuite
(https://go-review.googlesource.com/#/c/1710/).

From-SVN: r218884
2014-12-19 04:05:59 +00:00
GCC Administrator 0f3e3f28e9 Daily bump.
From-SVN: r218883
2014-12-19 00:16:27 +00:00
Paolo Carlini ac1a984a5f re PR c++/63723 (Narrowing conversion allowed in braced init list in SFINAE context)
2014-12-18  Paolo Carlini  <paolo.carlini@oracle.com>

	PR c++/63723
	* g++.dg/cpp0x/sfinae54.C: New.

From-SVN: r218880
2014-12-19 00:02:05 +00:00
Jason Merrill 90f6debee4 re PR c++/64105 (ICE: in strip_typedefs, at cp/tree.c:1326)
PR c++/64105
	* parser.c (cp_parser_simple_type_specifier): Make auto parameter
	before -std=c++14 an error.

From-SVN: r218879
2014-12-18 18:53:15 -05:00
Paolo Carlini 18d27358a5 re PR c++/59204 (Incorrect metaprogram evaluation in SFINAE context)
2014-12-18  Paolo Carlini  <paolo.carlini@oracle.com>

	PR c++/59204
	* g++.dg/cpp0x/sfinae53.C: New.

From-SVN: r218878
2014-12-18 23:43:46 +00:00
Jason Merrill 3696ea5851 re PR c++/64352 (No SFINAE with deleted function)
PR c++/64352
	* pt.c (tsubst_copy_and_build): Pass complain to mark_used.

From-SVN: r218877
2014-12-18 17:22:42 -05:00
Jason Merrill 1b82e09e18 re PR c++/64251 (Chromium build error only with --enable-checking=yes)
PR c++/64251
	* decl2.c (mark_used): Don't mark if in_template_function.

From-SVN: r218876
2014-12-18 17:22:36 -05:00
Vladimir Makarov 03b9b5ce20 lra-constraints.c (lra-constraints.c): Exchange places of sclass and dclass.
2014-12-18  Vladimir Makarov  <vmakarov@redhat.com>

	* lra-constraints.c (lra-constraints.c): Exchange places of sclass
	and dclass.

From-SVN: r218875
2014-12-18 21:50:48 +00:00
Vladimir Makarov 32b38e8972 re PR rtl-optimization/64291 (Miscompile t-div in GMP's testsuite)
2014-12-18  Vladimir Makarov  <vmakarov@redhat.com>

	PR rtl-optimization/64291
	* lra-remat.c (bad_for_rematerialization_p): Add UNPSEC_VLOATILE.
	(create_cands): Process only output reload insn with potential
	cands.

2014-12-18  Vladimir Makarov  <vmakarov@redhat.com>

	PR rtl-optimization/64291
	* testsuite/gcc.target/i386/pr64291-[12].c: New tests.

From-SVN: r218874
2014-12-18 20:49:44 +00:00
Paolo Carlini 6e4992ca78 re PR c++/60955 (Erroneous warning about taking address of register with std=c++1y)
/cp
2014-12-18  Paolo Carlini  <paolo.carlini@oracle.com>

	PR c++/60955
	* pt.c (struct warning_sentinel): Move it...
	* cp-tree.h: ... here.
	* semantics.c (force_paren_expr): Use it.

/testsuite
2014-12-18  Paolo Carlini  <paolo.carlini@oracle.com>

	PR c++/60955
	* g++.dg/warn/register-parm-1.C: New.

From-SVN: r218871
2014-12-18 17:53:55 +00:00
H.J. Lu fbe575b652 X86-64: Add -mskip-rax-setup
The Linux kernel never passes floating point arguments around, vararg
functions or not. Hence no vector registers are ever used when calling a
vararg function.  But gcc still dutifully emits an "xor %eax,%eax" before
each and every call of a vararg function.  Since no callee use that for
anything, these instructions are redundant.

This patch adds the -mskip-rax-setup option to skip setting up RAX
register when SSE is disabled and there are no variable arguments passed
in vector registers.  Since RAX register is used to avoid unnecessarily
saving vector registers on stack when passing variable arguments, the
impacts of this option are callees may waste some stack space, misbehave
or jump to a random location.  GCC 4.4 or newer don't those issues,
regardless the RAX register value since they don't check the RAX register
value when SSE is disabled.

gcc/

	* config/i386/i386.c (ix86_expand_call): Skip setting up RAX
	register for -mskip-rax-setup when there are no parameters
	passed in vector registers.
	* config/i386/i386.opt (mskip-rax-setup): New option.
	* doc/invoke.texi: Document -mskip-rax-setup.

gcc/testsuite/

	* gcc.target/i386/amd64-abi-7.c: New tests.
	* gcc.target/i386/amd64-abi-8.c: Likwise.
	* gcc.target/i386/amd64-abi-9.c: Likwise.

From-SVN: r218870
2014-12-18 09:35:45 -08:00
Alan Lawrence 8448880117 [AArch64] Simplify+improve patterns for ushr(d?)_n_u64 intrinsic
gcc/:
	* config/aarch64/aarch64-simd.md (aarch64_lshr_simddi): Handle shift
	by 64 by moving const0_rtx.
	(aarch64_ushr_simddi): Delete.

	* config/aarch64/aarch64.md (enum unspec): Delete UNSPEC_USHR64.

gcc/testsuite/:

        * gcc.target/aarch64/ushr64_1.c: Remove scan-assembler "ushr...64".

From-SVN: r218868
2014-12-18 15:20:11 +00:00
Alan Lawrence b5b34d3759 [AArch64] Simplify patterns for sshr_n_[us]64 intrinsic
* config/aarch64/aarch64.md (enum "unspec"): Remove UNSPEC_SSHR64.

        * config/aarch64/aarch64-simd.md (aarch64_ashr_simddi): Change shift
        amount to 63 if was 64.
        (aarch64_sshr_simddi): Remove.

From-SVN: r218867
2014-12-18 15:00:51 +00:00
Wilco Dijkstra 26e0ff9411 [AArch64] Add TARGET_MIN_DIVISIONS_FOR_RECIP_MUL
2014-12-18  Wilco Dijkstra  <wilco.dijkstra@arm.com>

	* gcc/config/aarch64/aarch64.c (TARGET_MIN_DIVISIONS_FOR_RECIP_MUL):
	Define.
	(aarch64_min_divisions_for_recip_mul): New function.

From-SVN: r218866
2014-12-18 13:48:34 +00:00
Wilco Dijkstra 0b82a5a253 [AArch64] Generalize code alignment
2014-12-18  Wilco Dijkstra  <wilco.dijkstra@arm.com>

	* config/aarch64/aarch64-protos.h (tune-params): Add code alignment
	tuning parameters.
	* gcc/config/aarch64/aarch64.c (generic_tunings): Add code alignment
	tuning parameters.
	(cortexa53_tunings): Likewise.
	(cortexa57_tunings): Likewise.
	(thunderx_tunings): Likewise.
	(aarch64_override_options): Use new alignment tunings.

From-SVN: r218865
2014-12-18 13:46:22 +00:00
Martin Liska 09cb9532c4 re PR tree-optimization/64330 (IPA-ICF merges const exported vars that could be addressable in other TUs)
Fix for PR64330.

	PR tree-optimization/64330
	* ipa-icf.c (sem_variable::parse): Add checking
	for externally visible symbols and do not introduce
	an alias for an external declaration.

From-SVN: r218864
2014-12-18 13:32:18 +00:00
Jan Hubicka 2ddeb89bf5 re PR bootstrap/63573 (libgo: ICE building libgo on powerpc-linux-gnu)
Fix for PR bootstrap/63573.

	PR bootstrap/63573
	* tree-inline.c (remap_gimple_stmt): Handle gimple_call_from_thunk_p
	predicate.

From-SVN: r218861
2014-12-18 12:06:34 +00:00
Martin Liska 544dafa696 re PR ipa/64146 (ipa-icf breaks gold dynamic_test_2 test)
Fix for PR ipa/64146

	PR ipa/64146
	* ipa-icf.c (sem_function::merge): Check for
	decl_binds_to_current_def_p is newly added to merge operation.
	* g++.dg/ipa/pr64146.C: New test.

From-SVN: r218860
2014-12-18 12:02:22 +00:00
Rainer Orth 72c122a20e Change mpx effective-target test into link test
* lib/mpx-dg.exp (check_effective_target_mpx): Change into link test.
	Add main.

From-SVN: r218859
2014-12-18 11:54:40 +00:00
Rainer Orth d8b1c7f44b Include target-utils.exp in boehm-gc testing
* testsuite/lib/boehm-gc.exp: Load target-utils.exp.

From-SVN: r218857
2014-12-18 09:42:22 +00:00
Prathamesh Kulkarni 0ecc12d8f0 Add myself to MAINTAINERS under Writer After Approval
From-SVN: r218856
2014-12-18 06:19:33 +00:00
Bin Cheng 6326a5f515 re PR middle-end/62178 ([AArch64] Performance regression on matrix matrix multiply due to r211211)
PR tree-optimization/62178
	* tree-ssa-loop-ivopts.c (cheaper_cost_with_cand): New function.
	(iv_ca_replace): New function.
	(try_improve_iv_set): New parameter try_replace_p.
	Break local optimal fixed-point by calling iv_ca_replace.
	(find_optimal_iv_set_1): Pass new argument to try_improve_iv_set.

	gcc/testsuite/ChangeLog
	PR tree-optimization/62178
	* gcc.target/aarch64/pr62178.c: New test.

From-SVN: r218855
2014-12-18 02:53:42 +00:00
Dehao Chen 29ca9bfb90 auto-profile.c (afdo_annotate_cfg): Invoke update_ssa in the right place.
gcc/ChangeLog:
2014-12-17  Dehao Chen  <dehao@google.com>

        * auto-profile.c (afdo_annotate_cfg): Invoke update_ssa in the right
        place.
        (auto_profile): Recompute inline summary after processing cgraph node.

From-SVN: r218854
2014-12-18 00:19:24 +00:00
GCC Administrator 6fc5f22af3 Daily bump.
From-SVN: r218853
2014-12-18 00:16:36 +00:00
Oleg Endo 89f8797ee1 re PR target/51244 ([SH] Inefficient conditional branch and code around T bit)
gcc/
	PR target/51244
	* config/sh/sh_treg_combine.cc (is_conditional_insn): New function.
	(cbranch_trace): Add member rtx* condition_rtx_in_insn, initialize it
	accordingly in constructor.
	(cbranch_trace::branch_condition_rtx_ref): New function.
	(cbranch_trace::branch_condition_rtx): Use branch_condition_rtx_ref.
	(sh_treg_combine::try_invert_branch_condition): Invert condition rtx
	in insn using reversed_comparison_code and validate_change instead of
	invert_jump_1.
	(sh_treg_combine::execute): Look for conditional insns in basic blocks
	in addition to conditional branches.
	* config/sh/sh.md (*movsicc_div0s): Remove combine patterns.

From-SVN: r218850
2014-12-17 23:08:14 +00:00
Oleg Endo ff49a9ba7b re PR target/51244 ([SH] Inefficient conditional branch and code around T bit)
gcc/
	PR target/51244
	* config/sh/sh_treg_combine.cc (sh_treg_combine::try_optimize_cbranch):
	Combine ccreg inversion and cbranch into inverted cbranch.

From-SVN: r218847
2014-12-17 22:52:21 +00:00
Sergio Durigan Junior 64e6d5c442 dg-extract-results.sh: Use --text with grep to avoid issues with binary files.
2014-12-17  Sergio Durigan Junior  <sergiodj@redhat.com>

	* dg-extract-results.sh: Use --text with grep to avoid issues with
	  binary files.  Fall back to cat -v, if that doesn't work.

From-SVN: r218843
2014-12-17 22:35:04 +00:00
Vladimir Makarov 113050e74b Fix typo in changelog.
From-SVN: r218836
2014-12-17 21:29:01 +00:00
Vladimir Makarov cdfc4dcf48 lra-constrints.c (process_alt_operands): Remove non allocatable hard regs when considering ira_prohibited_class_mode_regs.
2014-12-17  Vladimir Makarov  <vmakarov@redhat.com>

	* lra-constrints.c (process_alt_operands): Remove non allocatable
	hard regs when considering ira_prohibited_class_mode_regs.

From-SVN: r218835
2014-12-17 21:25:18 +00:00
Janus Weil f4e2df8970 re PR fortran/64173 ([F03] ICE involving procedure pointer component)
2014-12-17  Janus Weil  <janus@gcc.gnu.org>

	PR fortran/64173
	* trans-array.c (structure_alloc_comps): Do not nullify procedure
	pointer components.

2014-12-17  Janus Weil  <janus@gcc.gnu.org>

	PR fortran/64173
	* gfortran.dg/proc_ptr_comp_40.f90: New.

From-SVN: r218834
2014-12-17 22:12:42 +01:00
Jan Hubicka 6c0c245e30 sreal.h (sreal::normalize): Implement inline.
* sreal.h (sreal::normalize): Implement inline.
	(sreal::normalize_up): New function.
	(sreal::normalize_down): New function.
	* sreal.c (sreal::normalize): Remove.

From-SVN: r218833
2014-12-17 21:11:46 +00:00
Jason Merrill 12d9ce1903 re PR c++/64333 (C++14 constexpr gives wrong results when a looping constexpr function is evaluated twice)
PR c++/64333
	* constexpr.c (cxx_bind_parameters_in_call): non_constant_args parm.
	(cxx_eval_call_expression): Don't cache calls with non-constant args.
	(cxx_eval_constant_expression) [COMPOUND_EXPR]: Pass true for lval.
	(cxx_eval_unary_expression, cxx_eval_binary_expression)
	(cxx_eval_conditional_expression): Pass	false for lval.

From-SVN: r218832
2014-12-17 15:41:18 -05:00
Jason Merrill 92a596e856 * constexpr.c: Change "addr" parm names to "lval".
From-SVN: r218831
2014-12-17 15:41:12 -05:00
Jason Merrill 13f649f66c * constexpr.c: Tweak comments and formatting.
From-SVN: r218830
2014-12-17 15:41:07 -05:00
James Greenhalgh 43a39cdd96 [AArch64] Remove "generic_sched" attribute
gcc/

	* config/aarch64/aarch64.md (generic_sched): Delete it.

From-SVN: r218829
2014-12-17 18:15:46 +00:00
Jan-Benedict Glaw 53fea7871c MSP430: Fix unused arg warning
The build robot found this:

g++ -c   -g -O2 -DIN_GCC  -DCROSS_DIRECTORY_STRUCTURE  -fno-exceptions -fno-rtti -fasynchronous-unwind-tables -W -Wall -Wno-narrowing -Wwrite-strings -Wcast-qual -Wmissing-format-attribute -Woverloaded-virtual -pedantic -Wno-long-long -Wno-variadic-macros -Wno-overlength-strings -Werror -fno-common  -DHAVE_CONFIG_H -I. -I. -I../../../gcc/gcc -I../../../gcc/gcc/. -I../../../gcc/gcc/../include -I../../../gcc/gcc/../libcpp/include -I/opt/cfarm/mpc/include  -I../../../gcc/gcc/../libdecnumber -I../../../gcc/gcc/../libdecnumber/dpd -I../libdecnumber -I../../../gcc/gcc/../libbacktrace   -o msp430.o -MT msp430.o -MMD -MP -MF ./.deps/msp430.TPo ../../../gcc/gcc/config/msp430/msp430.c
../../../gcc/gcc/config/msp430/msp430.c:979:43: error: unused parameter ‘file’ [-Werror=unused-parameter]
 msp430_asm_output_addr_const_extra (FILE *file, rtx x)
                                           ^
cc1plus: all warnings being treated as errors
make[2]: *** [msp430.o] Error 1

(See for example this build:
http://toolchain.lug-owl.de/buildbot/show_build_details.php?id=384666)

Ok for this one?

2014-12-17  Jan-Benedict Glaw  <jbglaw@lug-owl.de>

        * config/msp430/msp430.c (msp430_asm_output_addr_const_extra): Fix
        unused argument warning.

From-SVN: r218828
2014-12-17 17:10:37 +00:00