1. 29 Jun, 2017 22 commits
  2. 28 Jun, 2017 18 commits
    • [AArch64] Do not increase data alignment at -Os and with -fconserve-stack. · 98503487
      We unnecessarily align data to 8 byte alignments even when -Os is
      specified. This brings the logic in the AArch64 backend more in line
      with the ARM backend and helps gain some image size in a few
      places. Caught by an internal report on the size of rodata sections
      being high with aarch64 gcc.
      
      * config/aarch64/aarch64.h (AARCH64_EXPAND_ALIGNMENT): New.
        (DATA_ALIGNMENT): Update to use AARCH64_EXPAND_ALIGNMENT.
        (LOCAL_ALIGNMENT): Update to use AARCH64_EXPAND_ALIGNMENT.
      
      Bootstrapped and regression tested on aarch64-none-linux-gnu with no
      regressions.
      
      From-SVN: r249764
      Ramana Radhakrishnan committed
    • PR c++/72764 - ICE with invalid template typename. · cffc4a68
      	* decl.c (build_typename_type): No longer static.
      	* tree.c (strip_typedefs): Use it instead of make_typename_type.
      
      From-SVN: r249760
      Jason Merrill committed
    • * config/i386/avx512vlintrin.h (_mm256_permutexvar_epi64) · 395a191d
      	(_mm256_permutexvar_epi32, _mm256_permutex_epi64): New intrinsics.
      
      testsuite/ChangeLog:
      
      	* gcc.target/i386/avx512vl-vpermd-1.c (_mm256_permutexvar_epi32):
      	Test new intrinsic.
      	* gcc.target/i386/avx512vl-vpermq-imm-1.c (_mm256_permutex_epi64):
      	Ditto.
      	* gcc.target/i386/avx512vl-vpermq-var-1.c (_mm256_permutexvar_epi64):
      	Ditto.
      	* gcc.target/i386/avx512f-vpermd-2.c: Do not check for AVX512F_LEN.
      	* gcc.target/i386/avx512f-vpermq-imm-2.c: Ditto.
      	* gcc.target/i386/avx512f-vpermq-var-2.c: Ditto.
      
      From-SVN: r249759
      Sebastian Peryt committed
    • PR c++/69300 - ICE with self-referential noexcept · 38a79c5a
      	* pt.c (maybe_instantiate_noexcept): Check for recursion.
      
      From-SVN: r249757
      Jason Merrill committed
    • PR c++/61022 - error with variadic template template parm · 7e61b3d4
      	* pt.c (convert_template_argument): Keep the TYPE_PACK_EXPANSION.
      
      From-SVN: r249756
      Jason Merrill committed
    • PR c++/72801 - ICE with variadic partial specialization · d778c637
      	* pt.c (unify_pack_expansion): Use PACK_EXPANSION_EXTRA_ARGS.
      
      From-SVN: r249755
      Jason Merrill committed
    • PR c++/55639 - partial specialization with ::template · 4516a545
      	* parser.c (cp_parser_class_head): Handle ::template.
      
      From-SVN: r249754
      Jason Merrill committed
    • PR c++/45976 - error with ::template in declarator. · 36f48ebd
      	* pt.c (resolve_typename_type): Fix TEMPLATE_ID_EXPR handling.
      
      From-SVN: r249753
      Jason Merrill committed
    • PR c++/54769 - wrong lookup of dependent template-name. · 1e5f79b6
      	* parser.c (cp_parser_template_name): Handle dependent object type.
      	(cp_parser_nested_name_specifier_opt): Make template_keyword_p a
      	parameter.
      	(cp_parser_id_expression): Pass it.
      	(cp_parser_diagnose_invalid_type_name): Handle TEMPLATE_ID_EXPR.
      
      From-SVN: r249752
      Jason Merrill committed
    • Make the TEMPLATE_ID_EXPR location a range. · dc3b932e
      	* parser.c (cp_parser_template_id): Use the range location on the
      	TEMPLATE_ID_EXPR.
      
      From-SVN: r249751
      Jason Merrill committed
    • PR c++/81204 - parse error with dependent template-name · 2a4754f5
      	* parser.c (cp_parser_lookup_name): Disqualify function templates
      	after lookup.
      
      From-SVN: r249750
      Jason Merrill committed
    • multiarch support for non-glibc linux systems · ad669a1a
      Current multiarch directory name is always *-linux-gnu* on linux,
      this patch configures different names for uclibc and musl targets.
      
      2017-06-28  Szabolcs Nagy  <szabolcs.nagy@arm.com>
      
      	* config.gcc (*-linux-musl*): Add t-musl tmake_file.
      	(*-linux-uclibc*): Add t-uclibc tmake_file.
      	* config/t-musl: New.
      	* config/t-uclibc: New.
      
      From-SVN: r249745
      Szabolcs Nagy committed
    • [ARM] Consistently check for neon in vect effective targets · 0ddc0ebc
      Conditions checked for ARM targets in vector-related effective targets
      are inconsistent:
      
      * sometimes arm*-*-* is checked
      * sometimes Neon is checked
      * sometimes arm_neon_ok and sometimes arm_neon is used for neon check
      * sometimes check_effective_target_* is used, sometimes
      * is-effective-target
      
      This patch consolidate all of these check into using is-effective-target
      arm_neon and when little endian was checked, the check is kept.
      
      2017-06-28  Thomas Preud'homme  <thomas.preudhomme@arm.com>
      
          gcc/testsuite/
          * lib/target-supports.exp (check_effective_target_vect_int): Replace
          current ARM check by ARM NEON's availability check.
          (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_shift): Likewise.
          (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_perm): Likewise.
          (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_qi_to_hi): Likewise.
          (check_effective_target_vect_widen_mult_qi_to_hi): Likewise.
          (check_effective_target_vect_widen_mult_hi_to_si): Likewise.
          (check_effective_target_vect_widen_mult_qi_to_hi_pattern): Likewise.
          (check_effective_target_vect_widen_mult_hi_to_si_pattern): Likewise.
          (check_effective_target_vect_widen_shift): Likewise.
          (check_effective_target_vect_extract_even_odd): Likewise.
          (check_effective_target_vect_interleave): Likewise.
          (check_effective_target_vect_multiple_sizes): Likewise.
          (check_effective_target_vect64): Likewise.
          (check_effective_target_vect_max_reduc): Likewise.
      
      From-SVN: r249744
      Thomas Preud'homme committed
    • [arm] Fix incorrect __ARM_ARCH_PROFILE for -march=armv7 · 8afb5358
      ACLE explicitly states that when targetting the common subset of
      ARMv7-A, ARMv7-R and ARMv7-M, the __ARM_ARCH_PROFILE macro should not
      be set.  We currently set it to 'M' which is clearly erroneous.
      
      The logic for creating this is very convoluted and also somewhat
      fragile, so I've taken the opportunity to use the new CPU and
      architecture definition infrastructure to record the profile for each
      architecture explicitly rather than try to reconstruct it from other
      data.  I think this results in a much more robust solution.
      
      2017-06-28  Richard Earnshaw  <rearnsha@arm.com>
      
      	* config/arm/parsecpu.awk (profile): Parse new keyword in an arch
      	context.
      	(gen_comm_data): Emit architectural setting of arch_prof.
      	* config/arm/arm-cpus.in (armv6-m, armv6s-m, armv7-a, armv7ve): Set the
      	profile.
      	(armv7-r, armv7-m, armv7e-m, armv8-a, armv8.1-a, armv8.2-a): Likewise.
      	(armv8-m.base, armv8-m.main): Likewise.
      	* arm-protos.h (arm_build_target): Add profile field.
      	(arch_option): Likewise.
      	* config/arm/arm.c (arm_configure_build_target): Copy the profile to
      	the active target.
      	* config/arm/arm.h (TARGET_ARM_ARCH_PROFILE): Use
      	arm_active_target.profile.
      
      From-SVN: r249743
      Richard Earnshaw committed
    • re PR tree-optimization/81227 (ICE in get_single_symbol, at tree-vrp.c:799) · 56a6d474
      2017-06-28  Richard Biener  <rguenther@suse.de>
      
      	PR middle-end/81227
      	* fold-const.c (negate_expr_p): Use TYPE_UNSIGNED, not
      	TYPE_OVERFLOW_WRAPS.
      	* match.pd (negate_expr_p): Likewise.
      	* tree-ssa-reassoc.c (optimize_range_tests_diff): Use
      	fold_build2, not fold_binary.
      
      	* gcc.dg/pr81227.c: New testcase.
      
      From-SVN: r249742
      Richard Biener committed
    • This patch fixes a failure in gcc.target/aarch64/reload-valid-spoff.c triggered... · 00eee3fa
      This patch fixes a failure in gcc.target/aarch64/reload-valid-spoff.c 
      triggered by https://gcc.gnu.org/ml/gcc-patches/2017-06/msg01367.html.
      
      In ILP32 all memory accesses must have Pmode as the base address, but
      aarch64_expand_mov_immediate wasn't emitting a conversion in one case.
      Besides fixing this add an assert that flags any MEM operands that are
      not Pmode.
      
          gcc/
      	* config/aarch64/aarch64 (aarch64_expand_mov_immediate):
      	Convert memory address to Pmode.
      	(aarch64_print_operand): Assert MEM operands are always Pmode.
      
      From-SVN: r249741
      Wilco Dijkstra committed
    • Improve Cortex-A53 shift bypass · 55994b97
      The aarch_forward_to_shift_is_not_shifted_reg bypass always returns true
      on AArch64 shifted instructions.  This causes the bypass to activate in
      too many cases, resulting in slower execution on Cortex-A53 like reported
      in PR79665.
      
      This patch uses the arm_no_early_alu_shift_dep condition instead which
      improves the example in PR79665 by ~7%.  Given it is no longer used,
      remove aarch_forward_to_shift_is_not_shifted_reg.  Also remove an
      unnecessary REG_P check.
      
          gcc/
      	PR target/79665
      	* config/arm/aarch-common.c (arm_no_early_alu_shift_dep):
      	Remove redundant if.
      	(aarch_forward_to_shift_is_not_shifted_reg): Remove.
      	* config/arm/aarch-common-protos.h
      	(aarch_forward_to_shift_is_not_shifted_re): Remove.
      	* config/arm/cortex-a53.md: Use arm_no_early_alu_shift_dep in bypass.
      
      From-SVN: r249740
      Wilco Dijkstra committed
    • re PR ipa/81238 (Target clone support does not make default clone static.) · 926c7865
      [gcc]
      2017-06-28  Michael Meissner  <meissner@linux.vnet.ibm.com>
      
      	PR ipa/81238
      	* multiple_target.c (create_dispatcher_calls): Set the default
      	clone to be static, not public.
      
      [gcc/testsuite]
      2017-06-28  Michael Meissner  <meissner@linux.vnet.ibm.com>
      
      	PR target/81193
      	* lib/target-supports.exp
      	(check_ppc_cpu_supports_hw_available): New test to make sure
      	__builtin_cpu_supports works on power7 and newer.
      
      From-SVN: r249737
      Michael Meissner committed