1. 08 Oct, 2018 18 commits
  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 15 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