1. 27 Jul, 2016 4 commits
    • predict.c: merge multi-edges · 5d9da222
      	* gcc.dg/predict-13.c: New test.
      	* gcc.dg/predict-14.c: New test.
      	* predict.c (set_even_probabilities): Handle unlikely edges.
      	(combine_predictions_for_bb): Likewise.
      
      From-SVN: r238781
      Martin Liska committed
    • Use __{U,}INTPTR_TYPE__ to avoid including stdint.h · af9e275f
      gcc/testsuite/
      
      	* gcc.dg/torture/pr69352.c: Use  __INTPTR_TYPE__ instead of 
      	including stdint.h.
      	* gcc.dg/torture/pr71866.c: Use __UINTPTR_TYPE__ isntead of
      	including stdint.h.
      
      From-SVN: r238780
      Senthil Kumar Selvaraj committed
    • re PR target/71869 (__builtin_isgreater raises an invalid exception on PPC64… · 71abba1e
      re PR target/71869 (__builtin_isgreater raises an invalid exception on PPC64 using __float128 inputs.)
      
      [gcc]
      2016-07-26  Michael Meissner  <meissner@linux.vnet.ibm.com>
      
      	PR target/71869
      	* config/rs6000/rs6000.c (rs6000_generate_compare): Rework
      	__float128 support when we don't have hardware support, so that
      	the IEEE built-in functions like isgreater, first call __unordkf3
      	to make sure neither operand is a NaN, and if both operands are
      	ordered, do the normal comparison.
      
      [gcc/testsuite]
      2016-07-26  Michael Meissner  <meissner@linux.vnet.ibm.com>
      
      	PR target/71869
      	* gcc.target/powerpc/float128-cmp.c: New test to make sure that
      	IEEE built-in functions handle quiet and signalling NaNs
      	correctly.
      
      From-SVN: r238779
      Michael Meissner committed
    • Daily bump. · 2f65c3b3
      From-SVN: r238778
      GCC Administrator committed
  2. 26 Jul, 2016 23 commits
    • re PR fortran/71862 (ICE in gfc_add_component_ref, at fortran/class.c:241) · 9cd74e8f
      2016-07-22  Steven G. Kargl  <kargl@gcc.gnu.org>
      
      	PR fortran/71862
      	* class.c: Remove assert.  Iterate over component only if non-null.
      
      2016-07-22  Steven G. Kargl  <kargl@gcc.gnu.org>
      
      	PR fortran/71862
      	* gfortran.dg/pr71862.f90: New test.
      
      From-SVN: r238774
      Steven G. Kargl committed
    • pr71675.c: Replace the unsupported c11 target selector with dg-options. · 0d48446f
      gcc/testsuite/ChangeLog:
      	* gcc.dg/atomic/pr71675.c: Replace the unsupported c11 target
      	selector with dg-options.
      
      From-SVN: r238766
      Martin Sebor committed
    • Missed changelog entries for commit 238252. Sorry, · 9e63c3aa
      2016-07-12  Nathan Sidwell  <nathan@acm.org>
      
      	* config/arm/arm.c (arm_option_override): Set MASK_SINGLE_PIC_BASE
      	when -mno-pic-data-is-text-relative is in effect, by default.
      	* doc/invoke.texi (mpic-data-is-text-relative): Document new
      	behavior and clarify.
      
      2016-07-12  Nathan Sidwell  <nathan@acm.org>
      
      	* gcc.target/arm/data-rel-1.c: New.
      	* gcc.target/arm/data-rel-2.c: New.
      	* gcc.target/arm/data-rel-3.c: New.
      
      From-SVN: r238763
      Nathan Sidwell committed
    • Minor changes in tree-vrp.c · e04de667
      gcc/ChangeLog:
      
      	* tree-vrp.c (dump_asserts_for): Print loc->expr instead of
      	name.
      	(extract_code_and_val_from_cond_with_ops): Verify that name is
      	either cond_op0 or cond_op1.
      
      From-SVN: r238762
      Patrick Palka committed
    • Teach VRP to register assertions along default switch labels (PR18046) · 524cf1e4
      gcc/ChangeLog:
      
      	PR tree-optimization/18046
      	* genmodes.c (emit_mode_size_inline): Emit an assert that
      	verifies that mode is a valid array index.
      	(emit_mode_nuinits_inline): Likewise.
      	(emit_mode_inner_inline): Likewise.
      	(emit_mode_unit_size_inline): Likewise.
      	(emit_mode_unit_precision_inline): Likewise.
      	* tree-vrp.c: Include params.h.
      	(find_switch_asserts): Register edge assertions for the default
      	label which correspond to the anti-ranges of each case label.
      	* params.def (PARAM_MAX_VRP_SWITCH_ASSERTIONS): New.
      	* doc/invoke.texi: Document it.
      
      gcc/testsuite/ChangeLog:
      
      	PR tree-optimization/18046
      	* gcc.dg/tree-ssa/ssa-dom-thread-6.c: Bump FSM count to 5.
      	* gcc.dg/tree-ssa/vrp103.c: New test.
      	* gcc.dg/tree-ssa/vrp104.c: New test.
      
      From-SVN: r238761
      Patrick Palka committed
    • Move ChangeLog entry to the right place · 100665d8
      From-SVN: r238760
      William Schmidt committed
    • pr63354.c: Require lp64 since -mprofile-kernel is not legal with -m32. · ed26375b
      2016-07-26  Bill Schmidt  <wschmidt@linux.vnet.ibm.com>
      
      	* gcc.target/powerpc/pr63354.c: Require lp64 since
      	-mprofile-kernel is not legal with -m32.
      
      From-SVN: r238759
      Bill Schmidt committed
    • gimple-ssa-strength-reduction.c (slsr_process_phi): Remove dead and unnecessary call to gimple_bb. · 6e281ce3
      2016-07-26  Bill Schmidt  <wschmidt@linux.vnet.ibm.com>
      
      	* gimple-ssa-strength-reduction.c (slsr_process_phi): Remove dead
      	and unnecessary call to gimple_bb.
      
      From-SVN: r238758
      Bill Schmidt committed
    • re PR rtl-optimization/71984 (wrong code with -O -mavx512cd) · 0b64ca40
      2016-07-26  Richard Biener  <rguenther@suse.de>
      
      	PR rtl-optimization/71984
      	* simplify-rtx.c (simplify_subreg): Use GET_MODE_SIZE and prepare
      	for VOIDmode.
      
      	* gcc.dg/torture/pr71984.c: New testcase.
      
      From-SVN: r238757
      Richard Biener committed
    • re PR tree-optimization/72517 (436.cactusADM: More than 40% regression in O3 and… · ab2b55c1
      re PR tree-optimization/72517 (436.cactusADM: More than 40% regression in O3 and Ofast on AMD bdver4 m/c.)
      
      2016-07-26  Richard Biener  <rguenther@suse.de>
      
      	PR middle-end/72517
      	* expmed.c (extract_bit_field_1): Constrain the vector mode
      	with element size matching the extraction mode size when
      	choosing a better vector mode to do the extraction from.
      
      From-SVN: r238756
      Richard Biener committed
    • Add support to run auto-vectorization tests for multiple effective targets. · 9b7937cf
      gcc/testsuite/
      
      	* g++.dg/vect/vect.exp: Add and set new global EFFECTIVE_TARGETS. Call
      	g++-dg-runtest via et-dg-runtest.
      	* gcc.dg/graphite/graphite.exp: Likewise, but for dg-runtest.
      	* gcc.dg/vect/vect.exp: Likewise.
      	* gfortran.dg/graphite/graphite.exp: Likewise, but for
      	gfortran-dg-runtest.
      	* gfortran.dg/vect/vect.exp: Likewise.
      	* lib/target-supports.exp (check_mpaired_single_hw_available): New.
      	(check_mips_loongson_hw_available): Likewise.
      	(check_effective_target_mpaired_single_runtime): Likewise.
      	(check_effective_target_mips_loongson_runtime): Likewise.
      	(add_options_for_mpaired_single): Likewise.
      	(check_effective_target_vect_int): Add global et_index.
      	Check and save the supported feature for a target selected by
      	the et_index target.  Break long lines where appropriate.  Call
      	et-is-effective-target for MIPS with an argument instead of
      	check_effective_target_* where appropriate.
      	(check_effective_target_vect_intfloat_cvt): Likewise.
      	(check_effective_target_vect_uintfloat_cvt): Likewise.
      	(check_effective_target_vect_floatint_cvt): Likewise.
      	(check_effective_target_vect_floatuint_cvt): Likewise.
      	(check_effective_target_vect_simd_clones): Likewise.
      	(check_effective_target_vect_shift): ewise.
      	(check_effective_target_whole_vector_shift): Likewise.
      	(check_effective_target_vect_bswap): Likewise.
      	(check_effective_target_vect_shift_char): Likewise.
      	(check_effective_target_vect_long): Likewise.
      	(check_effective_target_vect_float): Likewise.
      	(check_effective_target_vect_double): Likewise.
      	(check_effective_target_vect_long_long): Likewise.
      	(check_effective_target_vect_no_int_max): Likewise.
      	(check_effective_target_vect_no_int_add): Likewise.
      	(check_effective_target_vect_no_bitwise): Likewise.
      	(check_effective_target_vect_widen_shift): Likewise.
      	(check_effective_target_vect_no_align): Likewise.
      	(check_effective_target_vect_hw_misalign): Likewise.
      	(check_effective_target_vect_element_align): Likewise.
      	(check_effective_target_vect_condition): Likewise.
      	(check_effective_target_vect_cond_mixed): Likewise.
      	(check_effective_target_vect_char_mult): Likewise.
      	(check_effective_target_vect_short_mult): Likewise.
      	(check_effective_target_vect_int_mult): Likewise.
      	(check_effective_target_vect_extract_even_odd): Likewise.
      	(check_effective_target_vect_interleave): Likewise.
      	(check_effective_target_vect_stridedN): Likewise.
      	(check_effective_target_vect_multiple_sizes): Likewise.
      	(check_effective_target_vect64): Likewise.
      	(check_effective_target_vect_call_copysignf): Likewise.
      	(check_effective_target_vect_call_sqrtf): Likewise.
      	(check_effective_target_vect_call_btrunc): Likewise.
      	(check_effective_target_vect_call_btruncf): Likewise.
      	(check_effective_target_vect_call_ceil): Likewise.
      	(check_effective_target_vect_call_ceilf): Likewise.
      	(check_effective_target_vect_call_floor): Likewise.
      	(check_effective_target_vect_call_floorf): Likewise.
      	(check_effective_target_vect_call_lceil): Likewise.
      	(check_effective_target_vect_call_lfloor): Likewise.
      	(check_effective_target_vect_call_nearbyint): Likewise.
      	(check_effective_target_vect_call_nearbyintf): Likewise.
      	(check_effective_target_vect_call_round): Likewise.
      	(check_effective_target_vect_call_roundf): Likewise.
      	(check_effective_target_vect_perm): Likewise, but also append *_saved
      	to the existing global name to properly cache the result.
      	(check_effective_target_vect_perm_byte): Likewise.
      	(check_effective_target_vect_perm_short): Likewise.
      	(check_effective_target_vect_widen_sum_hi_to_si_pattern): Likewise.
      	(check_effective_target_vect_widen_sum_hi_to_si): Likewise.
      	(check_effective_target_vect_widen_sum_qi_to_hi): Likewise.
      	(check_effective_target_vect_widen_sum_qi_to_si): Likewise.
      	(check_effective_target_vect_widen_mult_qi_to_hi_pattern): Likewise.
      	(check_effective_target_vect_widen_mult_qi_to_hi): Likewise.
      	(check_effective_target_vect_widen_mult_hi_to_si_pattern): Likewise.
      	(check_effective_target_vect_widen_mult_si_to_di_pattern): Likewise.
      	(check_effective_target_vect_sdot_qi): Likewise.
      	(check_effective_target_vect_udot_qi): Likewise.
      	(check_effective_target_vect_sdot_hi): Likewise.
      	(check_effective_target_vect_udot_hi): Likewise.
      	(check_effective_target_vect_usad_char): Likewise.
      	(check_effective_target_vect_pack_trunc): Likewise.
      	(check_effective_target_vect_unpack): Likewise.
      	(check_effective_target_vect_aligned_arrays): Likewise.
      	(check_effective_target_vect_natural_alignment): Likewise.
      	(check_effective_target_vector_alignment_reachable): Likewise.
      	(check_effective_target_vector_alignment_reachable_for_64bit): Likewise.
      	(is-effective-target): Initialize et_index if undefined.
      	(et-dg-runtest): New.
      	(et-is-effective-target): Likewise.
      	(check_vect_support_and_set_flags): Add supported MIPS targets to
      	EFFECTIVE_TARGETS list.  Return the number of supported targets.
      
      From-SVN: r238755
      Robert Suchanek committed
    • re PR middle-end/70920 (if ((intptr_t)ptr == 0) doesn't get simplified to if (ptr == 0)) · 8f63caf6
      2016-07-26  Richard Biener  <rguenther@suse.de>
      	    Prathamesh Kulkarni <prathamesh.kulkarni@linaro.org>
      
      	PR middle-end/70920
      	* match.pd ((intptr)x eq/ne CST to x eq/ne (typeof x) CST): New
      	pattern.
      
      testsuite/
      	* gcc.dg/pr70920-1.c: New test-case.
      	* gcc.dg/pr70902-2.c: Likewise.
      	* gcc.dg/pr70920-3.c: Likewise.
      	* gcc.dg/pr70920-4.c: Likewise
      	* gcc.dg/tree-ssa/ssa-dom-branch-1.c: Change scan-tree-dump-times to
      	2 instead of 3.
      
      Co-Authored-By: Prathamesh Kulkarni <prathamesh.kulkarni@linaro.org>
      
      From-SVN: r238754
      Richard Biener committed
    • update_version_svn: Ignore the GCC 4.9 branch. · c4f82055
      2016-07-26  Richard Biener  <rguenther@suse.de>
      
      	* update_version_svn: Ignore the GCC 4.9 branch.
      
      From-SVN: r238753
      Richard Biener committed
    • crontab: Remove entry for the GCC 4.9 branch. · 7055b2bb
      2016-07-26  Richard Biener  <rguenther@suse.de>
      
      	* crontab: Remove entry for the GCC 4.9 branch.
      
      From-SVN: r238752
      Richard Biener committed
    • add [cd]tors to scc_info · b46e8e6a
      gcc/ChangeLog:
      
      2016-07-26  Trevor Saunders  <tbsaunde+gcc@tbsaunde.org>
      
      	* tree-ssa-structalias.c (struct scc_info): Change types of
      	members to auto_sbitmap and auto_vec.
      	(scc_info::scc_info): New constructor.
      	(scc_info::~scc_info): New destructor.
      	(init_scc_info): Remove.
      	(free_scc_info): Remove.
      	(find_indirect_cycles): Adjust.
      	(perform_var_substitution): Likewise.
      	(free_var_substitution_info): Likewise.
      
      From-SVN: r238751
      Trevor Saunders committed
    • add a constructor to elim_graph · 61801db9
      gcc/ChangeLog:
      
      2016-07-26  Trevor Saunders  <tbsaunde+gcc@tbsaunde.org>
      
      	* tree-outof-ssa.c (struct elim_graph): Change type of members
      	to auto_vec and auto_sbitmap.
      	(elim_graph::elim_graph): New constructor.
      	(delete_elim_graph): Remove.
      	(expand_phi_nodes): Adjust.
      
      From-SVN: r238750
      Trevor Saunders committed
    • remove elim_graph typedef · c8b1ebd9
      gcc/ChangeLog:
      
      2016-07-26  Trevor Saunders  <tbsaunde+gcc@tbsaunde.org>
      
      	* tree-outof-ssa.c (struct elim_graph): Remove typedef.
      	(new_elim_graph): Adjust.
      	(clear_elim_graph): Likewise.
      	(delete_elim_graph): Likewise.
      	(elim_graph_size): Likewise.
      	(elim_graph_add_node): Likewise.
      	(elim_graph_add_edge): Likewise.
      	(elim_graph_remove_succ_edge): Likewise.
      	(eliminate_name): Likewise.
      	(eliminate_build): Likewise.
      	(elim_forward): Likewise.
      	(elim_unvisited_predecessor): Likewise.
      	(elim_backward): Likewise.
      	(elim_create): Likewise.
      	(eliminate_phi): Likewise.
      	(expand_phi_nodes): Likewise.
      
      From-SVN: r238749
      Trevor Saunders committed
    • use auto_sbitmap in various places · 7ba9e72d
      gcc/ChangeLog:
      
      2016-07-26  Trevor Saunders  <tbsaunde+gcc@tbsaunde.org>
      
      	* bt-load.c (compute_out): Use auto_sbitmap class.
      	(link_btr_uses): Likewise.
      	* cfganal.c (mark_dfs_back_edges): Likewise.
      	(post_order_compute): Likewise.
      	(inverted_post_order_compute): Likewise.
      	(pre_and_rev_post_order_compute_fn): Likewise.
      	(single_pred_before_succ_order): Likewise.
      	* cfgexpand.c (pass_expand::execute): Likewise.
      	* cfgloop.c (verify_loop_structure): Likewise.
      	* cfgloopmanip.c (fix_bb_placements): Likewise.
      	(remove_path): Likewise.
      	(update_dominators_in_loop): Likewise.
      	* cfgrtl.c (break_superblocks): Likewise.
      	* ddg.c (check_sccs): Likewise.
      	(create_ddg_all_sccs): Likewise.
      	* df-core.c (df_worklist_dataflow): Likewise.
      	* dse.c (dse_step3): Likewise.
      	* except.c (eh_region_outermost): Likewise.
      	* function.c (thread_prologue_and_epilogue_insns): Likewise.
      	* gcse.c (prune_expressions): Likewise.
      	(prune_insertions_deletions): Likewise.
      	* gimple-ssa-backprop.c (backprop::~backprop): Likewise.
      	* graph.c (draw_cfg_nodes_no_loops): Likewise.
      	* ira-lives.c (remove_some_program_points_and_update_live_ranges): Likewise.
      	* lcm.c (compute_earliest): Likewise.
      	(compute_farthest): Likewise.
      	* loop-unroll.c (unroll_loop_constant_iterations): Likewise.
      	(unroll_loop_runtime_iterations): Likewise.
      	(unroll_loop_stupid): Likewise.
      	* lower-subreg.c (decompose_multiword_subregs): Likewise.
      	* lra-lives.c: Likewise.
      	* lra.c (lra): Likewise.
      	* modulo-sched.c (schedule_reg_moves): Likewise.
      	(optimize_sc): Likewise.
      	(get_sched_window): Likewise.
      	(sms_schedule_by_order): Likewise.
      	(check_nodes_order): Likewise.
      	(order_nodes_of_sccs): Likewise.
      	(order_nodes_in_scc): Likewise.
      	* recog.c (split_all_insns): Likewise.
      	* regcprop.c (pass_cprop_hardreg::execute): Likewise.
      	* reload1.c (reload): Likewise.
      	* sched-rgn.c (haifa_find_rgns): Likewise.
      	(split_edges): Likewise.
      	(compute_trg_info): Likewise.
      	* sel-sched.c (init_seqno): Likewise.
      	* store-motion.c (remove_reachable_equiv_notes): Likewise.
      	* tree-into-ssa.c (update_ssa): Likewise.
      	* tree-ssa-live.c (live_worklist): Likewise.
      	* tree-ssa-loop-im.c (fill_always_executed_in): Likewise.
      	* tree-ssa-loop-ivcanon.c (try_unroll_loop_completely):
      	* Likewise.
      	(try_peel_loop): Likewise.
      	* tree-ssa-loop-manip.c (tree_transform_and_unroll_loop):
      	* Likewise.
      	* tree-ssa-pre.c (compute_antic): Likewise.
      	* tree-ssa-reassoc.c (undistribute_ops_list): Likewise.
      	* tree-stdarg.c (reachable_at_most_once): Likewise.
      	* tree-vect-slp.c (vect_attempt_slp_rearrange_stmts): Likewise.
      	* var-tracking.c (vt_find_locations): Likewise.
      
      From-SVN: r238748
      Trevor Saunders committed
    • add auto_sbitmap class · 62e20785
      gcc/ChangeLog:
      
      2016-07-26  Trevor Saunders  <tbsaunde+gcc@tbsaunde.org>
      
      	* sbitmap.h (auto_sbitmap): New class.
      
      From-SVN: r238747
      Trevor Saunders committed
    • [RS6000] push_secondary_reload ICE · 3ef7d223
      	PR target/72103
      	* config/rs6000/rs6000.c (rs6000_secondary_reload): Initialize
      	sri->t_icode.
      
      From-SVN: r238744
      Alan Modra committed
    • os/user: fix Solaris declaration. · 870e8ca5
          
          Patch from Rainer Orth.
          
          Reviewed-on: https://go-review.googlesource.com/25210
      
      From-SVN: r238742
      Ian Lance Taylor committed
    • Daily bump. · 4c2726ef
      From-SVN: r238741
      GCC Administrator committed
  3. 25 Jul, 2016 13 commits
    • PR c++/65970 - revert loop location change · 1509db23
      	* cp-gimplify.c (genericize_cp_loop): Revert location change.
      
      From-SVN: r238737
      Jason Merrill committed
    • PR c++/71837 - pack expansion in init-capture · 47265942
      	* lambda.c (add_capture): Leave a pack expansion in a TREE_LIST.
      	(build_lambda_object): Call build_x_compound_expr_from_list.
      	* pt.c (tsubst) [DECLTYPE_TYPE]: Likewise.
      
      From-SVN: r238733
      Jason Merrill committed
    • Fix selftest::temp_source_file ctor · e27f0bc9
      gcc/ChangeLog:
      	* input.c (selftest::temp_source_file::temp_source_file): Fix
      	missing "%s" in fprintf.
      
      From-SVN: r238732
      David Malcolm committed
    • PR c++/71833 - member template with two parameter packs · fd8b207a
      	PR c++/54440
      	* pt.c (coerce_template_parameter_pack): Fix logic for
      	pack index.
      
      From-SVN: r238731
      Jason Merrill committed
    • PR c++/65970 - constexpr infinite loop · 5ec2cd9f
      gcc/c-family/
      	* c.opt (fconstexpr-loop-limit): New.
      gcc/cp/
      	* constexpr.c (cxx_eval_loop_expr): Count iterations.
      	* cp-gimplify.c (genericize_cp_loop): Use start_locus even for
      	infinite loops.
      
      From-SVN: r238730
      Jason Merrill committed
    • PR c++/71972 - constexpr array self-modification · fd2bfee5
      	* constexpr.c (cxx_eval_array_reference): Handle looking for the
      	value of an element we're currently modifying.
      
      From-SVN: r238729
      Jason Merrill committed
    • * g++.dg/init/elide5.C: Don't use unsigned long for size_t. · 8d683375
      From-SVN: r238728
      Jason Merrill committed
    • re PR middle-end/71732 (FAIL: gcc.dg/torture/pr71532.c at -O2 and above) · 007b405b
      	PR middle-end/71732
      	* cselib.c (cselib_process_insn): Invalidate argument slots for
      	const/pure calls.
      
      From-SVN: r238727
      John David Anglin committed
    • testsuite: add two missing label_values annotations · 7d575fff
      2016-07-25  Alexander Monakov  <amonakov@ispras.ru>
      
      	* gcc.c-torture/execute/pr71494.c: Require label_values.
      	* gcc.dg/pr16973.c: Ditto.
      
      From-SVN: r238726
      Alexander Monakov committed
    • [AArch64][10/10] ARMv8.2-A FP16 lane scalar intrinsics · bb6131db
      gcc/
      	* config/aarch64/arm_neon.h (vfmah_lane_f16, vfmah_laneq_f16,
      	vfmsh_lane_f16, vfmsh_laneq_f16, vmulh_lane_f16, vmulh_laneq_f16,
      	vmulxh_lane_f16, vmulxh_laneq_f16): New.
      
      From-SVN: r238725
      Jiong Wang committed
    • [AArch64][9/10] ARMv8.2-A FP16 three operands scalar intrinsics · 9a594ad6
      gcc/
      	* config/aarch64/aarch64-simd-builtins.def: Register new builtins.
      	* config/aarch64/aarch64.md (fma, fnma): Support HF.
      	* config/aarch64/arm_fp16.h (vfmah_f16, vfmsh_f16): New.
      
      From-SVN: r238724
      Jiong Wang committed
    • [AArch64][8/10] ARMv8.2-A FP16 two operands scalar intrinsics · 68ad28c3
      gcc/
      	* config/aarch64/aarch64-simd-builtins.def: Register new builtins.
      	* config/aarch64/aarch64.md (<FCVT_F2FIXED:fcvt_fixed_insn>hf<mode>3):
      	New.
      	(<FCVT_FIXED2F:fcvt_fixed_insn><mode>hf3): Likewise.
      	(add<mode>3): Likewise.
      	(sub<mode>3): Likewise.
      	(mul<mode>3): Likewise.
      	(div<mode>3): Likewise.
      	(*div<mode>3): Likewise.
      	(<fmaxmin><mode>3): Extend to HF.
      	* config/aarch64/aarch64-simd.md (aarch64_rsqrts<mode>): Likewise.
      	(fabd<mode>3): Likewise.
      	(<FCVT_F2FIXED:fcvt_fixed_insn><VHSDF_HSDF:mode>3): Likewise.
      	(<FCVT_FIXED2F:fcvt_fixed_insn><VHSDI_HSDI:mode>3): Likewise.
      	(aarch64_fmulx<mode>): Likewise.
      	(aarch64_fac<optab><mode>): Likewise.
      	(aarch64_frecps<mode>): Likewise.
      	(<FCVT_F2FIXED:fcvt_fixed_insn>hfhi3): New.
      	(<FCVT_FIXED2F:fcvt_fixed_insn>hihf3): Likewise.
      	* config/aarch64/iterators.md (VHSDF_SDF): Delete.
      	(VSDQ_HSDI): Support HI.
      	(fcvt_target, FCVT_TARGET): Likewise.
      	* config/aarch64/arm_fp16.h (vaddh_f16, vsubh_f16, vabdh_f16,
      	vcageh_f16, vcagth_f16, vcaleh_f16, vcalth_f16, vceqh_f16, vcgeh_f16,
      	vcgth_f16, vcleh_f16, vclth_f16, vcvth_n_f16_s16, vcvth_n_f16_s32,
      	vcvth_n_f16_s64, vcvth_n_f16_u16, vcvth_n_f16_u32, vcvth_n_f16_u64,
      	vcvth_n_s16_f16, vcvth_n_s32_f16, vcvth_n_s64_f16, vcvth_n_u16_f16,
      	vcvth_n_u32_f16, vcvth_n_u64_f16, vdivh_f16, vmaxh_f16, vmaxnmh_f16,
      	vminh_f16, vminnmh_f16, vmulh_f16, vmulxh_f16, vrecpsh_f16,
      	vrsqrtsh_f16): New.
      
      From-SVN: r238723
      Jiong Wang committed
    • [AArch64][7/10] ARMv8.2-A FP16 one operand scalar intrinsics · d7f33f07
      gcc/
      	* config.gcc (aarch64*-*-*): Install arm_fp16.h.
      	* config/aarch64/aarch64-builtins.c (hi_UP): New.
      	* config/aarch64/aarch64-simd-builtins.def: Register new builtins.
      	* config/aarch64/aarch64-simd.md (aarch64_frsqrte<mode>): Extend to HF
      	mode.
      	(aarch64_frecp<FRECP:frecp_suffix><mode>): Likewise.
      	(aarch64_cm<optab><mode>): Likewise.
      	* config/aarch64/aarch64.md (<frint_pattern><mode>2): Likewise.
      	(l<fcvt_pattern><su_optab><GPF:mode><GPI:mode>2): Likewise.
      	(fix_trunc<GPF:mode><GPI:mode>2): Likewise.
      	(sqrt<mode>2): Likewise.
      	(abs<mode>2): Likewise.
      	(<optab><mode>hf2): New pattern for HF mode.
      	(<optab>hihf2): Likewise.
      	* config/aarch64/arm_neon.h: Include arm_fp16.h.
      	* config/aarch64/iterators.md (GPF_F16, GPI_F16, VHSDF_HSDF): New.
      	(w1, w2, v, s, q, Vmtype, V_cmp_result, fcvt_iesize, FCVT_IESIZE):
      	Support HF mode.
      	* config/aarch64/arm_fp16.h: New file.
      	(vabsh_f16, vceqzh_f16, vcgezh_f16, vcgtzh_f16, vclezh_f16, vcltzh_f16,
      	vcvth_f16_s16, vcvth_f16_s32, vcvth_f16_s64, vcvth_f16_u16,
      	vcvth_f16_u32, vcvth_f16_u64, vcvth_s16_f16, vcvth_s32_f16,
      	vcvth_s64_f16, vcvth_u16_f16, vcvth_u32_f16, vcvth_u64_f16,
      	vcvtah_s16_f16, vcvtah_s32_f16, vcvtah_s64_f16, vcvtah_u16_f16,
      	vcvtah_u32_f16, vcvtah_u64_f16, vcvtmh_s16_f16, vcvtmh_s32_f16,
      	vcvtmh_s64_f16, vcvtmh_u16_f16, vcvtmh_u32_f16, vcvtmh_u64_f16,
      	vcvtnh_s16_f16, vcvtnh_s32_f16, vcvtnh_s64_f16, vcvtnh_u16_f16,
      	vcvtnh_u32_f16, vcvtnh_u64_f16, vcvtph_s16_f16, vcvtph_s32_f16,
      	vcvtph_s64_f16, vcvtph_u16_f16, vcvtph_u32_f16, vcvtph_u64_f16,
      	vnegh_f16, vrecpeh_f16, vrecpxh_f16, vrndh_f16, vrndah_f16, vrndih_f16,
      	vrndmh_f16, vrndnh_f16, vrndph_f16, vrndxh_f16, vrsqrteh_f16,
      	vsqrth_f16): New.
      
      From-SVN: r238722
      Jiong Wang committed