1. 10 Dec, 2014 25 commits
  2. 09 Dec, 2014 15 commits
    • re PR middle-end/64225 (-funsafe-math-optimizations generates call to pow where… · c293be1a
      re PR middle-end/64225 (-funsafe-math-optimizations generates call to pow where multiply instruction would do)
      
      2014-12-09  Bill Schmidt  <wschmidt@linux.vnet.ibm.com>
      
      	PR middle-end/64225
      	* tree-ssa-reassoc.c (acceptable_pow_call): Disable transformation
      	for BUILT_IN_POW when flag_errno_math is present.
      
      From-SVN: r218546
      Bill Schmidt committed
    • lto-wrapper.c (compile_offload_image): Start processing in_argv from 0 instead of 1. · 443743fd
      gcc/
      	* lto-wrapper.c (compile_offload_image): Start processing in_argv
      	from 0 instead of 1.
      	(run_gcc): Put offload objects into offload_argv, put LTO objects and
      	possible preceding arguments into lto_argv.
      	Pass offload_argv to compile_images_for_offload_targets instead of argv.
      	Use lto_argv for LTO recompilation instead of argv.
      lto-plugin/
      	* lto-plugin.c (offload_files, num_offload_files): New static variables.
      	(free_1): Use arguments instead of global variables.
      	(free_2): Free offload_files.
      	(all_symbols_read_handler): Add names from offload_files to lto-wrapper
      	arguments.
      	(claim_file_handler): Do not add file to claimed_files if it contains
      	offload sections without LTO sections.  Add it to offload_files instead.
      
      From-SVN: r218543
      Ilya Verbin committed
    • Fix date in change log entry. · 3f6ad8df
      From-SVN: r218542
      Oleg Endo committed
    • Add missing link to PR in change log entry. · 7d0ee249
      From-SVN: r218541
      Oleg Endo committed
    • toyvm.c: use correct path in debuginfo · 5cd614ce
      gcc/jit/ChangeLog:
      	* docs/examples/tut04-toyvm/toyvm.c (toyvm_function_compile): Move
      	logic for determine "funcname" to new function...
      	(get_function_name): ...here, adding logic to skip any leading
      	path from the filename.
      	(toyvm_function_parse): Use the filename for fn_filename, rather
      	than "name", so that the debugger can locate the source .toy
      	file.
      	(toyvm_function_parse): Don't fclose a NULL FILE *.
      
      From-SVN: r218540
      David Malcolm committed
    • (libgcc_s) Optional filename-based shared library versioning on AIX. · dd913323
      2014-12-09  Michael Haubenwallner <michael.haubenwallner@ssi-schaefer.com>
      
              (libgcc_s) Optional filename-based shared library versioning on AIX.
              * gcc/doc/install.texi: Describe --with-aix-soname option.
              * Makefile.in (with_aix_soname): Define.
              * config/rs6000/t-slibgcc-aix: Act upon --with-aix-soname option.
              * configure.ac: Accept --with-aix-soname=aix|svr4|both option.
              * configure: Recreate.
      
      From-SVN: r218539
      Michael Haubenwallner committed
    • PR jit/63854: Document how to run the jit testsuite under valgrind · 2712de78
      gcc/jit/ChangeLog:
      	PR jit/63854
      	* docs/internals/index.rst (Running under valgrind): New
      	subsection.
      	(docs/_build/texinfo/libgccjit.texi): Regenerate.
      
      From-SVN: r218538
      David Malcolm committed
    • [AArch64]Remove aarch64_get_lanedi, unused · 07ad57c4
      	* config/aarch64/aarch64-simd.md (aarch64_get_lanedi): Remove.
      
      From-SVN: r218537
      Alan Lawrence committed
    • [AArch64]Remove be_checked_get_lane, check bounds with __builtin_aarch64_im_lane_boundsi. · ed225d0c
      gcc/:
      
      	PR target/63870
      	* config/aarch64/aarch64-simd-builtins.def (be_checked_get_lane):
      	Delete.
      	* config/aarch64/aarch64-simd.md (aarch64_be_checked_get_lane<mode\>):
      	Delete.
      	* config/aarch64/arm_neon.h (aarch64_vget_lane_any): Use GCC
      	vector extensions, __aarch64_lane, __builtin_aarch64_im_lane_boundsi.
      	(__aarch64_vget_lane_f32, __aarch64_vget_lane_f64,
      	__aarch64_vget_lane_p8, __aarch64_vget_lane_p16,
      	__aarch64_vget_lane_s8, __aarch64_vget_lane_s16,
      	__aarch64_vget_lane_s32, __aarch64_vget_lane_s64,
      	__aarch64_vget_lane_u8, __aarch64_vget_lane_u16,
      	__aarch64_vget_lane_u32, __aarch64_vget_lane_u64,
      	__aarch64_vgetq_lane_f32, __aarch64_vgetq_lane_f64,
      	__aarch64_vgetq_lane_p8, __aarch64_vgetq_lane_p16,
      	__aarch64_vgetq_lane_s8, __aarch64_vgetq_lane_s16,
      	__aarch64_vgetq_lane_s32, __aarch64_vgetq_lane_s64,
      	__aarch64_vgetq_lane_u8, __aarch64_vgetq_lane_u16,
      	__aarch64_vgetq_lane_u32, __aarch64_vgetq_lane_u64): Delete.
      	(__aarch64_vdup_lane_any): Use __aarch64_vget_lane_any, remove
      	'q2' argument.
      	(__aarch64_vdup_lane_f32, __aarch64_vdup_lane_f64,
      	__aarch64_vdup_lane_p8, __aarch64_vdup_lane_p16,
      	__aarch64_vdup_lane_s8, __aarch64_vdup_lane_s16,
      	__aarch64_vdup_lane_s32, __aarch64_vdup_lane_s64,
      	__aarch64_vdup_lane_u8, __aarch64_vdup_lane_u16,
      	__aarch64_vdup_lane_u32, __aarch64_vdup_lane_u64,
      	__aarch64_vdup_laneq_f32, __aarch64_vdup_laneq_f64,
      	__aarch64_vdup_laneq_p8, __aarch64_vdup_laneq_p16,
      	__aarch64_vdup_laneq_s8, __aarch64_vdup_laneq_s16,
      	__aarch64_vdup_laneq_s32, __aarch64_vdup_laneq_s64,
      	__aarch64_vdup_laneq_u8, __aarch64_vdup_laneq_u16,
      	__aarch64_vdup_laneq_u32, __aarch64_vdup_laneq_u64): Remove argument
      	to __aarch64_vdup_lane_any.
      	(vget_lane_f32, vget_lane_f64, vget_lane_p8, vget_lane_p16,
      	vget_lane_s8, vget_lane_s16, vget_lane_s32, vget_lane_s64,
      	vget_lane_u8, vget_lane_u16, vget_lane_u32, vget_lane_u64,
      	vgetq_lane_f32, vgetq_lane_f64, vgetq_lane_p8, vgetq_lane_p16,
      	vgetq_lane_s8, vgetq_lane_s16, vgetq_lane_s32, vgetq_lane_s64,
      	vgetq_lane_u8, vgetq_lane_u16, vgetq_lane_u32, vgetq_lane_u64,
      	vdupb_lane_p8, vdupb_lane_s8, vdupb_lane_u8, vduph_lane_p16,
      	vduph_lane_s16, vduph_lane_u16, vdups_lane_f32, vdups_lane_s32,
      	vdups_lane_u32, vdupb_laneq_p8, vdupb_laneq_s8, vdupb_laneq_u8,
      	vduph_laneq_p16, vduph_laneq_s16, vduph_laneq_u16, vdups_laneq_f32,
      	vdups_laneq_s32, vdups_laneq_u32, vdupd_laneq_f64, vdupd_laneq_s64,
      	vdupd_laneq_u64, vfmas_lane_f32, vfma_laneq_f64, vfmad_laneq_f64,
      	vfmas_laneq_f32, vfmss_lane_f32, vfms_laneq_f64, vfmsd_laneq_f64,
      	vfmss_laneq_f32, vmla_lane_f32, vmla_lane_s16, vmla_lane_s32,
      	vmla_lane_u16, vmla_lane_u32, vmla_laneq_f32, vmla_laneq_s16,
      	vmla_laneq_s32, vmla_laneq_u16, vmla_laneq_u32, vmlaq_lane_f32,
      	vmlaq_lane_s16, vmlaq_lane_s32, vmlaq_lane_u16, vmlaq_lane_u32,
      	vmlaq_laneq_f32, vmlaq_laneq_s16, vmlaq_laneq_s32, vmlaq_laneq_u16,
      	vmlaq_laneq_u32, vmls_lane_f32, vmls_lane_s16, vmls_lane_s32,
      	vmls_lane_u16, vmls_lane_u32, vmls_laneq_f32, vmls_laneq_s16,
      	vmls_laneq_s32, vmls_laneq_u16, vmls_laneq_u32, vmlsq_lane_f32,
      	vmlsq_lane_s16, vmlsq_lane_s32, vmlsq_lane_u16, vmlsq_lane_u32,
      	vmlsq_laneq_f32, vmlsq_laneq_s16, vmlsq_laneq_s32, vmlsq_laneq_u16,
      	vmlsq_laneq_u32, vmul_lane_f32, vmul_lane_s16, vmul_lane_s32,
      	vmul_lane_u16, vmul_lane_u32, vmuld_lane_f64, vmuld_laneq_f64,
      	vmuls_lane_f32, vmuls_laneq_f32, vmul_laneq_f32, vmul_laneq_f64,
      	vmul_laneq_s16, vmul_laneq_s32, vmul_laneq_u16, vmul_laneq_u32,
      	vmulq_lane_f32, vmulq_lane_s16, vmulq_lane_s32, vmulq_lane_u16,
      	vmulq_lane_u32, vmulq_laneq_f32, vmulq_laneq_f64, vmulq_laneq_s16,
      	vmulq_laneq_s32, vmulq_laneq_u16, vmulq_laneq_u32) : Use
      	__aarch64_vget_lane_any.
      
      gcc/testsuite/:
      
      	* gcc.target/aarch64/simd/vget_lane_f32_indices_1.c: New test.
      	* gcc.target/aarch64/simd/vget_lane_f64_indices_1.c: Likewise.
      	* gcc.target/aarch64/simd/vget_lane_p16_indices_1.c: Likewise.
      	* gcc.target/aarch64/simd/vget_lane_p8_indices_1.c: Likewise.
      	* gcc.target/aarch64/simd/vget_lane_s16_indices_1.c: Likewise.
      	* gcc.target/aarch64/simd/vget_lane_s32_indices_1.c: Likewise.
      	* gcc.target/aarch64/simd/vget_lane_s64_indices_1.c: Likewise.
      	* gcc.target/aarch64/simd/vget_lane_s8_indices_1.c: Likewise.
      	* gcc.target/aarch64/simd/vget_lane_u16_indices_1.c: Likewise.
      	* gcc.target/aarch64/simd/vget_lane_u32_indices_1.c: Likewise.
      	* gcc.target/aarch64/simd/vget_lane_u64_indices_1.c: Likewise.
      	* gcc.target/aarch64/simd/vget_lane_u8_indices_1.c: Likewise.
      	* gcc.target/aarch64/simd/vgetq_lane_f32_indices_1.c: Likewise.
      	* gcc.target/aarch64/simd/vgetq_lane_f64_indices_1.c: Likewise.
      	* gcc.target/aarch64/simd/vgetq_lane_p16_indices_1.c: Likewise.
      	* gcc.target/aarch64/simd/vgetq_lane_p8_indices_1.c: Likewise.
      	* gcc.target/aarch64/simd/vgetq_lane_s16_indices_1.c: Likewise.
      	* gcc.target/aarch64/simd/vgetq_lane_s32_indices_1.c: Likewise.
      	* gcc.target/aarch64/simd/vgetq_lane_s64_indices_1.c: Likewise.
      	* gcc.target/aarch64/simd/vgetq_lane_s8_indices_1.c: Likewise.
      	* gcc.target/aarch64/simd/vgetq_lane_u16_indices_1.c: Likewise.
      	* gcc.target/aarch64/simd/vgetq_lane_u32_indices_1.c: Likewise.
      	* gcc.target/aarch64/simd/vgetq_lane_u64_indices_1.c: Likewise.
      	* gcc.target/aarch64/simd/vgetq_lane_u8_indices_1.c: Likewise.
      
      From-SVN: r218536
      Alan Lawrence committed
    • Add missing PR numbers to ChangeLog. Too late? · fdead6a4
      From-SVN: r218535
      Alan Lawrence committed
    • [AArch64]Improve error message for non-constant immediates · fca051af
      gcc/:
      
      	* gcc/config/aarch64-builtins.c (aarch64_simd_expand_args): Update error
      	message for SIMD_ARG_CONSTANT.
      
      gcc/testsuite/:
      
      	* gcc.target/aarch64/arg-type-diagnostics-1.c: Call intrinsic, update
      	expected error message.
      
      From-SVN: r218534
      Alan Lawrence committed
    • Add jit-tempdir.{c|h} · d1e5f2c7
      gcc/jit/ChangeLog:
              PR jit/64206
      	* Make-lang.in (jit_OBJS): Add jit/jit-tempdir.o.
      	* jit-common.h (gcc::jit::tempdir): New forward decl.
      	* jit-playback.c: Include jit-tempdir.h.
      	(gcc::jit::playback::context::context): Initialize m_tempdir.
      	(gcc::jit::playback::context::~context): Move tempdir
      	cleanup to new file jit-tempdir.c
      	(make_tempdir_path_template): Move to new file jit-tempdir.c.
      	(gcc::jit::playback::context::compile): Move tempdir creation
      	to new tempdir object in new file jit-tempdir.c.
      	(gcc::jit::playback::context::make_fake_args): Get path from
      	tempdir object rather than from member data.
      	(gcc::jit::playback::context::convert_to_dso): Likewise.
      	(gcc::jit::playback::context::dlopen_built_dso): Likewise.
      	(gcc::jit::playback::context::dump_generated_code): Likewise.
      	(gcc::jit::playback::context::get_path_c_file): New function.
      	(gcc::jit::playback::context::get_path_s_file): New function.
      	(gcc::jit::playback::context::get_path_so_file): New function.
      	* jit-playback.h (gcc::jit::playback::context::get_path_c_file):
      	New function.
      	(gcc::jit::playback::context::get_path_s_file): New function.
      	(gcc::jit::playback::context::get_path_so_file): New function.
      	(gcc::jit::playback::context): Move fields "m_path_template",
      	"m_path_tempdir", "m_path_c_file", "m_path_s_file",
      	"m_path_so_file" to new jit::tempdir class; add field "m_tempdir".
      	* jit-tempdir.c: New file.
      	* jit-tempdir.h: New file.
      
      From-SVN: r218533
      David Malcolm committed
    • [AArch64] Fix ICE on non-constant indices to __builtin_aarch64_im_lane_boundsi · 661fce82
      gcc/:
      
      	* config/aarch64/aarch64-builtins.c (aarch64_types_binopv_qualifiers,
      	TYPES_BINOPV): Delete.
      	(enum aarch64_builtins): Add AARCH64_BUILTIN_SIMD_LANE_CHECK and
      	AARCH64_SIMD_PATTERN_START.
      	(aarch64_init_simd_builtins): Register
      	__builtin_aarch64_im_lane_boundsi; use  AARCH64_SIMD_PATTERN_START.
      	(aarch64_simd_expand_builtin): Handle AARCH64_BUILTIN_LANE_CHECK; use
      	AARCH64_SIMD_PATTERN_START.
      
      	* config/aarch64/aarch64-simd.md (aarch64_im_lane_boundsi): Delete.
      	* config/aarch64/aarch64-simd-builtins.def (im_lane_bound): Delete.
      
      	* config/aarch64/arm_neon.h (__AARCH64_LANE_CHECK): New.
      	(__aarch64_vget_lane_f64, __aarch64_vget_lane_s64,
      	__aarch64_vget_lane_u64, __aarch64_vset_lane_any, vdupd_lane_f64,
      	vdupd_lane_s64, vdupd_lane_u64, vext_f32, vext_f64, vext_p8, vext_p16,
      	vext_s8, vext_s16, vext_s32, vext_s64, vext_u8, vext_u16, vext_u32,
      	vext_u64, vextq_f32, vextq_f64, vextq_p8, vextq_p16, vextq_s8,
      	vextq_s16, vextq_s32, vextq_s64, vextq_u8, vextq_u16, vextq_u32,
      	vextq_u64, vmulq_lane_f64): Use __AARCH64_LANE_CHECK.
      
      gcc/testsuite/:
      
      	* gcc.target/aarch64/simd/vset_lane_s16_const_1.c: New test.
      
      From-SVN: r218532
      Alan Lawrence committed
    • [AArch64]Fix ICE at -O0 on vld1_lane intrinsics · 2310e29f
      gcc/:
      
      	* config/aarch64/arm_neon.h (__AARCH64_NUM_LANES, __aarch64_lane *2):
      	New.
      	(aarch64_vset_lane_any): Redefine using previous, same for BE + LE.
      	(vset_lane_f32, vset_lane_f64, vset_lane_p8, vset_lane_p16,
      	vset_lane_s8, vset_lane_s16, vset_lane_s32, vset_lane_s64,
      	vset_lane_u8, vset_lane_u16, vset_lane_u32, vset_lane_u64): Remove
      	number of lanes.
      	(vld1_lane_f32, vld1_lane_f64, vld1_lane_p8, vld1_lane_p16,
      	vld1_lane_s8, vld1_lane_s16, vld1_lane_s32, vld1_lane_s64,
      	vld1_lane_u8, vld1_lane_u16, vld1_lane_u32, vld1_lane_u64): Call
      	__aarch64_vset_lane_any rather than vset_lane_xxx.
      
      gcc/testsuite/:
      
      	* gcc.target/aarch64/vld1_lane-o0.c: New test.
      
      From-SVN: r218531
      Alan Lawrence committed
    • vabs_intrinsic_2.c: New test. · 8f905d69
      gcc/testsuite/:
      
              * gcc.target/aarch64/vabs_intrinsic_2.c: New test.
      
      From-SVN: r218530
      Alan Lawrence committed