1. 03 Mar, 2017 4 commits
    • re PR middle-end/79818 (wrong code with -fwrapv and -Os/-O1/-O2/-O3) · 75473a91
      2017-03-03  Richard Biener  <rguenther@suse.de>
      
      	PR middle-end/79818
      	* match.pd ( X +- C1 CMP C2 -> X CMP C2 -+ C1): Add missing
      	TYPE_OVERFLOW_UNDEFINED check.
      
      	* gcc.dg/torture/pr79818.c: New testcase.
      
      From-SVN: r245860
      Richard Biener committed
    • Update overload resolution with deduction guides. · fb5ce608
      	* pt.c (do_class_deduction): Always build the copy guide.
      	(copy_guide_p, template_guide_p): New.
      	(build_deduction_guide): Remember the original constructor.
      	* call.c (joust): Prefer the copy guide and non-template guides.
      
      From-SVN: r245859
      Jason Merrill committed
    • Allow deduction guides to look into primary template. · de35db42
      	* cp-tree.h (struct saved_scope): Add deduction_guide_type.
      	(struct cp_decl_specifier_seq): Add constructor_p.
      	* parser.c (cp_parser_decl_specifier_seq): Set constructor_p.
      	(cp_parser_init_declarator): Check it.  Set ctor_dtor_or_conv_p.
      	Clear deduction_guide_type.  Don't handle deduction guide names.
      	(cp_parser_declarator): Don't clear ctor_dtor_or_conv_p.
      	(cp_parser_direct_declarator): Likewise.  Handle deduction guides.
      	(cp_parser_member_declaration, cp_parser_cache_defarg)
      	(cp_parser_objc_class_ivars): Set ctor_dtor_or_conv_p.
      	* pt.c (tsubst_copy, tsubst_copy_and_build): Revert last change.
      	(build_deduction_guide): Set deduction_guide_type.
      	(dependent_scope_p): Check deduction_guide_type.
      	* search.c (lookup_member): Likewise.
      
      From-SVN: r245858
      Jason Merrill committed
    • Daily bump. · 9e01c6ce
      From-SVN: r245857
      GCC Administrator committed
  2. 02 Mar, 2017 24 commits
  3. 01 Mar, 2017 12 commits
    • PR middle-end/79692 - [7 Regression] -Wformat-overflow false positive · 71dedb33
      gcc/ChangeLog:
      
      	PR middle-end/79692
      	* gimple-ssa-sprintf.c
      	(directive::known_width_and_precision): New function.
      	(format_integer): Use it.
      	(get_mpfr_format_length): Consider the full range of precision
      	when computing %g output with the # flag.  Set the likely byte
      	count to 3 rather than 1 when precision is indeterminate.
      	(format_floating): Correct the lower bound of precision.
      
      gcc/testsuite/ChangeLog:
      
      	PR middle-end/79692
      	* gcc.dg/tree-ssa/builtin-sprintf-2.c: Add test cases.
      	* gcc.dg/tree-ssa/builtin-sprintf-warn-10.c: Correct %#g.
      	* gcc.dg/tree-ssa/builtin-sprintf-warn-15.c: New test.
      	* gcc.dg/tree-ssa/builtin-snprintf-3.c: Ditto.
      
      From-SVN: r245822
      Martin Sebor committed
    • invoke.texi: Document default code model for 64-bit Linux. · 538d7dba
      2017-03-01  Bill Schmidt  <wschmidt@linux.vnet.ibm.com>
      
      	* doc/invoke.texi: Document default code model for 64-bit Linux.
      
      From-SVN: r245821
      Bill Schmidt committed
    • * es.po: Update. · 2590a109
      From-SVN: r245820
      Joseph Myers committed
    • re PR target/79752 (incorrect code generation for __divkf3 with -O2 -mcpu=power9) · af15f993
      2017-03-01  Aaron Sawdey  <acsawdey@linux.vnet.ibm.com>
      
              PR target/79752
              * config/rs6000/rs6000.md (peephole2 for udiv/umod): Should emit
              udiv rather than div since input pattern is unsigned.
      
      From-SVN: r245817
      Aaron Sawdey committed
    • i386.c (print_reg): Warn for values of unsupported size in integer register. · 48990905
      	* config/i386/i386.c (print_reg): Warn for values of
      	unsupported size in integer register.
      
      testsuite/ChangeLog:
      
      	* gcc.target/i386/invsize-2.c: New test.
      	* gcc.target/i386/invsize-3.c: Ditto.
      	* gcc.target/i386/invsize-4.c: Ditto.
      	* gcc.target/i386/pr66274.c: Expect "unsuported size" warning.
      	* gcc.target/i386/stackalign/asm-1.c: Ditto.
      
      From-SVN: r245815
      Uros Bizjak committed
    • cmd/go: add testdata/timeoutbench_test.go · c85ac396
      This file was accidentally omitted from the update to the final Go 1.8.
      
      From-SVN: r245814
      Ian Lance Taylor committed
    • re PR target/79439 (Missing nop instruction after recursive call corrupts TOC register) · c7f0c9f3
      [gcc]
      2017-03-01  Michael Meissner  <meissner@linux.vnet.ibm.com>
      
      	PR target/79439
      	* config/rs6000/predicates.md (current_file_function_operand): Do
      	not allow self calls to be local if the function is replaceable.
      
      [gcc/testsuite]
      2017-03-01  Michael Meissner  <meissner@linux.vnet.ibm.com>
      
      	PR target/79439
      	* gcc.target/powerpc/pr79439.c: New test.
      
      From-SVN: r245813
      Michael Meissner committed
    • pr79544.c: Add test for vec_vsrad and fix up scan string. · f5ef6bfc
      	* gcc.target/powerpc/pr79544.c: Add test for vec_vsrad and fix up
      	scan string.
      
      From-SVN: r245812
      Pat Haugen committed
    • re PR target/79395 (Compile error with -mcpu=power9 and __builtin_vec_vcmpne_p) · 50181506
      gcc/ChangeLog:
      
      2017-03-01  Kelvin Nilsen  <kelvin@gcc.gnu.org>
      
      	PR target/79395
      	* config/rs6000/altivec.h (vec_ctz and others): Change the
      	preprocessor macro that controls conditional compilation from
      	_ARCH_PWR9 to __POWER9_VECTOR__.
      	(vec_all_ne): Change parameterization of __altivec_scalar_pred
      	macro expansion under preprocessor #ifdef __POWER9_VECTOR__
      	control (instead of _ARCH_PWR9 control) so that template
      	definition uses power9-specific function.
      	(vec_any_eq): Likewise.
      	(vec_all_ne): Change macro definition to use a power9-specific
      	expansion under #ifdef __POWER9_VECTOR__ control (instead of
      	_ARCH_PWR9 control).
      	(vec_any_eq) Likewise.
      	* config/rs6000/rs6000-builtin.def (CMPNEF): Remove BU_P9V_AV_2
      	expansion for CMPNEF to remove support for xvcmpnesp instruction.
      	(CMPNED): Remove BU_P9V_AV2 expansion for CMPNED to remove
      	support for xvcmpnedp instruction.
      	(VCMPNEB_P): Replace BU_P9V_AV_P macro expansion with BU_P9V_AV_2
      	macro expansion so that Power9 implementation of vec_all_ne does
      	not use the AltiVec predicate framework.
      	(VCMPNEH_P): Likewise.
      	(VCMPNEW_P): Likewise.
      	(VCMPNED_P): Likewise.
      	(VCMPNEFP_P): Likewise.
      	(VCMPNEDP_P): Likewise.
      	(VCMPAEB_P): Add BU_P9V_AV_2 macro expansion to change
      	implementation of vec_any_eq to not use AltiVec predicate
      	framework.
      	(VCMPAEH_P): Likewise.
      	(VCMPAEW_P): Likewise.
      	(VCMPAED_P): Likewise.
      	(VCMPAEFP_P): Likewise.
      	(VCMPAEDP_P): Likewise.
      	(VCMPNE_P): Replace BU_P9V_OVERLOAD_P macro expansion with
      	BU_P9V_OVERLOAD_2 so that Power9 implementation of vec_all_ne does
      	not use the AltiVec predicate framework.
      	(VCMPAE_P): Add BU_P9V_OVERLOAD_2 macro to change implementation
      	of vec_any_eq to not use AltiVec predicate framework.
      	* config/rs6000/rs6000-c.c (rs6000_target_modify_macros): Add
      	support for predefined __POWER9_VECTOR__ macro to indicate that
      	Power9 instruction selection is enabled.
      	(altivec_overloaded_builtins): Remove extraneous
      	ALTIVEC_BUILTIN_VEC_CMPNE entry for overloaded
      	function argument types RS6000_BTI_bool_V16QI and
      	RS6000_BTI_bool_V16QI.  Remove erroneous ALTIVEC_BUILTIN_VEC_CMPNE
      	entry for overloaded function argument types RS6000_BTI_bool_V4SI
      	andRS6000_BTI_bool_V4SI, mapping to P9V_BUILTIN_CMPNEB.  Remove
      	two entries mapping to P9V_BUITIN_CMPNED and one entry mapping to
      	P9V_BUILTIN_CMPNEF to force use of instructions not specific to
      	Power9 for implementations of vec_cmpne.  Change the signature for
      	all definitions of the overloaded P9V_BUILTIN_VEC_CMPNE_P function
      	(representing vec_all_ne) to remove the previously described first
      	argument of type RS6000_BTI_INTSI, as this was an artifact of
      	reliance on the AltiVec predicate framework, which is no longer
      	used in the implementation of these functions.  Add
      	P9V_BUILTIN_VEC_VCMPAE_P entries (representing the vec_anyeq
      	function) to match all of the P9V_BUILTIN_VEC_VCMNE_P entries
      	since, unlike the AltiVec predicate framework implementation, we
      	do not share function descriptors between vec_alle and vec_anyeq.
      	(altivec_resolve_overloaded_builtin): Add SFmode and DFmode to the
      	set of modes that receive special treatment even when
      	TARGET_P9_VECTOR is true.  The special treatment emits code that
      	does not depend on Power9 instructions.
      	* config/rs6000/vector.md (vector_ne_<mode>_p): Change this
      	define_expand to not rely on AltiVec predicate framework.
      	(vector_ae_<mode>p): New define_expand to represent vec_any_eq
      	function.
      	(vector_ne_v2di_p): Change this define_expand to not rely on
      	AltiVec predicate framework.
      	(vector_ae_v2di_p): New define_expand to represent vec_any_eq
      	function.
      	(vector_ne_<mode>_p): Change this define_expand to not rely on
      	AltiVec predicate framework.
      	(vector_ae_<mode>p): New define_expand to represent vec_any_eq
      	function.
      	* config/rs6000/vsx.md (*vsx_ne_<mode>_p): For modes VSX_EXTRACT_I
      	(V16QI, V8HI, V4SI), correct a typo in the code emitted for this
      	define_insn pattern.
      	(*vsx_ne_<mode>_p): For modes VSX_F (V4SF and V2DF), remove this
      	define_insn pattern because the xvcmpne<VSs>. instruction is not
      	supported.
      	(vcmpne<VSs>): Remove this define_insn because xvcmpne<VSs>
      	instruction is not supported.
      
      gcc/testsuite/ChangeLog:
      
      2017-03-01  Kelvin Nilsen  <kelvin@gcc.gnu.org>
      
      	PR target/79395
      	* gcc.target/powerpc/vsu/vec-all-ne-10.c: Change scan-assembler
      	pattern to look for vcmpequd. instead of vcmpnew.
      	* gcc.target/powerpc/vsu/vec-all-ne-14.c: Likewise.
      	* gcc.target/powerpc/vsu/vec-all-ne-7.c: Change scan-assembler
      	pattern to look for xvcmpeqsp. instead of xvcmpnesp.
      	* gcc.target/powerpc/vsu/vec-all-ne-8.c: Change scan-assembler to
      	look for xvcmpeqdp. instead of xvcmpnedp.
      	* gcc.target/powerpc/vsu/vec-all-ne-9.c: Change scan-assembler to
      	look for vcmpequd. instead of vcmpnew.
      	* gcc.target/powerpc/vsu/vec-any-eq-10.c: Likewise.
      	* gcc.target/powerpc/vsu/vec-any-eq-14.c: Likewise.
      	* gcc.target/powerpc/vsu/vec-any-eq-7.c: Change scan-assembler to
      	look for xvcmpeqsp. instead of xvcmpnesp.
      	* gcc.target/powerpc/vsu/vec-any-eq-8.c: Change scan-assembler to
      	look for xvcmpeqdp. instead of xvcmpnedp.
      	* gcc.target/powerpc/vsu/vec-any-eq-9.c: Change scan-assembler to
      	look for vcmpequd. instead of vcmpnew.
      	* gcc.target/powerpc/vsu/vec-cmpne-8.c: Change scan-assembler to
      	look for vcmpeqsp instead of xvcmpnesp.
      	* gcc.target/powerpc/vsu/vec-cmpne-9.c: Change scan-assembler to
      	look for xvcmpeqdp instead of xvcmpnedp.
      
      From-SVN: r245811
      Kelvin Nilsen committed
    • documentation_hacking.xml: Tweak link to doxygen.org. · 00133e16
      	* doc/xml/manual/documentation_hacking.xml: Tweak link to
      	doxygen.org.
      
      From-SVN: r245808
      Gerald Pfeifer committed
    • * config/nvptx/nvptx.c: Include intl.h. · 50c620ca
      From-SVN: r245806
      Jakub Jelinek committed
    • [PR 78140] Reuse same IPA bits and VR info · 86cd0334
      2017-03-01  Martin Jambor  <mjambor@suse.cz>
      
      	PR lto/78140
      	* ipa-prop.h (ipa_bits): Removed field known.
      	(ipa_jump_func): Removed field vr_known.  Changed fields bits and m_vr
      	to pointers.  Adjusted their comments to warn about their sharing.
      	(ipcp_transformation_summary): Change bits to a vector of pointers.
      	(ipa_check_create_edge_args): Moved to ipa-prop.c, declare.
      	(ipa_get_ipa_bits_for_value): Declare.
      	* tree-vrp.h (value_range): Mark as GTY((for_user)).
      	* ipa-prop.c (ipa_bit_ggc_hash_traits): New.
      	(ipa_bits_hash_table): Likewise.
      	(ipa_vr_ggc_hash_traits): Likewise.
      	(ipa_vr_hash_table): Likewise.
      	(ipa_print_node_jump_functions_for_edge): Adjust for bits and m_vr
      	being pointers and vr_known being removed.
      	(ipa_set_jf_unknown): Likewise.
      	(ipa_get_ipa_bits_for_value): New function.
      	(ipa_set_jfunc_bits): Likewise.
      	(ipa_get_value_range): New overloaded functions.
      	(ipa_set_jfunc_vr): Likewise.
      	(ipa_compute_jump_functions_for_edge): Use the above functions to
      	construct bits and vr parts of jump functions.
      	(ipa_check_create_edge_args): Move here from ipa-prop.h, also allocate
      	ipa_bits_hash_table and ipa_vr_hash_table if they do not already
      	exist.
      	(ipcp_grow_transformations_if_necessary): Also allocate
      	ipa_bits_hash_table and ipa_vr_hash_table if they do not already
      	exist.
      	(ipa_node_params_t::duplicate): Do not copy bits, just pointers to
      	them.  Fix too long lines.
      	(ipa_write_jump_function): Adjust for bits and m_vr being pointers and
      	vr_known being removed.
      	(ipa_read_jump_function): Use new setter functions to construct bits
      	and vr parts of jump functions or set them to NULL.
      	(write_ipcp_transformation_info): Adjust for bits being pointers.
      	(read_ipcp_transformation_info): Likewise.
      	(ipcp_update_bits): Likewise.  Fix excessively long lines a trailing
      	space.
      	Include gt-ipa-prop.h.
      	* ipa-cp.c (propagate_bits_across_jump_function): Adjust for bits
      	being pointers.
      	(ipcp_store_bits_results): Likewise.
      	(propagate_vr_across_jump_function): Adjust for m_vr being a pointer.
      	Do not write to existing jump functions but use a temporary instead.
      
      From-SVN: r245805
      Martin Jambor committed