1. 22 Jan, 2018 11 commits
    • fixed year in gcc/ChangeLog and libgcc/ChangeLog · 6a18c146
      From-SVN: r256949
      Sebastian Perta committed
    • rl78.md: New define_expand "umaxdi3". · 5dd16013
      2017-01-22  Sebastian Perta  <sebastian.perta@renesas.com>
      
      	* config/rl78/rl78.md: New define_expand "umaxdi3".
      
      2017-01-22  Sebastian Perta  <sebastian.perta@renesas.com>
       
      	* config/rl78/umaxdi3.S: New assembly file.
      	* config/rl78/t-rl78: Added umaxdi3.S to LIB2ADD.
      
      From-SVN: r256948
      Sebastian Perta committed
    • fold-vec-abs-short-fwrap.c: Add xxspltib to scan-asembler valid instructions list. · 0d918596
      [testsuite]
      
      	2018-01-19  Will Schmidt <will_schmidt@vnet.ibm.com>
      
      	* gcc.target/powerpc/fold-vec-abs-short-fwrap.c: Add xxspltib to
      	scan-asembler valid instructions list.
      	* gcc.target/powerpc/fold-vec-abs-short.c: Same.
      	* gcc.target/powerpc/fold-vec-shift-left-longlong.c: Clean up
      	power8-vector requirement and option.
      	* gcc.target/powerpc/fold-vec-shift-left-fwrapv.c: Same.
      
      From-SVN: r256947
      Will Schmidt committed
    • rl78.c (rl78_note_reg_set): fixed dead reg check for non-QImode registers · 049b866d
      2018-01-12  Sebastian Perta  <sebastian.perta@renesas.com>
      	
      	* config/rl78/rl78.c (rl78_note_reg_set): fixed dead reg check 
      	for non-QImode registers
      
      From-SVN: r256945
      Sebastian Perta committed
    • PR 78534, 83704 Large character lengths · 6b271a2e
      This patch fixes various parts of the code to use a larger type than
      int for the character length. Depending on the situation,
      HOST_WIDE_INT, size_t, or gfc_charlen_t is appropriate.
      
      Regtested on x86_64-pc-linux-gnu and i686-pc-linux-gnu.
      
      gcc/fortran/ChangeLog:
      
      2018-01-22  Janne Blomqvist  <jb@gcc.gnu.org>
      
      	PR 78534
      	PR 83704
      	* arith.c (gfc_arith_concat): Use size_t for string length.
      	(gfc_compare_string): Likewise.
      	(gfc_compare_with_Cstring): Likewise.
      	* array.c (gfc_resolve_character_array_constructor): Use
      	HOST_WIDE_INT, gfc_mpz_get_hwi.
      	* check.c (gfc_check_fe_runtime_error): Use size_t.
      	* data.c (create_character_initializer): Use HOST_WIDE_INT,
      	gfc_extract_hwi.
      	* decl.c (gfc_set_constant_character_len): Use gfc_charlen_t.
      	(add_init_expr_to_sym): Use HOST_WIDE_INT.
      	* expr.c (gfc_build_init_expr): Use HOST_WIDE_INT,
      	gfc_extract_hwi.
      	(gfc_apply_init): Likewise.
      	* match.h (gfc_set_constant_character_len): Update prototype.
      	* primary.c (match_string_constant): Use size_t.
      	* resolve.c (resolve_ordinary_assign): Use HOST_WIDE_INT,
      	gfc_mpz_get_hwi.
      	* simplify.c (init_result_expr): Likewise.
      	(gfc_simplify_len_trim): Use size_t.
      	* target-memory.c (gfc_encode_character): Use size_t.
      	(gfc_target_encode_expr): Use HOST_WIDE_INT, gfc_mpz_get_hwi.
      	(interpret_array): Use size_t.
      	(gfc_interpret_character): Likewise.
      	* target-memory.h (gfc_encode_character): Update prototype.
      	(gfc_interpret_character): Likewise.
      	(gfc_target_interpret_expr): Likewise.
      	* trans-const.c (gfc_build_string_const): Use size_t for length
      	argument.
      	(gfc_build_wide_string_const): Likewise.
      	* trans-const.h (gfc_build_string_const): Likewise.
      	(gfc_build_wide_string_const): Likewise.
      
      2018-01-22  Janne Blomqvist  <jb@gcc.gnu.org>
      
      	PR 78534
      	PR 83704
      	* gfortran.dg/string_1.f90: Remove printing the length.
      
      From-SVN: r256944
      Janne Blomqvist committed
    • re PR tree-optimization/83963 ([graphite] ICE in merge_sese, at graphite-scop-detection.c:517) · 1dba94d4
      2018-01-22  Richard Biener  <rguenther@suse.de>
      
      	PR tree-optimization/83963
      	* graphite-scop-detection.c (scop_detection::get_sese): Delay
      	including the loop exit block.
      	(scop_detection::merge_sese): Likewise.
      	(scop_detection::add_scop): Do it here instead.
      
      	* gcc.dg/graphite/pr83963.c: New testcase.
      
      From-SVN: r256943
      Richard Biener committed
    • re PR c++/83895 (-Wparentheses warns about pointer-to-member typedefs) · 74e95ed0
      PR c++/83895
      
      cp/
      
      * decl.c (grokdeclarator): Don't diagnose extra parens
      on typedefs.
      
      testsuite/
      
      * g++.dg/warn/83895.C: New.
      
      From-SVN: r256942
      Ville Voutilainen committed
    • [ARM] Fix test fail with conflicting -mfloat-abi · 0e32449b
      This patch fixes my earlier test case that fails for arm-none-eabi
      with explicit user option for -mfloat-abi which conflict with
      the test case options. I have added a guard to skip the test
      on those cases.
      
      ChangeLog entries:
      
      *** gcc/testsuite/ChangeLog ***
      
      2018-01-22  Sudakshina Das  <sudi.das@arm.com>
      
      	* gcc.c-torture/compile/pr82096.c: Add dg-skip-if and
      	dg-require-effective-target directives.
      
      From-SVN: r256941
      Sudakshina Das committed
    • [arm] Make gcc.target/arm/copysign_softfloat_1.c more robust · dececdaa
      This test has needlessly restrictive requirements. It tries to force a soft-float target and tries to run.
      This makes it unsupportable for any non-soft-float variant.
      In fact, the test can be a run-time test for any target, and only the scan-assembler tests are specific to
      -mfloat-abi=soft. So this patch makes the test always runnable and makes the scan-assembler checks predicable
      on the the new arm_sotftfloat effective target check. 
      
      	* doc/sourcebuild.texi (arm_softfloat): Document.
      
      	* lib/target-supports.exp (check_effective_target_arm_softfloat):
      	New procedure.
      	* gcc.target/arm/copysign_softfloat_1.c: Allow running everywhere.
      	Adjust scan-assembler checks for soft-float.
      
      From-SVN: r256940
      Kyrylo Tkachov committed
    • re PR target/83946 (Safe Indirect Jumps broken on AIX) · 6a79ea14
      2018-01-21  Bill Schmidt  <wschmidt@linux.vnet.ibm.com>
      
      	PR target/83946
      	* gcc.target/powerpc/safe-indirect-jump-8.c: Skip for AIX.
      
      From-SVN: r256939
      Bill Schmidt committed
    • Daily bump. · e59ffda4
      From-SVN: r256938
      GCC Administrator committed
  2. 21 Jan, 2018 8 commits
  3. 20 Jan, 2018 6 commits
    • re PR fortran/83900 (ICE in gfc_simplify_matmul, at fortran/simplify.c:4593) · f5240750
      2018-01-20  Steven G. Kargl  <kargl@gcc.gnu.org>
      
      	PR fortran/83900
          * simplify.c (gfc_simplify_matmul): Set return type correctly.
      
      2018-01-20  Steven G. Kargl  <kargl@gcc.gnu.org>
      
      	PR fortran/83900
      	* gfortran.dg/matmul_18.f90: New test.
      
      From-SVN: r256919
      Steven G. Kargl committed
    • Fix vect_def_type handling in x86 scatter support (PR 83940) · 929b4411
      As Jakub says in the PR, the problem here was that the x86/built-in
      version of the scatter support was using a bogus scatter_src_dt
      when calling vect_get_vec_def_for_stmt_copy (and had since it
      was added).  The patch uses the vect_def_type from the original
      call to vect_is_simple_use instead.
      
      However, Jakub also pointed out that other parts of the load and store
      code passed the vector operand rather than the scalar operand to
      vect_is_simple_use.  That probably works most of the time since
      a constant scalar operand should give a constant vector operand,
      and likewise for external and internal definitions.  But it
      definitely seems more robust to pass the scalar operand.
      
      The patch avoids the issue for gather and scatter offsets by
      using the cached gs_info.offset_dt.  This is safe because gathers
      and scatters are never grouped, so there's only one statement operand
      to consider.  The patch also caches the vect_def_type for mask operands,
      which is safe because grouped masked operations share the same mask.
      
      That just leaves the store rhs.  We still need to recalculate the
      vect_def_type there since different store values in the group can
      have different definition types.  But since we still have access
      to the original scalar operand, it seems better to use that instead.
      
      2018-01-20  Richard Sandiford  <richard.sandiford@linaro.org>
      
      gcc/
      	PR tree-optimization/83940
      	* tree-vect-stmts.c (vect_truncate_gather_scatter_offset): Set
      	offset_dt to vect_constant_def rather than vect_unknown_def_type.
      	(vect_check_load_store_mask): Add a mask_dt_out parameter and
      	use it to pass back the definition type.
      	(vect_check_store_rhs): Likewise rhs_dt_out.
      	(vect_build_gather_load_calls): Add a mask_dt argument and use
      	it instead of a call to vect_is_simple_use.
      	(vectorizable_store): Update calls to vect_check_load_store_mask
      	and vect_check_store_rhs.  Use the dt returned by the latter instead
      	of scatter_src_dt.  Use the cached mask_dt and gs_info.offset_dt
      	instead of calls to vect_is_simple_use.  Pass the scalar rather
      	than the vector operand to vect_is_simple_use when handling
      	second and subsequent copies of an rhs value.
      	(vectorizable_load): Update calls to vect_check_load_store_mask
      	and vect_build_gather_load_calls.  Use the cached mask_dt and
      	gs_info.offset_dt instead of calls to vect_is_simple_use.
      
      gcc/testsuite/
      	PR tree-optimization/83940
      	* gcc.dg/torture/pr83940.c: New test.
      
      From-SVN: r256918
      Richard Sandiford committed
    • re PR middle-end/83945 (internal compiler error: Segmentation fault with -O -fcode-hoisting) · 37b7e787
      	PR middle-end/83945
      	* tree-emutls.c: Include gimplify.h.
      	(lower_emutls_2): New function.
      	(lower_emutls_1): If ADDR_EXPR is a gimple invariant and walk_tree
      	with lower_emutls_2 callback finds some TLS decl in it, unshare_expr
      	it before further processing.
      
      	* gcc.dg/tls/pr83945.c: New test.
      
      From-SVN: r256916
      Jakub Jelinek committed
    • re PR target/83930 (ICE: RTL check: expected code 'const_int', have 'mem' in… · 09cbbded
      re PR target/83930 (ICE: RTL check: expected code 'const_int', have 'mem' in simplify_binary_operation_1, at simplify-rtx.c:3302)
      
      	PR target/83930
      	* simplify-rtx.c (simplify_binary_operation_1) <case UMOD>: Use
      	UINTVAL (trueop1) instead of INTVAL (op1).
      
      	* gcc.dg/pr83930.c: New test.
      
      From-SVN: r256915
      Jakub Jelinek committed
    • re PR fortran/83900 (ICE in gfc_simplify_matmul, at fortran/simplify.c:4593) · f18fee82
      2018-01-19  Steven G. Kargl  <kargl@gcc.gnu.org>
      
      	PR fortran/83900
      	* simplify.c (gfc_simplify_matmul): Delete bogus assertion.
      
      2018-01-19  Steven G. Kargl  <kargl@gcc.gnu.org>
      
      	PR fortran/83900
      	* gfortran.dg/matmul_17.f90: New test.
      
      From-SVN: r256912
      Steven G. Kargl committed
    • Daily bump. · 9e2c94c9
      From-SVN: r256911
      GCC Administrator committed
  4. 19 Jan, 2018 15 commits