1. 16 Dec, 2016 15 commits
    • Revert accidentally changed file. · 17f3bb6d
      From-SVN: r243754
      Jakub Jelinek committed
    • re PR c/78408 (C loop initial declarations generate wrong code) · 7b45d0df
      	PR c/78408
      	* tree-ssa-ccp.c: Include tree-dfa.h.
      	(optimize_memcpy): New function.
      	(pass_fold_builtins::execute): Use it.  Remove useless conditional
      	break after BUILT_IN_VA_*.
      
      	* gcc.dg/pr78408-1.c: New test.
      	* gcc.dg/pr78408-2.c: New test.
      
      From-SVN: r243753
      Jakub Jelinek committed
    • re PR tree-optimization/78819 (Wrong code with VRP caused by register assertions… · 6b520e8d
      re PR tree-optimization/78819 (Wrong code with VRP caused by register assertions along default switch labels)
      
      	PR tree-optimization/78819
      	* tree-vrp.c (find_switch_asserts): Return if the insertion limit is 0.
      	Don't register an assertion if the default case shares a label with
      	another case.
      
      	* gcc.dg/tree-ssa/vrp112.c: New test.
      
      From-SVN: r243746
      Marek Polacek committed
    • The negdi2 patterns for ARM and Thumb-2 are duplicated because Thumb-2 doesn't… · ed2def05
      The negdi2 patterns for ARM and Thumb-2 are duplicated because Thumb-2 doesn't support RSC with an immediate.
      
      The negdi2 patterns for ARM and Thumb-2 are duplicated because Thumb-2
      doesn't support RSC with an immediate.  We can however emulate RSC with
      zero using a shifted SBC.  If we add this to subsi3_carryin the negdi
      patterns can be merged, simplifying things a bit.  This should generate
      identical code in all cases.
      
          gcc/
              * config/arm/arm.md (subsi3_carryin): Add Thumb-2 RSC #0.
              (arm_negdi2) Rename to negdi2_insn, allow on Thumb-2.
              * config/arm/thumb2.md (thumb2_negdi2): Remove pattern.
      
      From-SVN: r243745
      Wilco Dijkstra committed
    • Thumb uses a special register allocation order to increase the use of low registers. · c67b6f26
      Thumb uses a special register allocation order to increase the use of low
      registers.  Oddly enough, LR appears before R12, which means that LR must
      be saved and restored even if R12 is available.  Swapping R12 and LR means
      this simple example now uses R12 as a temporary (just like ARM):
      
      int f(long long a, long long b)
      {
        if (a < b) return 1;
        return a + b;
      }
      
          gcc/
      	* config/arm/arm.c (thumb_core_reg_alloc_order): Swap R12 and R14.
      
      From-SVN: r243744
      Wilco Dijkstra committed
    • [ARC] Remove old prof patterns. · bfb688ae
      gcc/
      2016-12-16  Claudiu Zissulescu  <claziss@synopsys.com>
      
      	* config/arc/arc.md (call_prof): Remove.
      	(call_value_prof): Likewise.
      	(sibcall_prof): Likewise.
      	(sibcall_value_prof): Likewise.
      
      From-SVN: r243743
      Claudiu Zissulescu committed
    • [ARC] Rework code for profiling. · e04ea1da
      gcc/
      2016-12-16  Claudiu Zissulescu  <claziss@synopsys.com>
      
      	* config/arc/arc.h (LINK_SPEC): Tidy up.
      	(ENDFILE_SPEC): Likewise.
      	(LIB_SPEC): Likewise.
      	(STARTFILE_SPEC): Include gcrt0 when profiling.
      	(FUNCTION_PROFILER): Use __mcount.
      	* config/arc/arc.opt (mucb-mcount): Remove.
      	* doc/invoke.texi (ARC): Remove mucb-mcount doc.
      	* arc/arc-protos.h (arc_profile_call): Remove.
      	* config/arc/arc.c (write_profile_sections): Likewise.
      	(arc_profile_call): Likewise.
      	(unspec_prof_hash): Likewise.
      	(unspec_prof_htab_eq): Likewise.
      	(arc_legitimate_constant_p): Remove UNSPEC_PROF.
      	(arc_reorg): Remove call to write_profile_sections.
      	* config/arc/arc.md (call): Remove call to arc_profile_call.
      	(call_value): Likewise.
      	(sibcall): Likewise.
      	(sibcall_value): Likewise.
      	(define_constants): Remove UNSPEC_PROF.
      
      libgcc/
      	* config.host (arc*-*-linux-uclibc*): Remove libgmon, crtg, and
      	crtgend.
      	(arc*-*-elf*): Likewise.
      	* config/arc/t-arc: Remove old gmon lib targets.
      	* config/arc/crtg.S: Remove.
      	* config/arc/crtgend.S: Likewise.
      	* config/arc/gmon/atomic.h: Likewise.
      	* config/arc/gmon/auxreg.h: Likewise.
      	* config/arc/gmon/dcache_linesz.S: Likewise.
      	* config/arc/gmon/gmon.c: Likewise.
      	* config/arc/gmon/machine-gmon.h: Likewise.
      	* config/arc/gmon/mcount.c: Likewise.
      	* config/arc/gmon/prof-freq-stub.S: Likewise.
      	* config/arc/gmon/prof-freq.c: Likewise.
      	* config/arc/gmon/profil.S: Likewise.
      	* config/arc/gmon/sys/gmon.h: Likewise.
      	* config/arc/gmon/sys/gmon_out.h: Likewise.
      	* config/arc/t-arc-newlib: Likewise.
      	* config/arc/t-arc700-uClibc: Renamed to t-arc-uClibc.
      
      From-SVN: r243742
      Claudiu Zissulescu committed
    • [ARC] Rework ARC600 64-bit multiplication patterns. · d476b53c
      Previously users of mulsidi_600 and umulsidi_600 had to take care of
      moving the multiplication result into the final destination themselves
      (from the MUL64_OUT_REG register).  This commit converts these two
      instruction patterns into insn_and_split patterns that now take the
      final destination as an extra operand.  The insn_and_split patterns
      generate the multiplication using two new multiplication instruction
      patterns, then generate the move of the result from the MUL64_OUT_REG
      register into the final destination.
      
      This is a clean up commit, there should be no user visible changes
      after this commit.
      
      2016-12-16  Claudiu Zissulescu  <claziss@synopsys.com>
      
      	* config/arc/arc.md (mulsidi_600): Change to insn_and_split,
      	generate new mul64 insn for core multiplication work.
      	(umulsidi_600): Likewise, but use mulu64 insn.
      	(mul64): New pattern, content taken from old mulsidi_600 insn
      	pattern.
      	(mulu64): Likewise, but using umulsidi_600.
      	(mulsidi3): Remove move to destination, this is now handled by
      	mulsidi_600 insn_and_split.
      	(umulsidi3): Likewise, but using umulsidi_600.
      
      From-SVN: r243741
      Claudiu Zissulescu committed
    • opt61.adb: New test. · cc0ca499
      	* gnat.dg/opt61.adb: New test.
      	* gnat.dg/opt61_pkg.ad[sb]: New helper.
      
      From-SVN: r243740
      Eric Botcazou committed
    • Implement LWG 2769, Redundant const in the return type of any_cast(const any&). · 62549523
      Implement LWG 2769, Redundant const in the return type of
      any_cast(const any&).
      * include/std/any (_AnyCast): New.
      (any_cast(const any&)): Use it and add an explicit cast for return.
      (any_cast(any&)): Likewise.
      (any_cast(any&&)): Likewise.
      * testsuite/20_util/any/misc/any_cast.cc: Add a test for a type
      that has an explicit copy constructor.
      *testsuite/20_util/any/misc/any_cast_neg.cc: Adjust.
      
      From-SVN: r243739
      Ville Voutilainen committed
    • re PR c++/71694 (store-data race with bitfields and tail-padding in C++) · b7fc43d7
      2016-12-16  Richard Biener  <rguenther@suse.de>
      
      	PR c++/71694
      	* langhooks-def.h (lhd_unit_size_without_reusable_padding): Declare.
      	(LANG_HOOKS_UNIT_SIZE_WITHOUT_REUSABLE_PADDING): Define.
      	(LANG_HOOKS_FOR_TYPES_INITIALIZER): Adjust.
      	* langhooks.h (struct lang_hooks_for_types): Add
      	unit_size_without_reusable_padding.
      	* langhooks.c (lhd_unit_size_without_reusable_padding): New.
      	* stor-layout.c (finish_bitfield_representative): Use
      	unit_size_without_reusable_padding langhook to decide on the
      	last representatives size.
      
      	cp/
      	* cp-objcp-common.h (cp_unit_size_without_reusable_padding): Declare.
      	(LANG_HOOKS_UNIT_SIZE_WITHOUT_REUSABLE_PADDING): Define.
      	* cp-objcp-common.c (cp_unit_size_without_reusable_padding): New.
      
      	* g++.dg/pr71694.C: New testcase.
      
      From-SVN: r243738
      Richard Biener committed
    • re PR middle-end/71632 (hang at -O3 on x86_64-linux-gnu) · c4d5c5e6
      2016-12-16  Richard Biener  <rguenther@suse.de>
      
      	PR middle-end/71632
      	* expr.c (expand_cond_expr_using_cmove): Bail out early if
      	we end up recursing via TER.
      
      	* gcc.dg/pr71632.c: New testcase.
      
      From-SVN: r243737
      Richard Biener committed
    • PR bootstrap/78817 - stage2 bootstrap failure in vec.h:1613:5: error: argument 1… · 7bd1e2ed
      PR bootstrap/78817 - stage2 bootstrap failure in vec.h:1613:5: error: argument 1 null where non-null expected after r243661
      
      gcc/ChangeLog:
      	* vec.h (vec<T, va_heap, vl_ptr>::safe_grow_cleared): Assert
      	a pointer is non-null.
      
      From-SVN: r243736
      Martin Sebor committed
    • compiler: fix comments + fieldnames to match libgo source · 2ae30b14
          
          A couple of the comments in the type descriptor code were out of date
          with respect to the names in libgo/go/runtime/type.go.  Fix up the
          comments and field names to bring them into sync.
          
          Reviewed-on: https://go-review.googlesource.com/34472
      
      From-SVN: r243735
      Ian Lance Taylor committed
    • Daily bump. · 6f9ad634
      From-SVN: r243734
      GCC Administrator committed
  2. 15 Dec, 2016 25 commits
    • compiler: fix off-by-1 array type len in Type::gc_symbol_constructor · 63ba3ad3
          
          Array type being built to hold GC var initializer was being created
          with an extra/unneeded slot. Fix up the code to insure that the array
          length matches the length of the initializer list.
          
          Reviewed-on: https://go-review.googlesource.com/34413
      
      From-SVN: r243731
      Ian Lance Taylor committed
    • re PR go/78763 (go1: internal compiler error: in do_get_backend, at… · 62afb87d
      re PR go/78763 (go1: internal compiler error: in do_get_backend, at go/gofrontend/expressions.cc:8352)
      
      	PR go/78763
          compiler: call determine_types even for constant expressions
          
          We need to call determine_types even for constant expressions, since a
          constant expression may include code like unsafe.Sizeof(0).  Something
          needs to determine the type of the untyped 0, and that should be the
          determine_types pass.
          
          Implementing that triggered a compiler crash on test/const1.go because
          it permitted some erroneous constants to make it all the way to the
          backend.  Catch that case by checking whether we get a constant
          overflow error, and marking the expression invalid if we do.  This is
          a good change in any case, as previously we reported the same constant
          overflow error multiple times, and now we only report it once.
          
          Fixes GCC PR 78763.
          
          Reviewed-on: https://go-review.googlesource.com/34496
      
      From-SVN: r243729
      Ian Lance Taylor committed
    • avx512bwintrin.h: Add new k-mask intrinsics. · 7cdb6e4c
      	* config/i386/avx512bwintrin.h: Add new k-mask intrinsics.
      	* config/i386/avx512dqintrin.h: Ditto.
      	* config/i386/avx512fintrin.h: Ditto.
      	* config/i386/i386-builtin.def (__builtin_ia32_kmovb,
      	__builtin_ia32_kmovd, __builtin_ia32_kmovq): New.
      	(__builtin_ia32_kmov16): Rename to __builtin_ia32_kmovw.
      	* config/i386/sse.md (kmov<mskmodesuffix>): New.
      
      testsuite/ChangeLog:
      
      	* gcc.target/i386/avx512bw-kmovd-1.c: New test.
      	* gcc.target/i386/avx512bw-kmovd-2.c: Ditto.
      	* gcc.target/i386/avx512bw-kmovd-3.c: Ditto.
      	* gcc.target/i386/avx512bw-kmovd-4.c: Ditto.
      	* gcc.target/i386/avx512bw-kmovq-1.c: Ditto.
      	* gcc.target/i386/avx512bw-kmovq-2.c: Ditto.
      	* gcc.target/i386/avx512bw-kmovq-3.c: Ditto.
      	* gcc.target/i386/avx512bw-kmovq-4.c: Ditto.
      	* gcc.target/i386/avx512dq-kmovb-2.c: Ditto.
      	* gcc.target/i386/avx512dq-kmovb-3.c: Ditto.
      	* gcc.target/i386/avx512dq-kmovb-4.c: Ditto.
      	* gcc.target/i386/avx512dq-kmovb-5.c: Ditto.
      	* gcc.target/i386/avx512f-kmovw-2.c: Ditto.
      	* gcc.target/i386/avx512f-kmovw-3.c: Ditto.
      	* gcc.target/i386/avx512f-kmovw-4.c: Ditto.
      	* gcc.target/i386/avx512f-kmovw-5.c: Ditto.
      
      From-SVN: r243728
      Andrew Senkevich committed
    • i386.md (ffs<mode>2): Generate CCCmode flags register for TARGET_BMI. · bdb51776
      	* config/i386/i386.md (ffs<mode>2): Generate CCCmode flags register
      	for TARGET_BMI.
      	(ffssi2_no_cmove): Ditto.
      	(*tzcnt<mode>_1_falsedep_1): New insn_and_split pattern.
      	(*tzcnt<mode>_1_falsedep): New insn pattern.
      
      	(LT_ZCNT): New mode iterator.
      	(lt_zcnt): New mode attribute.
      	(lt_zcnt_type): New mode attribute.
      	(<lt_zcnt>_<mode>): Macroize expander from bmi_tzcnt_<mode> and
      	lzcnt_<mode> using LT_ZCNT mode iterator.
      	(*<lt_zcnt>_<mode>_falsedep_1): Macroize insn from
      	*bmi_tzcnt_<mode>_falsedep_1 and *lzcnt_<mode>_falsedep_1
      	using LT_ZCNT mode iterator.
      	(*<lt_zcnt>_<mode>_falsedep): Macroize insn from
      	*bmi_tzcnt_<mode>_falsedep and *lzcnt_<mode>_falsedep
      	using LT_ZCNT mode iterator.
      	(*<lt_zcnt>_<mode>): Macroize insn from *bmi_tzcnt_<mode>
      	and *lzcnt_<mode> using LT_ZCNT mode iterator.
      	* config/i386/i386-builtin.def (__builtin_ia32_tzcnt_u16)
      	(__builtin_ia32_tzcnt_u32, __builtin_ia32_tzcnt_u64, __builtin_ctzs):
      	Update for rename.
      
      From-SVN: r243727
      Uros Bizjak committed
    • re PR fortran/78798 ([cleanup] some int-valued functions should be bool) · f3e1097b
      2016-12-15  Janus Weil  <janus@gcc.gnu.org>
      
      	PR fortran/78798
      	* gfortran.h (gfc_compare_derived_types,gfc_compare_types,
      	gfc_compare_interfaces,gfc_has_vector_subscript): Return bool instead
      	of int.
      	* interface.c (compare_components): Ditto.
      	(gfc_compare_union_types): Rename to compare_union_types, declare as
      	static, return bool.
      	(gfc_compare_derived_types): Return bool instead of int.
      	(gfc_compare_types): Ditto.
      	(compare_type): Ditto.
      	(compare_rank): Ditto.
      	(compare_type_rank): Ditto.
      	(compare_type_rank_if): Ditto.
      	(count_types_test): Ditto.
      	(generic_correspondence): Ditto.
      	(gfc_compare_interfaces): Ditto.
      	(check_interface0): Ditto.
      	(check_interface1): Ditto.
      	(compare_allocatable): Ditto.
      	(compare_parameter): Ditto.
      	(gfc_has_vector_subscript): Ditto.
      	(compare_actual_formal): Ditto.
      
      From-SVN: r243726
      Janus Weil committed
    • ipa-cp.c (class ipcp_bits_lattice): Formatting fixes. · 155c9907
      	* ipa-cp.c (class ipcp_bits_lattice): Formatting fixes.
      	(print_ipcp_constant_value): Likewise.
      	(ipcp_cloning_candidate_p): Likewise.
      	(ipcp_bits_lattice::get_value_and_mask): Likewise.
      	(ipcp_bits_lattice::meet_with_1): Likewise.
      	(ipcp_bits_lattice::meet_with): Likewise.
      	(initialize_node_lattices): Likewise.
      	(ipcp_lattice::add_value): Likewise.
      	(propagate_vals_accross_pass_through): Renamed to ...
      	(propagate_vals_across_pass_through): ... this function.
      	(propagate_vals_accross_ancestor): Renamed to ...
      	(propagate_vals_across_ancestor): ... this.
      	(propagate_scalar_accross_jump_function): Renamed to ...
      	(propagate_scalar_across_jump_function): ... this.
      	Adjust calls to above functions.
      	(propagate_context_accross_jump_function): Renamed to ...
      	(propagate_context_across_jump_function): ... this.
      	(propagate_bits_accross_jump_function): Renamed to ...
      	(propagate_bits_accross_jump_function): ... this.  Formatting fixes.
      	(propagate_vr_accross_jump_function): Renamed to ...
      	(propagate_vr_across_jump_function): ... this.
      	(merge_agg_lats_step): Formatting fixes.
      	(propagate_constants_accross_call): Renamed to ...
      	(propagate_constants_across_call): ... this.  Adjust calls to above
      	functions.
      	(ipa_get_indirect_edge_target_1): Formatting fixes.
      	(gather_context_independent_values): Likewise.
      	(estimate_local_effects): Likewise.
      	(add_all_node_vals_to_toposort): Likewise.
      	(propagate_constants_topo): Adjust calls to above functions.
      	(get_replacement_map): Formatting fixes.
      	(dump_profile_updates): Likewise.
      	(update_profiling_info): Likewise.
      	(update_specialized_profile): Likewise.
      	(create_specialized_node): Likewise.
      	(find_more_contexts_for_caller_subset): Likewise.
      	(decide_whether_version_node): Likewise.
      	(identify_dead_nodes): Likewise.
      	(ipcp_decision_stage): Likewise.
      	(ipcp_store_bits_results): Likewise.
      	(ipcp_store_vr_results): Likewise.
      	(ipcp_driver): Likewise.
      
      From-SVN: r243725
      Jakub Jelinek committed
    • P0490R0 GB 20: decomposition declaration should commit to tuple interpretation early · ce7888da
      	P0490R0 GB 20: decomposition declaration should commit to tuple
      	interpretation early
      	* decl.c (get_tuple_size): Make static.  If inst is error_mark_node
      	or non-complete type, return NULL_TREE, otherwise if
      	lookup_qualified_name fails or doesn't fold into INTEGER_CST, return
      	error_mark_node.
      	(get_tuple_element_type, get_tuple_decomp_init): Make static.
      	(cp_finish_decomp): Pass LOC to get_tuple_size.  If it returns
      	error_mark_node, complain and fail.
      
      	* g++.dg/cpp1z/decomp10.C (f1): Adjust expected diagnostics.
      
      From-SVN: r243724
      Jakub Jelinek committed
    • re PR c++/77585 (g++ incorrectly decides that member function is called without… · 2a810ded
      re PR c++/77585 (g++ incorrectly decides that member function is called without object in generic lambda)
      
      	PR c++/77585
      	* pt.c (instantiate_decl): Push to class scope lambda resides
      	within when instantiating a generic lambda function.
      
      	PR c++/77585
      	* g++.dg/cpp1y/pr77585.C: New.
      
      From-SVN: r243723
      Nathan Sidwell committed
    • Fix use-after-free lexing unterminated raw strings (PR preprocessor/78811) · a3998c2f
      gcc/ChangeLog:
      	PR preprocessor/78680
      	PR preprocessor/78811
      	* input.c (struct selftest::lexer_test): Add field
      	m_implicitly_expect_EOF.
      	(selftest::lexer_error_sink): New class.
      	(selftest::lexer_error_sink::s_singleton): New global.
      	(selftest::lexer_test::lexer_test): Initialize new field
      	"m_implicitly_expect_EOF".
      	(selftest::lexer_test::~lexer_test): Conditionalize the
      	check for the EOF token on the new field.
      	(selftest::test_lexer_string_locations_raw_string_unterminated):
      	New function.
      	(selftest::input_c_tests): Call the new test.
      
      libcpp/ChangeLog:
      	PR preprocessor/78680
      	PR preprocessor/78811
      	* lex.c (_cpp_lex_direct): Only determine the end-location of
      	the token and build a range for non-reserved start locations.
      	Do not do it for EOF tokens.
      
      From-SVN: r243721
      David Malcolm committed
    • Using leaf_function_p in a backend is dangerous as it incorrectly returns false... · a3038e19
      Using leaf_function_p in a backend is dangerous as it incorrectly returns
      false if it is called while in a sequence (for example during prolog/epilog
      generation).  Replace all uses with crtl->is_leaf as this is now initialized
      early enough in ira.c.  This typically causes no code generation differences
      unless there was a bug due to leaf_function_p returning the wrong value.
      
          gcc/
              * config/arm/arm.h (TARGET_BACKTRACE): Use crtl->is_leaf.
              * config/arm/arm.c (arm_option_check_internal): Improve comment.
              (thumb_force_lr_save): Use crtl->is_leaf.
              (arm_get_frame_offsets): Remove comment.  Use crtl->is_leaf.
              (thumb_far_jump_used_p): Remove comment.
              (arm_frame_pointer_required): Use crtl->is_leaf.
      
      From-SVN: r243720
      Wilco Dijkstra committed
    • [arm] Add missing arm-isa.h · 4d044f0b
      From-SVN: r243718
      Richard Earnshaw committed
    • extend.texi: Clean up @xref{...} uses. · e3889521
      	* doc/extend.texi: Clean up @xref{...} uses.
      	* doc/invoke.texi: Likewise.
      
      From-SVN: r243717
      Jakub Jelinek committed
    • [arm] Permit 'auto' in -mfpu · 844af767
      Now we finally have the infrastructure in place we can now derive
      details of the FPU from a CPU entry.  This patch enables this for the
      existing cores that already have an explicit FPU in their product names.
      
      	* arm-fpus.def: Add CNAME field to all FPU definitions.
      	* genopt.sh: Use explicit enumeration tags for FPU entries.
      	* arm-tables.opt: Regenerated.
      	* arm.opt (mfpu): Provide initial value.
      	* arm-opts.h (enum fpu_type): Build the enumeration from the list of
      	available FPUs.  Add 'auto' entry on the end.
      	* arm.c (arm_configure_build_target): Only do explicit configuration
      	of the FPU features if the selected FPU is not 'auto'.
      	(arm_option_override): Adjust initialization of arm_fpu_index.
      	Emit an error if we have a hard float ABI request, but the processor
      	does not support floating-point.
      	(arm_option_print): Handle -mfpu=auto.
      	(arm_valid_target_attribute_rec): Don't permit fpu=auto in pragmas
      	or function attributes.
      	(arm_identify_fpu_from_isa): Handle effective soft-float when
      	the FPU is automatically detected.
      	* arm-cores.def (arm1136jf-s): Add feature ISA_FP_DBL.
      	(arm1176jzf-s): Likewise.
      	(mpcore): Likewise.
      	(arm1156t2f-s): Likewise.
      
      From-SVN: r243716
      Richard Earnshaw committed
    • [arm] Remove FEATURES field from FPU descriptions · 7eca7f0b
      Now that everything uses the new ISA features, we can remove the
      FEATURES field from the FPU descriptions, along with all the macros
      and definitions associated with it.
      
      	* arm-fpus.def (ARM_FPU): Remove features field from all definitions.
      	* arm.h (arm_fpu_feature_set): Delete typedef.
      	(FPU_FL_NONE): Delete.
      	(FPU_FL_NEON): Delete.
      	(FPU_FL_FP16): Delete.
      	(FPU_FL_CRYPTO): Delete.
      	(FPU_FL_DBL): Delete.
      	(FPU_FL_D32): Delete.
      	(FPU_FL_VFPv2): Delete.
      	(FPU_FL_VFPv3): Delete.
      	(FPU_FL_VFPv4): Delete.
      	(FPU_FL_VFPv5): Delete.
      	(FPU_FL_AMRv8): Delete.
      	(FPU_VFPv2): Delete.
      	(FPU_VFPv3): Delete.
      	(FPU_VFPv4): Delete.
      	(FPU_VFPv5): Delete.
      	(FPU_ARMv8): Delete.
      	(FPU_DBL): Delete.
      	(FPU_D32): Delete.
      	(FPU_NEON): Delete.
      	(FPU_CRYPTO): Delete.
      	(FPU_FP16): Delete.
      	(arm_fpu_desc): Delete features field.
      	* arm.c (all_fpus): Don't initialize feature field.
      
      From-SVN: r243715
      Richard Earnshaw committed
    • [arm] Use ISA feature sets for determining inlinability · 56941f70
      Now that we can construct the build target isa from the cl_target_options
      data we can use this to determine inlinability.  This eliminates the
      final remaining use of the FPU features field.
      
      	* arm.c (arm_can_inline_p): Use ISA features for determining
      	inlinability.
      
      From-SVN: r243714
      Richard Earnshaw committed
    • [arm] Use cl_target_options for configuring the active target · a53613c4
      It now becomes apparent that it would be better to use the the
      cl_target_options as the basis for calling arm_configure_build_target;
      it already contains exactly the same fields that we need.  I chose not
      to rewrite the earlier patches as that would make the progression of
      changes seem less logical than it currently is, with several early
      changes having no immediate justification.
      
      	* arm-protos.h (arm_configure_build_target): Change second argument
      	to cl_target_options.
      	* arm.c (arm_configure_build_target): Likewise.
      	(arm_option_restore): Update accordingly.
      	(arm_option_override): Create the target_option_default_node before
      	calling arm_configure_build_target.  Use it in call of latter.
      	Resynchronize after all other overrides have been calculated.
      	(arm_valid_target_attribute_tree): Use the target options for
      	reconfiguration.  Resynchronize after performing override checks.
      	* arm-c.c (arm_pragma_target_parse): Use target optiosn from cur_tree
      	to reconfigure the build target.
      
      From-SVN: r243713
      Richard Earnshaw committed
    • [arm] Use arm_active_target for most FP feature tests · 091df649
      Now that the isa feature bits are all available in arm_active_target
      we can use that for most of the feature tests that are needed.
      
      	* arm.h (TARGET_VFPD32): Use arm_active_target.
      	(TARGET_VFP3): Likewise.
      	(TARGET_VFP5): Likewise.
      	(TARGET_VFP_SINGLE): Likewise.
      	(TARGET_VFP_DOUBLE): Likewise.
      	(TARGET_NEON_FP16): Likewise.
      	(TARGET_FP16): Likewise.
      	(TARGET_FMA): Likewise.
      	(TARGET_FPU_ARMV8): Likewise.
      	(TARGET_CRYPTO): Likewise.
      	(TARGET_NEON): Likewise.
      	(TARGET_FPU_FEATURES): Delete.
      	* arm.c (arm_option_check_internal): Check for iwmmxt conflict with
      	Neon using arm_active_target.
      
      From-SVN: r243712
      Richard Earnshaw committed
    • [arm] Eliminate TARGET_FPU_NAME · 8990ddcd
      Rather than assuming a specific fpu name has been selected, we work
      out the FPU from the ISA properties.  This is necessary since once we
      have default FPUs selected by the processor, there will be no explicit
      entry in the table of fpus to refer to.
      
      This also fixes a bug with the code I added recently to permit new
      aliases for existing FPU names: the new names cannot be passed to the
      assembler since it does not recognize them.  By mapping the ISA
      features back to the canonical names we avoid having to teach the
      assembler about the new names.
      
      	* arm.h (TARGET_FPU_NAME): Delete.
      	* arm.c (arm_identify_fpu_from_isa): New function.
      	(arm_declare_function_name): Use it to get the name for the FPU.
      
      From-SVN: r243711
      Richard Earnshaw committed
    • [arm] Initialize fpu capability bits in arm_active_target · 851966d6
      Now that we can describe the FPU with the standard ISA bits we need to
      initialize them.  However, the FPU settings can be changed with target build
      attributes, so we also need to reset them if things change.  This requires
      a bit of juggling about with the existing code to ensure that the active
      target is reconfigured after each change to the target options.
      
      	* arm-protos.h: Include sbitmap.h
      	(arm_configure_build_target): Make public.
      	* arm.c (arm_configure_build_target): Now not static.
      	(arm_valid_target_attribute_rec): Move internal option check to...
      	(arm_valid_target_attribute_tree0: ... here.  Also reconfingure the
      	active target.
      	(arm_override_options_after_change): Call arm_configure_build_target.
      	(isa_all_fpubits): Renamed from isa_fpubits.
      	(arm_option_restore): New function.
      	(TARGET_OPTION_RESTORE): Register it.
      	(arm_configure_build_target): Initialize the FPU capability bits in
      	the isa.
      	(arm_option_override): Move the code that forces the setting of the
      	FPU option before the call to arm_configure_build_target.
      	* arm.opt (march): Mark as Save.
      	(mcpu, mtune): Likewise.
      	* arm-c.c (arm_pragma_target_parse): Reconfigure the build target
      	after pragmas change the target options.
      
      From-SVN: r243710
      Richard Earnshaw committed
    • [arm] Add isa features to FPU descriptions · 066416da
      Similar to the new CPU and architecture ISA feature lists, we now add
      similar capabilities to each FPU description.  We don't use these yet,
      that will come in later patches.  These follow the same style as the
      newly modified flag sets, but use slightly different defaults that
      more accurately reflect the ISA specifications.
      
      	* arm-isa.h (isa_feature): Add bits for VFPv4, FPv5, fp16conv,
      	fP_dbl, fp_d32 and fp_crypto.
      	(ISA_ALL_FPU): Add all the new bits.
      	(ISA_VFPv2, ISA_VFPv3, ISA_VFPv4, ISA_FPv5): New macros.
      	(ISA_FP_ARMv8, ISA_FP_DBL, ISA_FP_D32, ISA_NEON, ISA_CRYPTO): Likewise.
      	* arm-fpus.def: Add ISA features to all FPUs.
      	* arm.h: (arm_fpu_desc): Add new field for ISA bits.
      	* arm.c (all_fpus): Initialize it.
      	* arm-tables.opt: Regenerated.
      
      From-SVN: r243709
      Richard Earnshaw committed
    • [arm] Remove FPU rev field · c17c0c7a
      Similar to the main ISA, we convert the FPU revision into a set of feature
      bits.  This permits a more complex set of capability relationships to be
      expressed more easily.  For now we continue to use the traditional bitmasks.
      
      	* arm.h (FPU_FL_VFPv2) New feature bit.
      	(FPU_FL_VFPv3, FPU_FL_VFPv4, FPU_FL_VFPv5, FPU_FL_ARMv8): Likewise.
      	(FPU_VFPv2, FPU_VFPv3, FPU_VFPv4, FPU_VFPv5, FPU_ARMv8): New helper
      	macros.
      	(FPU_DBL, FPU_D32, FPU_NEON, FPU_CRYPTO, FPU_FP16): Likewise.
      	(TARGET_FPU_REV): Delete.
      	(TARGET_VFP3): Use feature bits.
      	(TARGET_VFP5): Likewise.
      	(TARGET_FMA): Likewise.
      	(TARGET_FPU_ARMV8): Likewise.
      	(struct arm_fpu_desc): Delete rev field.
      	* arm-fpus.def: Delete REV entry, use new feature bits and macros.
      	* arm.c (all_fpus): Delete rev field.
      
      From-SVN: r243708
      Richard Earnshaw committed
    • [arm] Eliminate vfp_reg_type · 3d7f68c6
      Remove the VFP_REGS field by converting its meanings into flag
      attributes.  The new flag attributes build on each other describing
      increasing capabilities.  This allows us to do a better job when
      inlining functions with differing requiremetns on the fpu environment:
      we can now inline A into B if B has at least the same register set
      properties as B (previously we required identical register set
      properties).
      
      	* arm.h (vfp_reg_type): Delete.
      	(TARGET_FPU_REGS): Delete.
      	(arm_fpu_desc): Delete regs field.
      	(FPU_FL_NONE, FPU_FL_NEON, FPU_FL_FP16, FPU_FL_CRYPTO): Use unsigned
      	values.
      	(FPU_FL_DBL, FPU_FL_D32): Define.
      	(TARGET_VFPD32): Use feature test.
      	(TARGET_VFP_SINGLE): Likewise.
      	(TARGET_VFP_DOUBLE): Likewise.
      	* arm-fpus.def: Update all entries for new feature bits.
      	* arm.c (all_fpus): Update initializer macro.
      	(arm_can_inline_p): Remove test on fpu regs.
      
      From-SVN: r243707
      Richard Earnshaw committed
    • [arm] Delete unused arm_fp_model · 9e9219f3
      The arm_fp_model enumeration type has only had one useful value since
      the FPA support was removed, and it's no-longer used anywhere.  This
      patch just cleans that up by removing it.
      
      	* arm.h (arm_fp_model): Delete.
      
      From-SVN: r243706
      Richard Earnshaw committed
    • [arm] Remove remaining references to arm feature sets · 5d4dc0cd
      Nothing uses the old feature sets now, so we can delete them entirely.
      
      	* arm-cores.def: Remove FLAGS field from all core definitions.
      	* arm-arches.def: Likewise.
      	* arm-opts.h (enum processor_type): Remove FLAGS parameter from
      	ARM_CORES macro.
      	(arm_arch_core_flags): Likewise, plus ARM_ARCH macro.
      	* arm-protos.h (FL_*): Delete.
      	(arm_feature_set): Delete.
      	(ARM_FSET_*): Delete.
      	* arm.c (struct processors): Delete flags field.
      	(all_cores): Delete FLAGS parameter from macro, don't initialize flags.
      	(all architectures): Likewise.
      
      From-SVN: r243705
      Richard Earnshaw committed
    • [arm] Rework arm-common to use new feature bits. · 03d222fa
      This converts the recently added implicit -mthumb support code to use
      the new data structures.  Since we have a very simple query and no
      initialized copies of the sbitmaps, for now we simply scan the list of
      features to look for the one of interest.
      
      	* arm-opts.h (struct arm_arch_core_flag): Add new field ISA.
      	Initialize it.
         	(arm_arch_core_flag): Delete flags field.
          	(arm_arch_core_flags): Don't initialize flags field.
       	* common/config/arm/arm-common.c (check_isa_bits_for): New function.
      	(arm_target_thumb_only): Use new isa bits arrays.
      
      From-SVN: r243704
      Richard Earnshaw committed