1. 16 Nov, 2016 8 commits
    • Fix missing brackets in arc.c · f857b8ef
      The old code still built thanks to the brackets in the definition
      of XVECEXP.
      
      gcc/
      	* config/arc/arc.c (arc_loop_hazard): Add missing brackets.
      
      From-SVN: r242473
      Richard Sandiford committed
    • Fix bogus failure of Wlogical-op-1.c for avr · 4786fabe
      The test assumes short is always smaller than int, and therefore does not 
      expect a warning when the logical operands are of type short and int.
      
      This isn't true for the avr - shorts and ints are of the same size, and
      therefore the warning triggers for the above case also.
      
      Fix by explicitly typedef'ing __INT32_TYPE for int and __INT16_TYPE__ for short
      if the target's int size is less than 4 bytes.
      
      gcc/testsuite/
      2016-11-16  Senthil Kumar Selvaraj  <senthil_kumar.selvaraj@atmel.com>
      
      	* c-c++-common/Wlogical-op-1.c: Use __INT{16,32}_TYPE__ instead
      	of {short,int} if __SIZEOF_INT__ is less than 4 bytes.
      
      From-SVN: r242472
      Senthil Kumar Selvaraj committed
    • [ARM] PR target/78364: Add proper restrictions to zero and sign_extract patterns operands · b6adf1c5
      	PR target/78364
      	* config/arm/arm.md (*extv_reg): Restrict operands 2 and 3 to the
      	proper ranges for an SBFX instruction.
      	(extzv_t2): Likewise for UBFX.
      
      From-SVN: r242471
      Kyrylo Tkachov committed
    • re PR tree-optimization/78348 ([7 REGRESSION] 15% performance drop for… · 510d73a0
      re PR tree-optimization/78348 ([7 REGRESSION] 15% performance drop for coremark-pro/nnet-test after r242038)
      
      2016-11-16  Richard Biener  <rguenther@suse.de>
      
      	PR tree-optimization/78348
      	* tree-loop-distribution.c (enum partition_kind): Add PKIND_MEMMOVE.
      	(generate_memcpy_builtin): Honor PKIND_MEMCPY on the partition.
      	(classify_partition): Set PKIND_MEMCPY if dependence analysis
      	revealed no dependency, PKIND_MEMMOVE otherwise.
      
      	* gcc.dg/tree-ssa/ldist-24.c: New testcase.
      
      From-SVN: r242470
      Richard Biener committed
    • re PR sanitizer/77823 (ICE: in ubsan_encode_value, at ubsan.c:137 with… · 1705cebd
      re PR sanitizer/77823 (ICE: in ubsan_encode_value, at ubsan.c:137 with -fsanitize=undefined and vector types)
      
      	PR sanitizer/77823
      	* ubsan.c (ubsan_build_overflow_builtin): Add DATAP argument, if
      	it points to non-NULL tree, use it instead of ubsan_create_data.
      	(instrument_si_overflow): Handle vector signed integer overflow
      	checking.
      	* ubsan.h (ubsan_build_overflow_builtin): Add DATAP argument.
      	* tree-vrp.c (simplify_internal_call_using_ranges): Punt for
      	vector IFN_UBSAN_CHECK_*.
      	* internal-fn.c (expand_addsub_overflow): Add DATAP argument,
      	pass it through to ubsan_build_overflow_builtin.
      	(expand_neg_overflow, expand_mul_overflow): Likewise.
      	(expand_vector_ubsan_overflow): New function.
      	(expand_UBSAN_CHECK_ADD, expand_UBSAN_CHECK_SUB,
      	expand_UBSAN_CHECK_MUL): Use tit for vector arithmetics.
      	(expand_arith_overflow): Adjust expand_*_overflow callers.
      
      	* c-c++-common/ubsan/overflow-vec-1.c: New test.
      	* c-c++-common/ubsan/overflow-vec-2.c: New test.
      
      From-SVN: r242469
      Jakub Jelinek committed
    • re PR libgcc/68468 (frv/bfin FDPIC toolchain build error) · 00178b98
      	PR libgcc/68468
      	* unwind-dw2-fde-dip.c: Fix build on FDPIC targets.
      
      From-SVN: r242468
      Waldemar Brodkorb committed
    • * g++.dg/cpp1z/init-statement6.C: Rename a function. · ed66ba99
      From-SVN: r242467
      Marek Polacek committed
    • Daily bump. · bb00603d
      From-SVN: r242466
      GCC Administrator committed
  2. 15 Nov, 2016 32 commits
    • install.texi: Remove references to java/libjava. · 648e68d5
      2016-11-16  Matthias Klose  <doko@ubuntu.com>
      
              * doc/install.texi: Remove references to java/libjava.
      
      From-SVN: r242463
      Matthias Klose committed
    • [multiple changes] · 5d70ab07
      2016-11-15  Jerry DeLisle  <jvdelisle@gcc.gnu.org>
      	    Thomas Koenig  <tkoenig@gcc.gnu.org>
      
      	PR libgfortran/51119
      	* Makefile.am: Add new optimization flags matmul.
      	* Makefile.in: Regenerate.
      	* m4/matmul.m4: For the case of all strides = 1, implement a
      	fast blocked matrix multiply. Fix some whitespace.
      	* generated/matmul_c10.c: Regenerate.
      	* generated/matmul_c16.c: Regenerate.
      	* generated/matmul_c4.c: Regenerate.
      	* generated/matmul_c8.c: Regenerate.
      	* generated/matmul_i1.c: Regenerate.
      	* generated/matmul_i16.c: Regenerate.
      	* generated/matmul_i2.c: Regenerate.
      	* generated/matmul_i4.c: Regenerate.
      	* generated/matmul_i8.c: Regenerate.
      	* generated/matmul_r10.c: Regenerate.
      	* generated/matmul_r16.c: Regenerate.
      	* generated/matmul_r4.c: Regenerate.
      	* generated/matmul_r8.c: Regenerate.
      
      2016-11-15  Thomas Koenig  <tkoenig@gcc.gnu.org>
      
      	PR libgfortran/51119
      	* gfortran.dg/matmul_12.f90: New test case.
      
      From-SVN: r242462
      Jerry DeLisle committed
    • tree-ssa-coalesce.c (register_default_def): Remove register_ssa_partition. · fd0477ca
      gcc/ChangeLog:
      
      2016-11-16  Kugan Vivekanandarajah  <kuganv@linaro.org>
      
      	* tree-ssa-coalesce.c (register_default_def): Remove register_ssa_partition.
      	(create_outofssa_var_map): Likewise.
      	* tree-ssa-live.c (register_ssa_partition_check): Remove.
      	* tree-ssa-live.h (register_ssa_partition): Likewise.
      
      From-SVN: r242461
      Kugan Vivekanandarajah committed
    • genattrtab.c (attr_rtx_1): Avoid allocating new rtx objects. · a8dd1337
      2016-11-15  Bernd Edlinger  <bernd.edlinger@hotmail.de>
      
              * genattrtab.c (attr_rtx_1): Avoid allocating new rtx objects.
              Clear ATTR_CURR_SIMPLIFIED_P for re-used binary rtx objects.
              Use DEF_ATTR_STRING for string arguments.  Use RTL_HASH for
              integer arguments.  Only set ATTR_PERMANENT_P on newly hashed
              rtx when all sub-rtx are also permanent.
              (attr_eq): Simplify.
              (attr_copy_rtx): Remove.
              (make_canonical, get_attr_value): Use attr_equal_p.
              (copy_boolean): Rehash NOT.
              (simplify_test_exp_in_temp,
              optimize_attrs): Remove call to attr_copy_rtx.
              (attr_alt_intersection, attr_alt_union,
              attr_alt_complement, mk_attr_alt): Rehash EQ_ATTR_ALT.
              (make_automaton_attrs): Use attr_eq.
      
      From-SVN: r242460
      Bernd Edlinger committed
    • install.texi: Remove references to java/libjava. · 839984f4
      2016-11-15  Matthias Klose  <doko@ubuntu.com>
      
              * doc/install.texi: Remove references to java/libjava.
              * doc/invoke.texi: Likewise.
              * doc/standards.texi: Likewise.
      
      From-SVN: r242456
      Matthias Klose committed
    • install.texi: Remove references to java/libjava. · 97a2feb6
      2016-11-15  Matthias Klose  <doko@ubuntu.com>
      
              * doc/install.texi: Remove references to java/libjava.
              * doc/sourcebuild.texi: Likewise.
      
      From-SVN: r242455
      Matthias Klose committed
    • PR 59406 note that FNV hash functions are incorrect · 27b3b3f4
      	PR libstdc++/59406
      	* include/bits/functional_hash.h: Add comment noting difference from
      	FNV-1a.
      	* include/tr1/functional_hash.h: Likewise.
      	* libsupc++/hash_bytes.cc: Likewise.
      
      From-SVN: r242454
      Jonathan Wakely committed
    • Use existing helper for new std::string constructor · 3663671a
      	* include/bits/basic_string.h: Reuse _If_sv alias template for new
      	constructor.
      
      From-SVN: r242453
      Jonathan Wakely committed
    • Make std::tuple_size<cv T> SFINAE-friendly (LWG 2770) · 6ae2ae3b
      	* doc/xml/manual/intro.xml: Document LWG 2770 status. Remove entries
      	for 2742 and 2748.
      	* doc/html/*: Regenerate.
      	* include/std/utility (__tuple_size_cv_impl): New helper to safely
      	detect tuple_size<T>::value, as per LWG 2770.
      	(tuple_size<cv T>): Adjust partial specializations to derive from
      	__tuple_size_cv_impl.
      	* testsuite/20_util/tuple/cv_tuple_size.cc: Test SFINAE-friendliness.
      
      From-SVN: r242452
      Jonathan Wakely committed
    • libiberty: demangler crash with missing :? or fold expression component. · 168126e5
      When constructing an :? or fold expression that requires a third
      expression only the first and second were explicitly checked to
      not be NULL. Since the third expression is also required in these
      constructs it needs to be explicitly checked and rejected when missing.
      Otherwise the demangler will crash once it tries to d_print the
      NULL component. Added two examples to demangle-expected of strings
      that would crash before this fix.
      
      Found by American Fuzzy Lop (afl) fuzzer.
      
      From-SVN: r242451
      Mark Wielaard committed
    • libiberty: Fix some demangler crashes caused by reading past end of input. · 0d0bfbf4
      In various situations the cplus_demangle () function could read past the
      end of input causing crashes. Add checks in various places to not advance
      the demangle string location and fail early when end of string is reached.
      Add various examples of input strings to the testsuite that would crash
      test-demangle before the fixes.
      
      Found by using the American Fuzzy Lop (afl) fuzzer.
      
      libiberty/ChangeLog:
      
             * cplus-dem.c (demangle_signature): After 'H', template function,
             no success and don't advance position if end of string reached.
             (demangle_template): After 'z', template name, return zero on
             premature end of string.
             (gnu_special): Guard strchr against searching for zero characters.
             (do_type): If member, only advance mangled string when 'F' found.
             * testsuite/demangle-expected: Add examples of strings that could
             crash the demangler by reading past end of input.
      
      From-SVN: r242450
      Mark Wielaard committed
    • Adjust pretty printer test for variant<T&> · 6f959acc
      	* testsuite/libstdc++-prettyprinters/cxx17.cc: Adjust test for
      	variant<T&>.
      
      From-SVN: r242449
      Jonathan Wakely committed
    • funcspec-56.inc: New file. · 48aef8e2
      	* gcc.target/i386/funcspec-56.inc: New file.
      	* gcc.target/i386.funcspec-5.c: Include funcspec-56.inc.  Remove
      	common 32-bit and 64-bit function specific options.
      	* gcc.target/i386.funcspec-6.c: Ditto.
      
      From-SVN: r242448
      Uros Bizjak committed
    • Fix instances of gen_rtx_REG (VOIDmode, ...) · 240930c4
      Several definitions of INCOMING_RETURN_ADDR_RTX used
      gen_rtx_REG (VOIDmode, ...), which with later patches
      would trip an assert.  This patch converts them to use
      Pmode instead.
      
      gcc/
      2016-11-15  Richard Sandiford  <richard.sandiford@arm.com>
      	    Alan Hayward  <alan.hayward@arm.com>
      	    David Sherwood  <david.sherwood@arm.com>
      
      	* config/i386/i386.h (INCOMING_RETURN_ADDR_RTX): Use Pmode instead
      	of VOIDmode.
      	* config/ia64/ia64.h (INCOMING_RETURN_ADDR_RTX): Likewise.
      	* config/iq2000/iq2000.h (INCOMING_RETURN_ADDR_RTX): Likewise.
      	* config/m68k/m68k.h (INCOMING_RETURN_ADDR_RTX): Likewise.
      	* config/microblaze/microblaze.h (INCOMING_RETURN_ADDR_RTX): Likewise.
      	* config/mips/mips.h (INCOMING_RETURN_ADDR_RTX): Likewise.
      	* config/mn10300/mn10300.h (INCOMING_RETURN_ADDR_RTX): Likewise.
      	* config/nios2/nios2.h (INCOMING_RETURN_ADDR_RTX): Likewise.
      
      Co-Authored-By: Alan Hayward <alan.hayward@arm.com>
      Co-Authored-By: David Sherwood <david.sherwood@arm.com>
      
      From-SVN: r242447
      Richard Sandiford committed
    • Use MEM_SIZE rather than GET_MODE_SIZE in dce.c · 7eb87420
      Using MEM_SIZE is more general, since it copes with cases where
      targets are forced to use BLKmode references for whatever reason.
      
      gcc/
      2016-11-15  Richard Sandiford  <richard.sandiford@arm.com>
      	    Alan Hayward  <alan.hayward@arm.com>
      	    David Sherwood  <david.sherwood@arm.com>
      
      	* dce.c (check_argument_store): Pass the size instead of
      	the memory reference.
      	(find_call_stack_args): Pass MEM_SIZE to check_argument_store.
      
      Co-Authored-By: Alan Hayward <alan.hayward@arm.com>
      Co-Authored-By: David Sherwood <david.sherwood@arm.com>
      
      From-SVN: r242446
      Richard Sandiford committed
    • Use simplify_gen_binary in canon_rtx · 231314e3
      After simplifying the operands of a PLUS, canon_rtx checked only
      for cases in which one of the simplified operands was a constant,
      falling back to gen_rtx_PLUS otherwise.  This left the PLUS in a
      non-canonical order if one of the simplified operands was
      (plus (reg R1) (const_int X)); we'd end up with:
      
             (plus (plus (reg R1) (const_int Y)) (reg R2))
      
      rather than:
      
             (plus (plus (reg R1) (reg R2)) (const_int Y))
      
      Fixing this exposed new DSE opportunities on spu-elf in
      gcc.c-torture/execute/builtins/strcat-chk.c but otherwise
      it doesn't seem to have much practical effect.
      
      gcc/
      2016-11-15  Richard Sandiford  <richard.sandiford@arm.com>
      	    Alan Hayward  <alan.hayward@arm.com>
      	    David Sherwood  <david.sherwood@arm.com>
      
      	* alias.c (canon_rtx): Use simplify_gen_binary.
      
      Co-Authored-By: Alan Hayward <alan.hayward@arm.com>
      Co-Authored-By: David Sherwood <david.sherwood@arm.com>
      
      From-SVN: r242445
      Richard Sandiford committed
    • Add a load_extend_op wrapper · 3712c7a3
      LOAD_EXTEND_OP only applies to scalar integer modes that are narrower
      than a word.  However, callers weren't consistent about which of these
      checks they made beforehand, and also weren't consistent about whether
      "smaller" was based on (bit)size or precision (IMO it's the latter).
      This patch adds a wrapper to try to make the macro easier to use.
      
      LOAD_EXTEND_OP is often used to disable transformations that aren't
      beneficial when extends from memory are free, so being stricter about
      the check accidentally exposed more optimisation opportunities.
      
      "SUBREG_BYTE (...) == 0" and subreg_lowpart_p are implied by
      paradoxical_subreg_p, so the patch also removes some redundant tests.
      
      The patch doesn't change reload, since different checks could have
      unforeseen consequences.
      
      gcc/
      2016-11-15  Richard Sandiford  <richard.sandiford@arm.com>
      	    Alan Hayward  <alan.hayward@arm.com>
      	    David Sherwood  <david.sherwood@arm.com>
      
      	* rtl.h (load_extend_op): Declare.
      	* rtlanal.c (load_extend_op): New function.
      	(nonzero_bits1): Use it.
      	(num_sign_bit_copies1): Likewise.
      	* cse.c (cse_insn): Likewise.
      	* fold-const.c (fold_single_bit_test): Likewise.
      	(fold_unary_loc): Likewise.
      	* fwprop.c (free_load_extend): Likewise.
      	* postreload.c (reload_cse_simplify_set): Likewise.
      	(reload_cse_simplify_operands): Likewise.
      	* combine.c (try_combine): Likewise.
      	(simplify_set): Likewise.  Remove redundant SUBREG_BYTE and
      	subreg_lowpart_p checks.
      
      Co-Authored-By: Alan Hayward <alan.hayward@arm.com>
      Co-Authored-By: David Sherwood <david.sherwood@arm.com>
      
      From-SVN: r242444
      Richard Sandiford committed
    • Fix simplify_shift_const_1 handling of vector shifts · ba3c3dc0
      simplify_shift_const_1 handles both shifts of scalars by scalars
      and shifts of vectors by scalars.  For vectors this means that
      each element is shifted by the same amount.
      
      However:
      
      (a) the two cases weren't always distinguished, so we'd try
              things for vectors that only made sense for scalars.
      
      (b) a lot of the range and bitcount checks were based on the
              bitsize or precision of the full shifted operand, rather
              than the mode of each element.
      
      Fixing (b) accidentally exposed more optimisation opportunities,
      although that wasn't the point of the patch.
      
      gcc/
      2016-11-15  Richard Sandiford  <richard.sandiford@arm.com>
      	    Alan Hayward  <alan.hayward@arm.com>
      	    David Sherwood  <david.sherwood@arm.com>
      
      	* combine.c (simplify_shift_const_1): Use the number of bits
      	in the inner mode to determine the range of the shift.
      	When handling shifts of vectors, skip any rules that apply
      	only to scalars.
      
      Co-Authored-By: Alan Hayward <alan.hayward@arm.com>
      Co-Authored-By: David Sherwood <david.sherwood@arm.com>
      
      From-SVN: r242442
      Richard Sandiford committed
    • Move misplaced assignment in num_sign_bit_copies1 · 89e64bc0
      The old assignment to bitwidth was before we handled VOIDmode with:
      
            if (mode == VOIDmode)
              mode = GET_MODE (x);
      
      so when VOIDmode was specified we would always use:
      
            if (bitwidth < GET_MODE_PRECISION (GET_MODE (x)))
              {
                num0 = cached_num_sign_bit_copies (x, GET_MODE (x),
                                                   known_x, known_mode, known_ret);
                return MAX (1,
                            num0 - (int) (GET_MODE_PRECISION (GET_MODE (x)) - bitwidth));
              }
      
      For a zero bitwidth this always returns 1 (which is the most
      pessimistic result).
      
      gcc/
      2016-11-15  Richard Sandiford  <richard.sandiford@arm.com>
      	    Alan Hayward  <alan.hayward@arm.com>
      	    David Sherwood  <david.sherwood@arm.com>
      
      	* rtlanal.c (num_sign_bit_copies1): Calculate bitwidth after
      	handling VOIDmode.
      
      Co-Authored-By: Alan Hayward <alan.hayward@arm.com>
      Co-Authored-By: David Sherwood <david.sherwood@arm.com>
      
      From-SVN: r242440
      Richard Sandiford committed
    • Makefile.def: Remove references to GCJ. · 8e4d2ca4
      2016-11-15  Matthias Klose  <doko@ubuntu.com>
      
              * Makefile.def: Remove references to GCJ.
              * Makefile.tpl: Likewise.
              * Makefile.in: Regenerate.
      
      From-SVN: r242439
      Matthias Klose committed
    • variant: Remove variant<T&>... · 7b277e8b
      	* include/std/variant: Remove variant<T&>, variant<void>, variant<> support
      	to rebase on the post-Issaquah design.
      	* testsuite/20_util/variant/compile.cc: Likewise.
      
      From-SVN: r242437
      Tim Shen committed
    • libgomp testsuite: add missing map clauses · 18d2ada8
      	* testsuite/libgomp.fortran/examples-4/device-1.f90 (e_57_1): Add
      	mapping clauses to target constructs.
      	* testsuite/libgomp.fortran/examples-4/device-3.f90 (e_57_3): Ditto.
      
      
      Co-Authored-By: Alexander Monakov <amonakov@ispras.ru>
      
      From-SVN: r242436
      Martin Jambor committed
    • decomp14.C: New test. · 5a65a911
      	* g++.dg/cpp1z/decomp14.C: New test.
      	* g++.dg/cpp1z/decomp15.C: New test.
      	* g++.dg/cpp1z/decomp16.C: New test.
      
      From-SVN: r242435
      Jakub Jelinek committed
    • decl.c (cp_finish_decomp): For DECL_NAMESPACE_SCOPE_P decl, set DECL_ASSEMBLER_NAME. · a0f5b987
      	* decl.c (cp_finish_decomp): For DECL_NAMESPACE_SCOPE_P decl,
      	set DECL_ASSEMBLER_NAME.
      	* parser.c (cp_parser_decomposition_declaration): Likewise
      	if returning error_mark_node.
      	* mangle.c (mangle_decomp): New function.
      	* cp-tree.h (mangle_decomp): New declaration.
      
      	* g++.dg/cpp1z/decomp13.C: New test.
      
      From-SVN: r242434
      Jakub Jelinek committed
    • config-ml.in: Remove references to GCJ. · 84c1b9d3
      <toplevel>
      
      2016-11-15  Matthias Klose  <doko@ubuntu.com>
      
      	* config-ml.in: Remove references to GCJ.
      	* configure.ac: Likewise.
      	* configure: Regenerate.
      
      config/
      
      2016-11-15  Matthias Klose  <doko@ubuntu.com>
      
      	multi.m4: Don't set GCJ.
      
      gcc/
      
      2016-11-15  Matthias Klose  <doko@ubuntu.com>
      
      	* doc/install.texi: Remove references to gcj/libjava.
      	* doc/invoke.texi: Likewise.
      
      */ (where necessary)
      
      2016-11-15  Matthias Klose  <doko@ubuntu.com>
      
      	* configure: Regenerate.
      
      From-SVN: r242433
      Matthias Klose committed
    • PR c++/78358 - tuple decomposition decltype · 94460802
      	* semantics.c (finish_decltype_type): Strip references for a tuple
      	decomposition.
      	* cp-tree.h (DECL_DECOMPOSITION_P): False for non-variables.
      
      From-SVN: r242432
      Jason Merrill committed
    • tree-ssa-threadbackward.c (fsm_find_thread_path): Remove unneeded parameter. · 435fd407
      	* tree-ssa-threadbackward.c (fsm_find_thread_path): Remove unneeded
      	parameter.  Callers changed.
      	(check-subpath_and_update_thread_path): Extracted from
      	fsm_find_control_statement_thread_paths.
      	(handle_phi, handle_assignment, handle_assignment_p): Likewise.
      	(handle_phi, handle_assignment): Allow any constant node, not
      	just INTEGER_CST.
      
      From-SVN: r242431
      Jeff Law committed
    • ChangeLog: Fix ChangeLog entry. · 22b15758
      	* gcc/ChangeLog: Fix ChangeLog entry.
      	* gcc/c/ChangeLog: Ditto.
      	* gcc/c-family/ChangeLog: Ditto.
      	* gcc/cp/ChangeLog: Ditto.
      
      From-SVN: r242429
      Uros Bizjak committed
    • [ARC] [libgcc] Fix defines · d64af69f
      libgcc/
      2016-11-15  Claudiu Zissulescu  <claziss@synopsys.com>
      
      	* config/arc/lib1funcs.S (__mulsi3): Use feature defines instead
      	of checking for cpus.
      	(__umulsidi3, __umulsi3_highpart, __udivmodsi4, __divsi3)
      	(__modsi3, __clzsi2): Likewise.
      
      From-SVN: r242428
      Claudiu Zissulescu committed
    • re PR c++/71988 (ICE in dump_simple_decl (gcc/cp/error.c:965)) · 0c8a8fe2
      	PR c++/71988
      	* g++.dg/cpp0x/constexpr-71988.C: New test.
      
      From-SVN: r242426
      Jakub Jelinek committed