1. 08 Oct, 2018 5 commits
    • re PR c++/71128 ([concepts] ICE on ill-formed explicit instantiation of a function concept) · a52cdecf
      /cp
      2018-10-08  Paolo Carlini  <paolo.carlini@oracle.com>
      
      	PR c++/71128
      	* pt.c (do_decl_instantiation): Per 12.6.8/5, a concept cannot be
      	explicitly instantiated.
      
      /testsuite
      2018-10-08  Paolo Carlini  <paolo.carlini@oracle.com>
      
      	PR c++/71128
      	* g++.dg/concepts/pr71128.C: New.
      
      From-SVN: r264914
      Paolo Carlini committed
    • Don't ICE on vectors of enums (PR 87286) · 8656dafa
      We've traditionally allowed vectors of enums (not sure if that's
      deliberate) but vector_types_compatible_elements_p checked for
      INTEGER_TYPE rather than INTEGRAL_TYPE_P.
      
      2018-10-08  Richard Sandiford  <richard.sandiford@arm.com>
      
      gcc/c-family/
      	PR c/87286
      	* c-common.c (vector_types_compatible_elements_p): Use
      	INTEGRAL_TYPE_P instead of checking only for INTEGER_TYPE.
      
      gcc/testsuite/
      	PR c/87286
      	* gcc.dg/pr87286.c: New test.
      
      From-SVN: r264913
      Richard Sandiford committed
    • re PR middle-end/63155 (memory hog) · 09068087
      2018-10-08  Richard Biener  <rguenther@suse.de>
      
      	PR tree-optimization/63155
      	* tree-ssa-propagate.c (add_ssa_edge): Do cheap check first.
      	(ssa_propagation_engine::ssa_propagate): Remove redundant
      	bitmap bit clearing.
      
      From-SVN: r264912
      Richard Biener committed
    • list (list<>::cbegin()): Use C++11 direct initialization. · edec2bad
      2018-10-08  François Dumont  <fdumont@gcc.gnu.org>
      
      	* include/debug/list (list<>::cbegin()): Use C++11 direct
      	initialization.
      	(list<>::cend()): Likewise.
      	(list<>::emplace<>(const_iterator, _Args&&...)): Likewise.
      	(list<>::insert(const_iterator, initializer_list<>)): Likewise.
      	(list<>::insert(const_iterator, size_type, const _Tp&)): Likewise.
      	(list<>::erase(const_iterator, const_iterator)): Ensure consistent
      	iterator comparisons.
      	(list<>::splice(const_iterator, list&&, const_iterator,
      	const_iterator)): Likewise.
      
      From-SVN: r264911
      François Dumont committed
    • Daily bump. · c0485831
      From-SVN: r264910
      GCC Administrator committed
  2. 07 Oct, 2018 1 commit
  3. 06 Oct, 2018 6 commits
    • Use gfc_charlen_type instead of int for string lenghts · c0ab1530
      This patch cleans up a few places where I noticed the code was still
      using int instead gfc_charlen_type for string lengths.  Regtested on
      x86_64-pc-linux-gnu, committed as obvious.
      
      libgfortran/ChangeLog:
      
      2018-10-06  Janne Blomqvist  <jb@gcc.gnu.org>
      
      	* io/unix.c (compare_file_filename): Use gfc_charlen_type instead
      	of int for string length.
      	(inquire_sequential): Likewise.
      	(inquire_direct): Likewise.
      	(inquire_formatted): Likewise.
      	(inquire_unformatted): Likewise.
      	(inquire_access): Likewise.
      	(inquire_read): Likewise.
      	(inquire_write): Likewise.
      	(inquire_readwrite): Likewise.
      	* io/unix.h (compare_file_filename): Likewise.
      	(inquire_sequential): Likewise.
      	(inquire_direct): Likewise.
      	(inquire_formatted): Likewise.
      	(inquire_unformatted): Likewise.
      	(inquire_read): Likewise.
      	(inquire_write): Likewise.
      	(inquire_readwrite): Likewise.
      
      From-SVN: r264901
      Janne Blomqvist committed
    • re PR fortran/86111 (ICE in gfc_arith_concat, at fortran/arith.c:985) · 7318fdca
      2018-10-06  Thomas Koenig  <tkoenig@gcc.gnu.org>
      
      	PR fortran/86111
      	* gfortran.h (enum arith): Add ARITH_WRONGCONCAT.
      	* arith.h (gfc_arith_error): Issue error for ARITH_WRONGCONCAT.
      	(gfc_arith_concat):  If the types of op1 and op2 are not
      	character of if their kinds do not match, issue ARITH_WRONGCONCAT.
      
      2018-10-06  Thomas Koenig  <tkoenig@gcc.gnu.org>
      
      	PR fortran/86111
      	* gfortran.dg/array_constructor_type_23.f90: New test.
      
      From-SVN: r264900
      Thomas Koenig committed
    • re PR fortran/83999 (ICE in gfc_trans_assignment_1, at fortran/trans-expr.c:10233) · 2b03b800
      2018-10-06  Paul Thomas  <pault@gcc.gnu.org>
      
      	PR fortran/83999
      	* resolve.c (resolve_fl_procedure): Include class functions in
      	the test that elemental function results be scalar.
      
      2018-10-06  Paul Thomas  <pault@gcc.gnu.org>
      
      	PR fortran/83999
      	* gfortran.dg/elemental_function_4.f90 : New test.
      
      From-SVN: r264899
      Paul Thomas committed
    • re PR fortran/84640 (gcc/fortran/simplify.c:2587:9: runtime error: pointer index… · f64b9ed9
      re PR fortran/84640 (gcc/fortran/simplify.c:2587:9: runtime error: pointer index expression with base 0x0000090de160 overflowed to 0xffffffffc0632960)
      
       2018-10-06  Thomas Koenig  <tkoenig@gcc.gnu.org>
      
      	PR fortran/84640
      	* simplify.c (gfc_simplify_cshift): Extend size of hs_ex and ss_ex
      	by one. Set extents one past the array boundaries to zero to avoid
      	warning with instrumented compiler.
      	(gfc_simplify_eoshift): Likewise, only for ss_ex.
      
      From-SVN: r264898
      Thomas Koenig committed
    • re PR rtl-optimization/86939 (IRA incorrectly creates an interference between a… · a141f2d8
      re PR rtl-optimization/86939 (IRA incorrectly creates an interference between a pseudo register and a hard register)
      
      gcc/
      	PR rtl-optimization/86939
      	PR rtl-optimization/87479
      	* ira.h (non_conflicting_reg_copy_p): New prototype.
      	* ira-lives.c (ignore_reg_for_conflicts): New static variable.
      	(make_hard_regno_dead): Don't add conflicts for register
      	ignore_reg_for_conflicts.
      	(make_object_dead): Likewise.
      	(non_conflicting_reg_copy_p): New function.
      	(process_bb_node_lives): Set ignore_reg_for_conflicts for copies.
      	Remove special conflict handling of REAL_PIC_OFFSET_TABLE_REGNUM.
      	* lra-lives.c (ignore_reg_for_conflicts): New static variable.
      	(make_hard_regno_dead): Don't add conflicts for register
      	ignore_reg_for_conflicts.  Remove special conflict handling of
      	REAL_PIC_OFFSET_TABLE_REGNUM.  Remove now unused argument
      	check_pic_pseudo_p and update callers.
      	(mark_pseudo_dead): Don't add conflicts for register
      	ignore_reg_for_conflicts.
      	(process_bb_lives): Set ignore_reg_for_conflicts for copies.
      
      gcc/testsuite/
      	PR rtl-optimization/86939
      	PR rtl-optimization/87479
      	* gcc.target/powerpc/pr86939.c: New test.
      	* gcc/testsuite/gcc.target/i386/pr49095.c: Fix expected results.
      
      From-SVN: r264897
      Peter Bergner committed
    • Daily bump. · fb6f9bbc
      From-SVN: r264896
      GCC Administrator committed
  4. 05 Oct, 2018 24 commits
    • RISC-V: Fix -fsignaling-nans for glibc testsuite. · 1fcbfb00
      	gcc/
      	* config/riscv/riscv.md (f<quiet_pattern>_quiet<ANYF:mode><X:mode>4):
      	Add define_expand.  Add ! HONOR_SNANS check to current pattern.  Add
      	new pattern using HONOR_SNANS that emits one extra instruction.
      
      Co-Authored-By: Jim Wilson <jimw@sifive.com>
      
      From-SVN: r264892
      Andrew Waterman committed
    • rs6000: Some mfcr pattern simplification · a3a81f29
      
      	* config/rs6000/rs6000.md (unnamed mfcr scc_comparison_operator
      	patterns): Merge SI and DI patterns to a GPR pattern.
      	(unnamed define_insn and define_split for record form of that): Merge
      	to a single define_insn_and_split pattern.
      
      From-SVN: r264889
      Segher Boessenkool committed
    • string_merge1.adb: Fix test expectations. · c1ec62f1
      2018-10-05  Bernd Edlinger  <bernd.edlinger@hotmail.de>
      
              * gnat.dg/string_merge1.adb: Fix test expectations.
              * gnat.dg/string_merge2.adb: Likewise.
      
      From-SVN: r264888
      Bernd Edlinger committed
    • Support string locations for C++ in -Wformat (PR c++/56856) · 0d48e877
      -Wformat in the C++ FE doesn't work as well as it could:
      (a) it doesn't report precise locations within the string literal, and
      (b) it doesn't underline arguments for those arguments !CAN_HAVE_LOCATION_P,
      despite having location wrapper nodes.
      
      For example:
      
        Wformat-ranges.C:32:10: warning: format '%s' expects argument of type 'char*', but argument 2 has type 'int' [-Wformat=]
        32 |   printf("hello %s", 42);
           |          ^~~~~~~~~~
      
      (a) is due to not wiring up the langhook for extracting substring
          locations.
      
          This patch uses the one in c-family; it also fixes string literal
          parsing so that it records string concatenations (needed for
          extracting substring locations from concatenated strings).
      
      (b) is due to the call to maybe_constant_value here:
             fargs[j] = maybe_constant_value (argarray[j]);
          within build_over_call.
      
          The patch fixes this by building a vec of location_t values when
          calling check_function_arguments.
          I attempted to eliminate the maybe_constant_value call here, but
          it's needed by e.g. check_function_sentinel for detecting NULL,
          and that code is in "c-family", so it can't simply call into
          maybe_constant_value (which is in "cp").
      
      With this patch, the output for the above example is improved to:
      
        Wformat-ranges.C:32:18: warning: format '%s' expects argument of type 'char*', but argument 2 has type 'int' [-Wformat=]
        32 |   printf("hello %s", 42);
           |                 ~^   ~~
           |                  |   |
           |                  |   int
           |                  char*
           |                 %d
      
      gcc/cp/ChangeLog:
      	PR c++/56856
      	* call.c (build_over_call): Build a vec of locations of the
      	arguments before the call to maybe_constant_value, and pass to
      	check_function_arguments.
      	* cp-lang.c (LANG_HOOKS_GET_SUBSTRING_LOCATION): Define as
      	c_get_substring_location.
      	* parser.c (cp_parser_string_literal): Capture string
      	concatenation locations.
      
      gcc/ChangeLog:
      	PR c++/56856
      	* input.c (expand_location_to_spelling_point): Add param "aspect"
      	and use rather than hardcoding LOCATION_ASPECT_CARET.
      	(get_substring_ranges_for_loc): Handle the case of a single token
      	within a macro expansion.
      	* input.h (expand_location_to_spelling_point): Add "aspect" param,
      	defaulting to LOCATION_ASPECT_CARET.
      
      gcc/testsuite/ChangeLog:
      	PR c++/56856
      	* g++.dg/ext/builtin4.C: Set expected location for warning to the
      	correct location within the format string.
      	* g++.dg/plugin/plugin.exp (plugin_test_list): Add the plugin and
      	files for testing locations within string literal locations from
      	the C frontend.
      	* g++.dg/warn/Wformat-method.C: New test.
      	* g++.dg/warn/Wformat-pr71863.C: New test.
      	* g++.dg/warn/Wformat-ranges-c++11.C: New test.
      	* g++.dg/warn/Wformat-ranges.C: New test, based on
      	gcc.dg/format/diagnostic-ranges.c.
      	* gcc.dg/plugin/diagnostic-test-string-literals-1.c
      	(test_multitoken_macro): Generalize expected output to work with
      	both C and C++.
      	* gcc.dg/plugin/diagnostic-test-string-literals-2.c
      	(test_stringified_token_1): Likewise.
      	(test_stringified_token_3): Likewise.
      
      From-SVN: r264887
      David Malcolm committed
    • * config/i386/i386.md: Reorder cmpi patterns. · 1f58c814
      From-SVN: r264886
      Uros Bizjak committed
    • i386.md (*cmpxf_cc_i387): Remove pattern. · 874761d2
      	* config/i386/i386.md (*cmpxf_cc_i387): Remove pattern.
      	(*cmp<mode>_cc_i387): Ditto.
      	(*cmpu<mode>_cc_i387): Ditto.
      	(*cmp<X87MODEF:mode>_<SWI24:mode>_cc_i387): Ditto.
      	* config/i386/i386.c (ix86_expand_fp_compare): Remove
      	"scratch" argument.
      	<case IX86_FPCMP_SAHF>: Do not generate pattern with HImode clobber.
      	Emit x86_sahf_1 pattern.
      	(ix86_expand_compare): Update call to ix86_expand_fp_compare.
      	(ix86_expand_carry_flag_compare): Ditto.
      
      From-SVN: r264884
      Uros Bizjak committed
    • Add some pdp11 target hook definitions for C++ · 7717110a
          * config/pdp11/pdp11.c (TARGET_CXX_GUARD_TYPE): Define.
          (TARGET_CXX_CLASS_DATA_ALWAYS_COMDAT): Define.
          (TARGET_CXX_LIBRARY_RTTI_COMDAT): Define.
          (pdp11_guard_type): New function.
      
      From-SVN: r264883
      Paul Koning committed
    • libgo: use inline assembly in favor of call to _xgetbv() · 7fc9c2e5
          
          Use inline assembly in the implementation of internal_cpu.xgetbv as
          opposed to a call to the intrinsic _xgetbv(), since non-gcc compilers
          (e.g. clang) may or may not have support for it.
          
          Reviewed-on: https://go-review.googlesource.com/c/140137
      
      From-SVN: r264882
      Ian Lance Taylor committed
    • Remove -mfloat32, -mfloat64 switches from pdp11 target. · d5a98955
          * config/pdp11/pdp11.h (FLOAT_TYPE_SIZE): Always 32.
          * config/pdp11/pdp11.opt (mfloat32): Remove.
          (mfloat64): Remove.
          * doc/invoke.texi (pdp11 -mfloat32): Remove:
          (pdp11 -mfloat64): Remove.
      
      From-SVN: r264881
      Paul Koning committed
    • testsuite: multiline.exp: implement optional target/xfail selector · 9a85d982
      gcc/testsuite/ChangeLog:
      	* lib/multiline.exp (proc dg-end-multiline-output): Check argument
      	count.  If there's a 3rd argument, use dg-process-target on it,
      	bailing out, or recording expected failures as "maybe_x".
      	(proc handle-multiline-outputs): Extract "maybe_x", and use it
      	to convert pass/fail into xpass/xfail.
      
      From-SVN: r264880
      David Malcolm committed
    • i386.md (*cmpxf_i387): Change operand 2 predicate to reg_or_0_operand. · 08993ffb
      	* config/i386/i386.md (*cmpxf_i387): Change operand 2 predicate
      	to reg_or_0_operand.  Add "C" constraint.
      	(*cmpxf_cc_i387): Ditto.
      	(*cmp<mode>_i387): Change operand 2 predicate
      	to nonimm_or_0_operand.  Add "C" constraint.
      	(*cmp<mode>_cc_i387): Ditto.
      	(*cmp<mode>_0_i387): Remove insn pattern.
      	(*cmp<mode>_0_cc_i387): Ditto.
      
      From-SVN: r264879
      Uros Bizjak committed
    • constraints.md ("C"): Do not depend on TARGET_SSE. · 808d8de5
      	* config/i386/constraints.md ("C"): Do not depend on TARGET_SSE.
      	* config/i386/predicates.md (nonimm_or_0_operand): Rename
      	from vector_move_operand.  Update all uses.
      
      From-SVN: r264877
      Uros Bizjak committed
    • PR tree-optimization/87490 - ICE in expand_builtin_strnlen with a constant… · f3431652
      PR tree-optimization/87490 - ICE in expand_builtin_strnlen with a constant argument and non-constant bound
      
      gcc/ChangeLog:
      
      	PR tree-optimization/87490
      	* builtins.c (expand_builtin_strnlen): Handle a null data.decl
      	consistently.
      
      gcc/testsuite/ChangeLog:
      
      	PR tree-optimization/87490
      	* gcc.dg/pr87490.c: New test.
      	* gcc.dg/warn-strnlen-no-nul-2.c: Same.
      
      From-SVN: r264876
      Martin Sebor committed
    • 2018-10-05 François Dumont <fdumont@gcc.gnu.org> · e0b9bc23
      	* include/bits/stl_tree.h
      	(_Rb_tree_iterator<>::operator==): Make inline friend.
      	(_Rb_tree_iterator<>::operator!=): Likewise.
      	(_Rb_tree_const_iterator<>::operator==): Likewise.
      	(_Rb_tree_const_iterator<>::operator!=): Likewise.
      	(operator==(const _Rb_tree_iterator<>&,
      	const _Rb_tree_const_iterator&)): Remove.
      	(operator!=(const _Rb_tree_iterator<>&,
      	const _Rb_tree_const_iterator&)): Remove.
      	(operator==(const _Rb_tree<>&, const _Rb_tree<>&)): Make inline friend.
      	(operator<(const _Rb_tree<>&, const _Rb_tree<>&)): Likewise.
      	(operator!=(const _Rb_tree<>&, const _Rb_tree<>&)): Likewise and
      	deprecate.
      	(operator>(const _Rb_tree<>&, const _Rb_tree<>&)): Likewise.
      	(operator<=(const _Rb_tree<>&, const _Rb_tree<>&)): Likewise.
      	(operator>=(const _Rb_tree<>&, const _Rb_tree<>&)): Likewise.
      	* include/debug/map.h (map<>::erase(const_iterator, const_iterator)):
      	Compare __victim with _Base::cend().
      	* include/debug/multimap.h
      	(multimap<>::erase(const_iterator, const_iterator)): Likewise.
      	* include/debug/set.h (set<>::erase(const_iterator, const_iterator)):
      	Compare __victim with _Base::cend().
      	* include/debug/multiset.h
      	(multiset<>::erase(const_iterator, const_iterator)): Likewise.
      
      From-SVN: r264875
      François Dumont committed
    • re PR tree-optimization/71625 (missing strlen optimization on different array initialization style) · 825e6458
      2018-10-05  Steve Ellcey  <sellcey@cavium.com>
      
      	PR tree-optimization/71625
      	* /gcc.target/aarch64/vclz.c (test_vclz_s8): Add noinline attribute.
      	(test_vclz_s16): Ditto.
      	(test_vclz_s32): Ditto.
      	(test_vclzq_s8): Ditto.
      	(test_vclzq_s16): Ditto.
      	(test_vclzq_s32): Ditto.
      	(test_vclz_u8): Ditto.
      	(test_vclz_u16): Ditto.
      	(test_vclz_u32): Ditto.
      	(test_vclzq_u8): Ditto.
      	(test_vclzq_u16): Ditto.
      	(test_vclzq_u32): Ditto.
      	* gcc.target/aarch64/vneg_s.c (test_vneg_s8): Ditto.
      	(test_vneg_s16): Ditto.
      	(test_vneg_s32): Ditto.
      	(test_vneg_s64): Ditto.
      	(test_vnegd_s64): Ditto.
      	(test_vnegq_s8): Ditto.
      	(test_vnegq_s16): Ditto.
      	(test_vnegq_s32): Ditto.
      	(test_vnegq_s64): Ditto.
      
      From-SVN: r264874
      Steve Ellcey committed
    • runtime: remove checkgoarm function · cbba2e1e
          
          Nothing in libgo calls checkgoarm, and it relies on a variable, goarm,
          that is not set.
          
          Reviewed-on: https://go-review.googlesource.com/c/140057
      
      From-SVN: r264872
      Ian Lance Taylor committed
    • re PR libbacktrace/87529 (libbacktrace API forces users to have memory leaks) · a2a86641
      	PR libbacktrace/87529
      	* backtrace.h: Document that backtrace_create_state should be
      	called only once.
      
      From-SVN: r264871
      Ian Lance Taylor committed
    • re PR middle-end/63155 (memory hog) · f48bd5e4
      2018-10-05  Richard Biener  <rguenther@suse.de>
      
      	PR tree-optimization/63155
      	* tree-ssa-ccp.c (ccp_propagate::visit_phi): Avoid excess
      	vertical space in dumpfiles.
      	* tree-ssa-propagate.h
      	(ssa_propagation_engine::process_ssa_edge_worklist): Remove.
      	* tree-ssa-propagate.c (cfg_blocks_back): New global.
      	(ssa_edge_worklist_back): Likewise.
      	(curr_order): Likewise.
      	(cfg_blocks_get): Remove abstraction.
      	(cfg_blocks_add): Likewise.
      	(cfg_blocks_empty_p): Likewise.
      	(add_ssa_edge): Add to current or next worklist based on
      	RPO index.
      	(add_control_edge): Likewise.
      	(ssa_propagation_engine::process_ssa_edge_worklist): Fold
      	into ...
      	(ssa_propagation_engine::ssa_propagate): ... here.  Unify
      	iteration from CFG and SSA edge worklist so we process
      	everything in RPO order, prioritizing forward progress
      	over iteration.
      	(ssa_prop_init): Allocate new worklists, do not dump
      	immediate uses.
      	(ssa_prop_fini): Free new worklists.
      
      From-SVN: r264869
      Richard Biener committed
    • tree-core.h (tree_block::abstract_flag): Remove. · 700adeb6
      2018-10-05  Richard Biener  <rguenther@suse.de>
      
      	* tree-core.h (tree_block::abstract_flag): Remove.
      	(tree_block::block_num): Make full 32bits.
      	* tree.def (BLOCK): Remove docs about BLOCK_ABSTRACT.
      	* tree.h (BLOCK_ABSTRACT): Remove.
      	* dwarf2out.c (gen_lexical_block_die): Remove dead code
      	resulting from BLOCK_ABSTRACT being always false.
      	(gen_inlined_subroutine_die): Likewise.
      	(gen_block_die): Likewise.
      	* tree.c (block_ultimate_origin): Likewise.
      	* tree-pretty-print.c (dump_block_node): Remove code dealing
      	with BLOCK_ABSTRACT.
      	* tree-ssa-live.c (dump_scope_block): Likewise.
      	* tree-streamer-in.c (unpack_ts_block_value_fields): Likewise.
      	* tree-streamer-out.c (pack_ts_block_value_fields): Likewise.
      
      From-SVN: r264868
      Richard Biener committed
    • i386.c (ix86_add_stmt_cost): When scalar cost is asked for initialize mode to… · 3f41c986
      i386.c (ix86_add_stmt_cost): When scalar cost is asked for initialize mode to the component mode of the...
      
      2018-10-05   Richard Biener  <rguenther@suse.de>
      
      	* config/i386/i386.c (ix86_add_stmt_cost): When scalar cost
      	is asked for initialize mode to the component mode of the
      	vector type.
      
      From-SVN: r264866
      Richard Biener committed
    • i386: Don't pass -msse2avx to assembler for -mavx · ae36de91
      With
      
      gcc -O2 -fPIC -flto -g -c -o a.o a.c
      gcc -O2 -fPIC -flto -g -mavx   -c -o b.o b.c
      gcc -shared -O2 -fPIC -flto -g -o lib1.so a.o b.o
      
      LTO correctly generates AVX for b.o and SSE for a.o.  But the GCC driver
      passes -msse2avx to assembler, which encodes SSE instructions as AVX
      instructions.  We shouldn't pass -msse2avx to assembler for -mavx.
      
      	PR target/87522
      	* config/i386/gnu-user.h (ASM_SPEC): Don't pass -msse2avx to
      	assembler for -mavx.
      	* config/i386/gnu-user64.h (ASM_SPEC): Likewise.
      
      From-SVN: r264864
      H.J. Lu committed
    • rs6000: Various fixes for the new fpscr builtins (PR87509) · 49022a8b
      With these fixes all testcases test clean for me, both on
      powerpc64-linux {-m32,-m64} and on powerpc64le-linux, with all
      relevant -mcpu= settings.
      
      
      	PR target/87509
      	* config/rs6000/rs6000-builtin.def (RS6000_BUILTIN_SET_FPSCR_DRN): Use
      	RS6000_BTM_DFP.
      	* config/rs6000/rs6000.md (rs6000_set_fpscr_rn): Require the operand
      	to be DImode.  When using mffscrn, force the operand to a register.
      
      gcc/testsuite/
      	PR target/87509
      	* gcc.target/powerpc/test_fpscr_drn_builtin.c: Use hard_dfp instead
      	of dfp_hw.  Don't include <altivec.h>.
      	* gcc.target/powerpc/test_fpscr_drn_builtin_error.c: Ditto.  Require
      	lp64.
      	* gcc.target/powerpc/test_fpscr_rn_builtin.c: Don't include <altivec.h>.
      	* gcc.target/powerpc/test_fpscr_rn_builtin_error.c: Ditto.
      	* gcc.target/powerpc/test_mffsl.c: Ditto.
      
      From-SVN: r264863
      Segher Boessenkool committed
    • re PR testsuite/87487 (New test case gfortran.dg/deferred_character_24.f90 in… · 3665f77c
      re PR testsuite/87487 (New test case gfortran.dg/deferred_character_24.f90 in r264721 fails on big endian)
      
      2018-10-05  Paul Thomas  <pault@gcc.gnu.org>
      
      	PR fortran/87487
      	* trans-decl.c (gfc_get_symbol_decl): Make sure that deferred
      	character length pointer initializer has the right type to fix
      	problem with deferred_character_24.f90 on big endian.
      
      From-SVN: r264862
      Paul Thomas committed
    • Daily bump. · 1afa270f
      From-SVN: r264860
      GCC Administrator committed
  5. 04 Oct, 2018 4 commits
    • contrib: unused_functions.py: Handle archives · 0448002b
      one can now use verbatim the arguments used by the driver invocation to
      link e.g. cc1.
      
      2018-10-04  Bernhard Reutner-Fischer  <aldot@gcc.gnu.org>
      
      	* unused_functions.py: Handle archive files.
      
      From-SVN: r264856
      Bernhard Reutner-Fischer committed
    • i386.md (*fop_<X87MODEF:mode>_2_i387): Macroize insn from… · f556d6b5
      i386.md (*fop_<X87MODEF:mode>_2_i387): Macroize insn from *fop_<MODEF:mode>_2_i387 and *fop_xf_2_i387 using X87MODEF...
      
      	* config/i386/i386.md (*fop_<X87MODEF:mode>_2_i387): Macroize insn
      	from *fop_<MODEF:mode>_2_i387 and *fop_xf_2_i387 using
      	X87MODEF mode iterator.
      	(*fop_<X87MODEF:mode>_3_i387): Macroize insn from
      	*fop_<MODEF:mode>_3_i387 and *fop_xf_3_i387 using
      	X87MODEF mode iterator.
      
      From-SVN: r264855
      Uros Bizjak committed
    • invoke.texi (-Wno-prio-ctor-dtor): Document new warning -Wno-prio-ctor-dtor. · 8cff0652
      	* doc/invoke.texi (-Wno-prio-ctor-dtor): Document new warning
      	-Wno-prio-ctor-dtor.
      
      	* c-attribs.c (get_priority): Add a warning flag warn_prio_ctor_dtor
      	to generate constructor destructor priority warning.
      	* c.opt (-Wprio-ctor-dtor): New option.
      
      	* c-c++-common/Wprio-ctor-dtor.c: New test.
      
      From-SVN: r264853
      Vinay Kumar committed
    • Report vectorization problems via a new opt_problem class · f4ebbd24
      This is v3 of the patch; previous versions were:
        v2: https://gcc.gnu.org/ml/gcc-patches/2018-07/msg00446.html
        v1: https://gcc.gnu.org/ml/gcc-patches/2018-06/msg01462.html
      
      This patch introduces a class opt_problem, along with wrapper
      classes for bool (opt_result) and for pointers (e.g. opt_loop_vec_info
      for loop_vec_info).
      
      opt_problem instances are created when an optimization problem
      is encountered, but only if dump_enabled_p.  They are manually
      propagated up the callstack, and are manually reported at the
      "top level" of an optimization if dumping is enabled, to give the user
      a concise summary of the problem *after* the failure is reported.
      In particular, the location of the problematic statement is
      captured and emitted, rather than just the loop's location.
      
      For example:
      
      no-vfa-vect-102.c:24:3: missed: couldn't vectorize loop
      no-vfa-vect-102.c:27:7: missed: statement clobbers memory: __asm__ __volatile__("" :  :  : "memory");
      
      Changed in v3:
      * This version bootstraps and passes regression testing (on
        x86_64-pc-linux-gnu).
      * added selftests, to exercise the opt_problem machinery
      * removed the "bool to opt_result" ctor, so that attempts to
        use e.g. return a bool from an opt_result-returning function
        will fail at compile time
      * use formatted printing within opt_problem ctor to replace the
        various dump_printf_loc calls
      * dropped i18n
      * changed the sense of vect_analyze_data_ref_dependence's return
        value (see the ChangeLog)
      * add MSG_PRIORITY_REEMITTED, so that -fopt-info can show the
        messages, without them messing up the counts in scan-tree-dump-times
        in DejaGnu tests
      
      gcc/ChangeLog:
      	* Makefile.in (OBJS): Add opt-problem.o.
      	* dump-context.h: Include "selftest.h.
      	(selftest::temp_dump_context): New forward decl.
      	(class dump_context): Make friend of class
      	selftest::temp_dump_context.
      	(dump_context::dump_loc_immediate): New decl.
      	(class dump_pretty_printer): Move here from dumpfile.c.
      	(class temp_dump_context): Move to namespace selftest.
      	(temp_dump_context::temp_dump_context): Add param
      	"forcibly_enable_dumping".
      	(selftest::verify_dumped_text):
      	(ASSERT_DUMPED_TEXT_EQ): Move here from dumpfile.c.
      	(selftest::verify_item):
      	(ASSERT_IS_TEXT): Move here from dumpfile.c.
      	(ASSERT_IS_TREE): Likewise.
      	(ASSERT_IS_GIMPLE): Likewise.
      	* dumpfile.c (dump_context::dump_loc): Move immediate dumping
      	to...
      	(dump_context::dump_loc_immediate): ...this new function.
      	(class dump_pretty_printer): Move to dump-context.h.
      	(dump_switch_p_1): Don't enable MSG_PRIORITY_REEMITTED.
      	(opt_info_switch_p_1): Enable MSG_PRIORITY_REEMITTED.
      	(temp_dump_context::temp_dump_context): Move to "selftest"
      	namespace.  Add param "forcibly_enable_dumping", and use it to
      	conditionalize the use of m_pp;
      	(selftest::verify_dumped_text): Make non-static.
      	(ASSERT_DUMPED_TEXT_EQ): Move to dump-context.h.
      	(selftest::verify_item): Make non-static.
      	(ASSERT_IS_TEXT): Move to dump-context.h.
      	(ASSERT_IS_TREE): Likewise.
      	(ASSERT_IS_GIMPLE): Likewise.
      	(selftest::test_capture_of_dump_calls): Pass "true" for new
      	param of temp_dump_context.
      	* dumpfile.h (enum dump_flag): Add MSG_PRIORITY_REEMITTED, adding
      	it to MSG_ALL_PRIORITIES.  Update values of TDF_COMPARE_DEBUG and
      	TDF_COMPARE_DEBUG.
      	* opt-problem.cc: New file.
      	* opt-problem.h: New file.
      	* optinfo-emit-json.cc
      	(selftest::test_building_json_from_dump_calls): Pass "true" for
      	new param of temp_dump_context.
      	* optinfo.cc (optinfo_kind_to_dump_flag): New function.
      	(optinfo::emit_for_opt_problem): New function.
      	(optinfo::emit): Clarity which emit_item is used.
      	* optinfo.h (optinfo::get_dump_location): New accessor.
      	(optinfo::emit_for_opt_problem): New decl.
      	(optinfo::emit): Make const.
      	* selftest-run-tests.c (selftest::run_tests): Call
      	selftest::opt_problem_cc_tests.
      	* selftest.h (selftest::opt_problem_cc_tests): New decl.
      	* tree-data-ref.c (dr_analyze_innermost): Convert return type from
      	bool to opt_result, converting fprintf messages to
      	opt_result::failure_at calls.  Add "stmt" param for use by the
      	failure_at calls.
      	(create_data_ref): Pass "stmt" to the dr_analyze_innermost call.
      	(runtime_alias_check_p): Convert return type from bool to
      	opt_result, converting dump_printf calls to
      	opt_result::failure_at, using the statement DDR_A for their
      	location.
      	(find_data_references_in_stmt): Convert return type from bool to
      	opt_result, converting "return false" to opt_result::failure_at
      	with a new message.
      	* tree-data-ref.h: Include "opt-problem.h".
      	(dr_analyze_innermost): Convert return type from bool to opt_result,
      	and add a const gimple * param.
      	(find_data_references_in_stmt): Convert return type from bool to
      	opt_result.
      	(runtime_alias_check_p): Likewise.
      	* tree-predcom.c (find_looparound_phi): Pass "init_stmt" to
      	dr_analyze_innermost.
      	* tree-vect-data-refs.c (vect_mark_for_runtime_alias_test):
      	Convert return type from bool to opt_result, adding a message for
      	the PARAM_VECT_MAX_VERSION_FOR_ALIAS_CHECKS zero case.
      	(vect_analyze_data_ref_dependence): Convert return type from bool
      	to opt_result.  Change sense of return type from "false"
      	effectively meaning "no problems" to "false" meaning a problem,
      	so that "return false" becomes "return opt_result::success".
      	Convert "return true" calls to opt_result::failure_at, using
      	the location of statement A rather than vect_location.
      	(vect_analyze_data_ref_dependences): Convert return type from bool
      	to opt_result.
      	(verify_data_ref_alignment): Likewise, converting dump_printf_loc
      	calls to opt_result::failure_at, using the stmt location rather
      	than vect_location.
      	(vect_verify_datarefs_alignment): Convert return type from bool
      	to opt_result.
      	(vect_enhance_data_refs_alignment): Likewise.  Split local "stat"
      	into multiple more-tightly-scoped copies.
      	(vect_analyze_data_refs_alignment): Convert return type from bool
      	to opt_result.
      	(vect_analyze_data_ref_accesses): Likewise, converting a
      	"return false" to a "return opt_result::failure_at", adding a
      	new message.
      	(vect_prune_runtime_alias_test_list): Convert return type from
      	bool to opt_result, converting dump_printf_loc to
      	opt_result::failure_at.  Add a %G to show the pertinent statement,
      	and use the stmt's location rather than vect_location.
      	(vect_find_stmt_data_reference): Convert return type from
      	bool to opt_result, converting dump_printf_loc to
      	opt_result::failure_at, using stmt's location.
      	(vect_analyze_data_refs):  Convert return type from bool to
      	opt_result.  Convert "return false" to "return
      	opt_result::failure_at", adding messages as needed.
      	* tree-vect-loop.c (vect_determine_vf_for_stmt_1): Convert return
      	type from bool to opt_result.
      	(vect_determine_vf_for_stmt): Likewise.
      	(vect_determine_vectorization_factor): Likewise, converting
      	dump_printf_loc to opt_result::failure_at, using location of phi
      	rather than vect_location.
      	(vect_analyze_loop_form_1): Convert return type from bool to
      	opt_result, converting dump_printf_loc calls, retaining the use of
      	vect_location.
      	(vect_analyze_loop_form): Convert return type from loop_vec_info
      	to opt_loop_vec_info.
      	(vect_analyze_loop_operations): Convert return type from bool to
      	opt_result, converting dump_printf_loc calls, using the location
      	of phi/stmt rather than vect_location where available.  Convert
      	various "return false" to "return opt_result::failure_at" with
      	"unsupported phi" messages.
      	(vect_get_datarefs_in_loop): Convert return type from bool to
      	opt_result.  Add a message for the
      	PARAM_LOOP_MAX_DATAREFS_FOR_DATADEPS failure.
      	(vect_analyze_loop_2): Convert return type from bool to
      	opt_result.  Ensure "ok" is set to a opt_result::failure_at before
      	each "goto again;", adding new messages where needed.
      	Add "unsupported grouped {store|load}" messages.
      	(vect_analyze_loop): Convert return type from loop_vec_info to
      	opt_loop_vec_info.
      	* tree-vect-slp.c (vect_analyze_slp): Convert return type from
      	bool to opt_result.
      	* tree-vect-stmts.c (process_use): Likewise, converting
      	dump_printf_loc call and using stmt location, rather than
      	vect_location.
      	(vect_mark_stmts_to_be_vectorized): Likeise.
      	(vect_analyze_stmt): Likewise, adding a %G.
      	(vect_get_vector_types_for_stmt): Convert return type from bool to
      	opt_result, converting dump_printf_loc calls and using stmt
      	location, rather than vect_location.
      	(vect_get_mask_type_for_stmt): Convert return type from tree to
      	opt_tree, converting dump_printf_loc calls and using stmt location.
      	* tree-vectorizer.c: Include "opt-problem.h.
      	(try_vectorize_loop_1): Flag "Analyzing loop at" dump message as
      	MSG_PRIORITY_INTERNALS.  Convert local "loop_vinfo" from
      	loop_vec_info to opt_loop_vec_info.  If if fails, and dumping is
      	enabled, use it to report at the top level "couldn't vectorize
      	loop" followed by the problem.
      	* tree-vectorizer.h (opt_loop_vec_info): New typedef.
      	(vect_mark_stmts_to_be_vectorized): Convert return type from bool
      	to opt_result.
      	(vect_analyze_stmt): Likewise.
      	(vect_get_vector_types_for_stmt): Likewise.
      	(tree vect_get_mask_type_for_stmt): Likewise.
      	(vect_analyze_data_ref_dependences): Likewise.
      	(vect_enhance_data_refs_alignment): Likewise.
      	(vect_analyze_data_refs_alignment): Likewise.
      	(vect_verify_datarefs_alignment): Likewise.
      	(vect_analyze_data_ref_accesses): Likewise.
      	(vect_prune_runtime_alias_test_list): Likewise.
      	(vect_find_stmt_data_reference): Likewise.
      	(vect_analyze_data_refs): Likewise.
      	(vect_analyze_loop): Convert return type from loop_vec_info to
      	opt_loop_vec_info.
      	(vect_analyze_loop_form): Likewise.
      	(vect_analyze_slp): Convert return type from bool to opt_result.
      
      gcc/testsuite/ChangeLog:
      	* gcc.dg/vect/nodump-vect-opt-info-2.c: New test.
      	* gcc.dg/vect/vect-alias-check-4.c: Add "-fopt-info-vec-all" to
      	dg-additional-options.  Add dg-message and dg-missed directives
      	to verify that -fopt-info messages are written at the correct
      	locations.
      
      From-SVN: r264852
      David Malcolm committed