1. 24 Nov, 2016 15 commits
  2. 23 Nov, 2016 25 commits
    • Fix e500 offset handling for TImode. · 6fa42ea3
      Given my previous fix for a missing insn pattern for e500, building
      glibc runs into an assembler error "Error: operand out of range (256
      is not between 0 and 248)".  This comes from an insn:
      
      (insn 115 1209 1210 (set (reg:DF 27 27 [orig:294 _129 ] [294])
              (subreg:DF (mem/c:TI (plus:SI (reg/f:SI 1 1)
                          (const_int 256 [0x100])) [14 %sfp+256 S16 A128]) 0)) 1909 {*frob_df_ti}
           (nil))
      
      This patch adjusts the offset handling for TImode - and TDmode and
      PTImode in case such subregs can arise for them - to be the same as
      for TFmode, so that proper SPE offset checks are made in the
      TARGET_E500_DOUBLE case.
      
      This allows the glibc build to complete.  Testing shows 372 FAILs
      across the gcc, g++ and libstdc++ testsuites; more cleanup is
      certainly needed, but this gets to the point where the toolchain at
      least builds so it's possible to compare test results when fixing
      bugs.
      
      	* config/rs6000/rs6000.c (rs6000_legitimate_offset_address_p): For
      	TARGET_E500_DOUBLE. handle TDmode, TImode and PTImode the same as
      	TFmode, IFmode and KFmode.
      
      From-SVN: r242814
      Joseph Myers committed
    • Add another e500 subreg pattern. · 03f24169
      Building glibc for powerpc-linux-gnuspe --enable-e500-double, given
      the patch <https://gcc.gnu.org/ml/gcc-patches/2016-11/msg02404.html>
      applied, fails with errors such as:
      
      ../sysdeps/ieee754/ldbl-128ibm/s_modfl.c: In function '__modfl':
      ../sysdeps/ieee754/ldbl-128ibm/s_modfl.c:91:1: error: unrecognizable insn:
       }
       ^
      (insn 31 30 32 2 (set (reg:DF 203)
              (subreg:DF (reg:TI 202) 8)) "../sysdeps/ieee754/ldbl-128ibm/s_modfl.c":44 -1
           (nil))
      ../sysdeps/ieee754/ldbl-128ibm/s_modfl.c:91:1: internal compiler error: in extract_insn, at recog.c:2311
      
      This patch adds an insn pattern similar to various patterns already
      present to handle extracting such a subreg.  This allows the glibc
      build to get further, until it runs into an assembler error for which
      I have another patch.
      
      gcc:
      	* config/rs6000/spe.md (*frob_<SPE64:mode>_ti_8): New insn
      	pattern.
      
      gcc/testsuite:
      	* gcc.c-torture/compile/20161123-1.c: New test.
      
      From-SVN: r242813
      Joseph Myers committed
    • combine: Query can_change_dest_mode before changing dest mode · 469585df
      As reported in https://gcc.gnu.org/ml/gcc-patches/2016-11/msg02388.html .
      
      Changing the mode of a hard register can lead to problems, or at least
      it can make worse code if the result will need reloads.
      
      
      	* combine.c (change_zero_ext): Only change the mode of a hard register
      	destination if can_change_dest_mode holds for that.
      
      From-SVN: r242812
      Segher Boessenkool committed
    • * varasm.c (assemble_name): Increase buffer size for name. · 188a2091
      From-SVN: r242810
      Jeff Law committed
    • * config/i386/i386.md: Move some insn patterns around. · 11a669fb
      From-SVN: r242809
      Uros Bizjak committed
    • opth-gen.awk: Use unsigned shifts for bit masks. · d5c45ad7
      2016-11-07  Bernd Edlinger  <bernd.edlinger@hotmail.de>
      
      	* opth-gen.awk: Use unsigned shifts for bit masks.  Allow all bits
      	to be used.  Add brackets around macro argument.
      
      From-SVN: r242803
      Bernd Edlinger committed
    • re PR fortran/78297 (ICE in finish_equivalences, at fortran/trans-common.c:1246) · 91c9fb42
      2016-11-23  Steven G. Kargl  <kargl@gcc.gnu.org>
      
      	PR fortran/78297
      	* trans-common.c (finish_equivalences): Do not dereference a NULL pointer.
      
      2016-11-23  Steven G. Kargl  <kargl@gcc.gnu.org>
      
      	PR fortran/78297
      	* gfortran.dg/pr78297.f90: New test.
      
      From-SVN: r242802
      Steven G. Kargl committed
    • i386.md (*<any_or:code>hi_1): Fix operand 2 constraints. · cf919e35
      	* config/i386/i386.md (*<any_or:code>hi_1): Fix operand 2 constraints.
      
      From-SVN: r242796
      Uros Bizjak committed
    • re PR sanitizer/69278 (Confusion option handling for -sanitize-recovery=alll) · c944c6a2
      	PR sanitizer/69278
      	* opts.c (parse_sanitizer_options): For -fsanitize=undefined,
      	restore enabling also SANITIZE_UNREACHABLE and SANITIZE_RETURN.
      
      	* g++.dg/ubsan/return-7.C: New test.
      	* c-c++-common/ubsan/unreachable-4.c: New test.
      
      From-SVN: r242795
      Jakub Jelinek committed
    • re PR tree-optimization/78482 (wrong code at -O3 in both 32-bit and 64-bit modes… · 871a2c6c
      re PR tree-optimization/78482 (wrong code at -O3 in both 32-bit and 64-bit modes on x86_64-linux-gnu)
      
      	PR tree-optimization/78482
      	* gcc.dg/torture/pr78482.c (c, d): Use signed char instead of char.
      	(bar): New function.
      	(main): Call bar instead of printf.
      
      From-SVN: r242794
      Jakub Jelinek committed
    • re PR middle-end/69183 (ICE when using OpenMP PRIVATE keyword in OMP DO loop not… · c39dad64
      re PR middle-end/69183 (ICE when using OpenMP PRIVATE keyword in OMP DO loop not explicitly encapsulated in OMP PARALLEL region)
      
      	PR middle-end/69183
      	* omp-low.c (build_outer_var_ref): Change lastprivate argument
      	to code, pass it recursively, adjust uses.  For OMP_CLAUSE_PRIVATE
      	on worksharing constructs, treat it like clauses on simd construct.
      	Formatting fix.
      	(lower_rec_input_clauses): For OMP_CLAUSE_PRIVATE_OUTER_REF pass
      	OMP_CLAUSE_PRIVATE as last argument to build_outer_var_ref.
      	(lower_lastprivate_clauses): Pass OMP_CLAUSE_LASTPRIVATE instead
      	of true as last argument to build_outer_var_ref.
      
      	* gfortran.dg/gomp/pr69183.f90: New test.
      
      From-SVN: r242793
      Jakub Jelinek committed
    • re PR target/78230 (Compile pr66178.c fail for mips64el-elf with N64 abi) · 62567da0
      	PR target/78230
      	* gcc.dg/torture/pr66178.c (test): Use uintptr_t instead of int.
      	(test2) Ditto.
      
      From-SVN: r242792
      Kito Cheng committed
    • i386.md (*movqi_internal): Calculate mode attribute of alternatives 7,8,9… · 46e89251
      i386.md (*movqi_internal): Calculate mode attribute of alternatives 7,8,9 depending on TARGET_AVX512DQ.
      
      	* gcc.target/config/i386.md (*movqi_internal): Calculate mode
      	attribute of alternatives 7,8,9 depending on TARGET_AVX512DQ.
      	<TYPE_MSKMOV>: Emit kmovw for MODE_HI insn mode attribute.
      	(*k<logic><mode>): Calculate mode attribute depending on
      	TARGET_AVX512DQ.  Emit k<logic>w for MODE_HI insn mode attribute.
      	(*andqi_1): Calculate mode attribute of alternative 3 depending
      	on TARGET_AVX512DQ.  Emit kandw for MODE_HI insn mode attribute.
      	(kandn<mode>): Calculate mode attribute of alternative 2 depending
      	on TARGET_AVX512DQ.  Emit kandnw for MODE_HI insn mode attribute.
      	(kxnor<mode>): Merge insn patterns using SWI1248_AVX512BW mode
      	iterator.  Calculate mode attribute of alternative 1 depending
      	on TARGET_AVX512DQ.  Emit kxnorw for MODE_HI insn mode attribute.
      	(*one_cmplqi2_1): Calculate mode attribute of alternative 2 depending
      	on TARGET_AVX512DQ.  Emit knotw for MODE_HI insn mode attribute.
      
      From-SVN: r242791
      Uros Bizjak committed
    • re PR c++/77907 (Add "const" to argument of constexpr constructor causes the… · 25cb6b33
      re PR c++/77907 (Add "const" to argument of constexpr constructor causes the object to be left in unconstructed state)
      
      	PR c++/77907
      	* cp-gimplify.c (cp_fold) <case CALL_EXPR>: When calling constructor
      	and maybe_constant_value returns non-CALL_EXPR, create INIT_EXPR
      	with the object on lhs and maybe_constant_value returned expr on rhs.
      
      	* g++.dg/cpp0x/pr77907.C: New test.
      
      From-SVN: r242790
      Jakub Jelinek committed
    • OpenMP offloading to NVPTX: libgomp changes · 6103184e
      	* Makefile.am (libgomp_la_SOURCES): Add atomic.c, icv.c, icv-device.c.
      	* Makefile.in. Regenerate.
      	* configure.ac [nvptx*-*-*] (libgomp_use_pthreads): Set and use it...
      	(LIBGOMP_USE_PTHREADS): ...here; new define.
      	* configure: Regenerate.
      	* config.h.in: Likewise.
      	* config/posix/affinity.c: Move to...
      	* affinity.c: ...here (new file).  Guard use of Pthreads-specific
      	interface by LIBGOMP_USE_PTHREADS. 
      	* critical.c: Split out GOMP_atomic_{start,end} into...
      	* atomic.c: ...here (new file).
      	* env.c: Split out ICV definitions into...
      	* icv.c: ...here (new file) and...
      	* icv-device.c: ...here. New file.
      	* config/linux/lock.c (gomp_init_lock_30): Move to generic lock.c.
      	(gomp_destroy_lock_30): Ditto.
      	(gomp_set_lock_30): Ditto.
      	(gomp_unset_lock_30): Ditto.
      	(gomp_test_lock_30): Ditto.
      	(gomp_init_nest_lock_30): Ditto.
      	(gomp_destroy_nest_lock_30): Ditto.
      	(gomp_set_nest_lock_30): Ditto.
      	(gomp_unset_nest_lock_30): Ditto.
      	(gomp_test_nest_lock_30): Ditto.
      	* lock.c: New.
      	* config/nvptx/lock.c: New.
      	* config/nvptx/bar.c: New.
      	* config/nvptx/bar.h: New.
      	* config/nvptx/doacross.h: New.
      	* config/nvptx/error.c: New.
      	* config/nvptx/icv-device.c: New.
      	* config/nvptx/mutex.h: New.
      	* config/nvptx/pool.h: New.
      	* config/nvptx/proc.c: New.
      	* config/nvptx/ptrlock.h: New.
      	* config/nvptx/sem.h: New.
      	* config/nvptx/simple-bar.h: New.
      	* config/nvptx/target.c: New.
      	* config/nvptx/task.c: New.
      	* config/nvptx/team.c: New.
      	* config/nvptx/time.c: New.
      	* config/posix/simple-bar.h: New.
      	* libgomp.h: Guard pthread.h inclusion.  Include simple-bar.h.
      	(gomp_num_teams_var): Declare.
      	(struct gomp_thread_pool): Change threads_dock member to
      	gomp_simple_barrier_t.
      	[__nvptx__] (gomp_thread): New implementation.
      	(gomp_thread_attr): Guard by LIBGOMP_USE_PTHREADS.
      	(gomp_thread_destructor): Ditto.
      	(gomp_init_thread_affinity): Ditto.
      	* team.c: Guard uses of Pthreads-specific interfaces by
      	LIBGOMP_USE_PTHREADS.  Adjust all uses of threads_dock.
      	(gomp_free_thread) [__nvptx__]: Do not call 'free'.
      
      	* config/nvptx/alloc.c: Delete.
      	* config/nvptx/barrier.c: Ditto.
      	* config/nvptx/fortran.c: Ditto.
      	* config/nvptx/iter.c: Ditto.
      	* config/nvptx/iter_ull.c: Ditto.
      	* config/nvptx/loop.c: Ditto.
      	* config/nvptx/loop_ull.c: Ditto.
      	* config/nvptx/ordered.c: Ditto.
      	* config/nvptx/parallel.c: Ditto.
      	* config/nvptx/priority_queue.c: Ditto.
      	* config/nvptx/sections.c: Ditto.
      	* config/nvptx/single.c: Ditto.
      	* config/nvptx/splay-tree.c: Ditto.
      	* config/nvptx/work.c: Ditto.
      
      	* testsuite/libgomp.fortran/fortran.exp (lang_link_flags): Pass
      	-foffload=-lgfortran in addition to -lgfortran.
      	* testsuite/libgomp.oacc-fortran/fortran.exp (lang_link_flags): Ditto.
      
      	* plugin/plugin-nvptx.c: Include <limits.h>.
      	(struct targ_fn_descriptor): Add new fields.
      	(struct ptx_device): Ditto.  Set them...
      	(nvptx_open_device): ...here.
      	(nvptx_adjust_launch_bounds): New.
      	(nvptx_host2dev): Allow NULL 'nvthd'.
      	(nvptx_dev2host): Ditto.
      	(GOMP_OFFLOAD_get_caps): Add GOMP_OFFLOAD_CAP_OPENMP_400.
      	(link_ptx): Adjust log sizes.
      	(nvptx_host2dev): Allow NULL 'nvthd'.
      	(nvptx_dev2host): Ditto.
      	(nvptx_set_clocktick): New.  Use it...
      	(GOMP_OFFLOAD_load_image): ...here.  Set new targ_fn_descriptor
      	fields.
      	(GOMP_OFFLOAD_dev2dev): New.
      	(nvptx_adjust_launch_bounds): New.
      	(nvptx_stacks_size): New.
      	(nvptx_stacks_alloc): New.
      	(nvptx_stacks_free): New.
      	(GOMP_OFFLOAD_run): New.
      	(GOMP_OFFLOAD_async_run): New (stub).
      
      Co-Authored-By: Dmitry Melnik <dm@ispras.ru>
      Co-Authored-By: Jakub Jelinek <jakub@redhat.com>
      
      From-SVN: r242789
      Alexander Monakov committed
    • * config/mcore/mcore.c (emit_new_cond_insn): Fix prototype. · 6251fe93
      From-SVN: r242788
      Jeff Law committed
    • iq2000.c (iq2000_rtx_costs): Avoid multiplication in boolean context warning. · 7d1f0a00
      	* config/iq2000/iq2000.c (iq2000_rtx_costs): Avoid multiplication
      	in boolean context warning.
      
      From-SVN: r242787
      Jeff Law committed
    • re PR middle-end/78153 (strlen return value can be assumed to be less than PTRDIFF_MAX) · cfe3d653
      2016-11-23  Prathamesh Kulkarni  <prathamesh.kulkarni@linaro.org>
      
      	PR middle-end/78153
      	* gimple-fold.c (fold_stmt_1): Handle case for GIMPLE_RETURN.
      	* tree-vrp.c (extract_range_basic): Handle case for
      	CFN_BUILT_IN_STRLEN.
      
      testsuite/
      	* gcc.dg/tree-ssa/pr78153-1.c: New test.
      	* gcc.dg/tree-ssa/pr78153-2.c: Likewise.
      
      From-SVN: r242786
      Prathamesh Kulkarni committed
    • * config/ia64/ia64.c (ia64_emit_insn_before): Fix prototype. · 017fdefe
      From-SVN: r242785
      Jeff Law committed
    • [Patch ARM 17/17] Enable _Float16 for ARM and fix PR target/63250 · 5774b1fa
      gcc/
      
      	PR target/63250
      	* config/arm/arm-builtins.c (arm_simd_floatHF_type_node): Rename to...
      	(arm_fp16_type_node): ...This, make visibile.
      	(arm_simd_builtin_std_type): Rename arm_simd_floatHF_type_node to
      	arm_fp16_type_node.
      	(arm_init_simd_builtin_types): Likewise.
      	(arm_init_fp16_builtins): Likewise.
      	* config/arm/arm.c (arm_excess_precision): New.
      	(arm_floatn_mode): Likewise.
      	(TARGET_C_EXCESS_PRECISION): Likewise.
      	(TARGET_FLOATN_MODE): Likewise.
      	(arm_promoted_type): Only promote arm_fp16_type_node.
      	* config/arm/arm.h (arm_fp16_type_node): Declare.
      
      gcc/testsuite/
      
      	PR target/63250
      	* lib/target-supports.exp (add_options_for_float16): Add
      	-mfp16-format=ieee when testign arm*-*-*.
      
      From-SVN: r242784
      James Greenhalgh committed
    • [Patch 16/17 libgcc ARM] Half to double precision conversions · 5e0f10a0
      gcc/
      
      	* config/arm/arm.c (arm_convert_to_type): Delete.
      	(TARGET_CONVERT_TO_TYPE): Delete.
      	(arm_init_libfuncs): Enable trunc_optab from DFmode to HFmode.
      	(arm_libcall_uses_aapcs_base): Add trunc_optab from DF- to HFmode.
      	* config/arm/arm.h (TARGET_FP16_TO_DOUBLE): New.
      	* config/arm/arm.md (truncdfhf2): Only convert through SFmode if we
      	are in fast math mode, and have no single step hardware instruction.
      	(extendhfdf2): Only expand through SFmode if we don't have a
      	single-step hardware instruction.
      	* config/arm/vfp.md (*truncdfhf2): New.
      	(extendhfdf2): Likewise.
      
      gcc/testsuite/
      
      	* gcc.target/arm/fp16-rounding-alt-1.c (ROUNDED): Change expected
      	result.
      	* gcc.target/arm/fp16-rounding-ieee-1.c (ROUNDED): Change expected
      	result.
      
      From-SVN: r242783
      James Greenhalgh committed
    • [Patch 15/17 libgcc ARM] Add double to half conversions. · bea64ca3
      libgcc/
      
      	* config/arm/fp16.c (binary64): New.
      	(__gnu_d2h_internal): New.
      	(__gnu_d2h_ieee): New.
      	(__gnu_d2h_alternative): New.
      
      
      
      Co-Authored-By: Matthew Wahab <matthew.wahab@arm.com>
      
      From-SVN: r242782
      James Greenhalgh committed