1. 15 Oct, 2014 6 commits
  2. 14 Oct, 2014 34 commits
    • msp430-modes.def (PSI): Add. · c32ab325
      * config/msp430/msp430-modes.def (PSI): Add.
      
      * config/msp430/msp430-protos.h (msp430_hard_regno_nregs_has_padding): New.
      (msp430_hard_regno_nregs_with_padding): New.
      * config/msp430/msp430.c (msp430_scalar_mode_supported_p): New.
      (msp430_hard_regno_nregs_has_padding): New.
      (msp430_hard_regno_nregs_with_padding): New.
      (msp430_unwind_word_mode): Use PSImode instead of SImode.
      (msp430_addr_space_legitimate_address_p): New.
      (msp430_asm_integer): New.
      (msp430_init_dwarf_reg_sizes_extra): New.
      (msp430_print_operand): Use X suffix for PSImode even in small model.
      * config/msp430/msp430.h (POINTER_SIZE): Use 20 bits, not 32.
      (PTR_SIZE): ...but 4 bytes for EH.
      (SIZE_TYPE): Use __int20.
      (PTRDIFF_TYPE): Likewise.
      (INCOMING_FRAME_SP_OFFSET): Adjust.
      * config/msp430/msp430.md (movqi_topbyte): New.
      (movpsi): Use fixed suffixes.
      (movsipsi2): Enable for 430X, not large model.
      (extendhipsi2): Likewise.
      (zero_extendhisi2): Likewise.
      (zero_extendhisipsi2): Likewise.
      (extend_and_shift1_hipsi2): Likewise.
      (extendpsisi2): Likewise.
      (*bitbranch<mode>4_z): Fix suffix logic.
      
      From-SVN: r216225
      DJ Delorie committed
    • Fix sanitizer build on sparc. · c8473336
      	* sanitizer_common/sanitizer_platform_limits_linux.cc (time_t):
      	Define at __kernel_time_t, as needed for sparc.
      	(struct __old_kernel_stat): Don't check if __sparc__ is defined.
      	* libsanitizer/sanitizer_common/sanitizer_platform_limits_posix.h
      	(__sanitizer): Define struct___old_kernel_stat_sz,
      	struct_kernel_stat_sz, and struct_kernel_stat64_sz for sparc.
      	(__sanitizer_ipc_perm): Adjust for sparc targets.
      	(__sanitizer_shmid_ds): Likewsie.
      	(__sanitizer_sigaction): Likewsie.
      	(IOC_SIZE): Likewsie.
      
      From-SVN: r216224
      David S. Miller committed
    • re PR ada/62019 (gnat.dg/weak2.adb fails everywhere) · 5940e204
      	PR ada/62019
      	* tree-eh.c (tree_could_trap) <FUNCTION_DECL>: Revamp and really
      	do not choke on null node.
      	<VAR_DECL>: Likewise.
      
      From-SVN: r216223
      Eric Botcazou committed
    • More missed bits from the big __intN patch · 9edc6e4c
      From-SVN: r216222
      DJ Delorie committed
    • Missed bit of previous commit. · e1217ac7
      From-SVN: r216221
      DJ Delorie committed
    • machmode.h (int_n_data_t): New. · 78a7c317
      	* machmode.h (int_n_data_t): New.
      	(int_n_enabled_p): New.
      	(int_n_data): New.
      	* tree.c (int_n_enabled_p): New.
      	(int_n_trees): New.
      	(make_or_reuse_type): Check for all __intN types, not just
      	__int128.
      	(build_common_tree_nodes): Likewise.  Also fill in integer_typs[]
      	entries.
      	* tree.h (int128_integer_type_node): Remove.
      	(int128_unsigned_type_node): Remove.
      	(int_n_trees_t): New.
      	(int_n_enabled_p): New.
      	(int_n_trees): New.
      	* toplev.c (standard_type_bitsize): New.
      	(do_compile): Check which __intN types are enabled for the current
      	run.
      	* builtin-types.def (BT_INT128): Remove.
      	(BT_UINT128): Remove.
      	* machmode.def: Add macro to create __int128 for all targets.
      	* stor-layout.c (mode_for_size): Support __intN types.
      	(smallest_mode_for_size): Likewise.
      	(initialize_sizetypes): Support __intN types.
      	* genmodes.c (struct mode_data): Add int_n field.
      	(blank_mode): Likewise.
      	(INT_N): New.
      	(make_int_n): New.
      	(emit_insn_modes_h): Count __intN entries and define
      	NUM_INT_N_ENTS.
      	(emit_mode_int_n): New.
      	(emit_insn_modes_c): Call it.
      	* gimple.c (gimple_signed_or_unsigned_type): Check for all __intN
      	types, not just __int128.
      	* tree-core.h (integer_type_kind): Remove __int128-specific
      	entries, reserve spots for __intN entries.
      
      libstdc++-v3/
      	* src/c++11/limits.cc: Add support for __intN types.
      	* include/std/type_traits: Likewise.
      	* include/std/limits: Likewise.
      	* include/c_std/cstdlib: Likewise.
      	* include/bits/cpp_type_traits.h: Likewise.
      	* include/c_global/cstdlib: Likewise.
      
      c-family/
      	* c-pretty-print.c (pp_c_integer_constant): Check for all __intN
      	types, not just __int128.
      	* c-cppbuiltin.c (c_cpp_builtins): Add builtins for all __intN
      	types, not just __int128.
      	(cpp_atomic_builtins): Round pointer sizes up.
      	(type_suffix): Use type precision, not specific types.
      	* c-common.c (c_common_reswords): Remove __int128 special case.
      	(c_common_type_for_size): Check for all __intN types, not just
      	__int128.
      	(c_common_type_for_mode): Likewise.
      	(c_common_signed_or_unsigned_type): Likewise.
      	(c_build_bitfield_integer_type): Likewise.
      	(c_common_nodes_and_builtins): Likewise.
      	(keyword_begins_type_specifier): Likewise.
      	* c-common.h (rid): Remove RID_INT128 and add RID_INT_N_* for all
      	__intN variants.
      
      c/
      	* c-parser.c (c_parse_init): Add RID entries for each __intN.
      	(c_token_starts_typename): Check all __intN, not just __int128.
      	(c_token_starts_declspecs): Likewise.
      	(c_parser_declspecs): Likewise.
      	(c_parser_attribute_any_word): Likewise.
      	(c_parser_objc_selector): Likewise.
      	* c-tree.h (c_typespec_keyword): cts_int128 -> cts_int_n.
      	(struct c_declspecs): Add int_n_idx field to record *which* __intN
      	is specified.
      	* c-decl.c (declspecs_add_type): Check for all __intN, not just
      	__int128.
      	(finish_declspecs): Likewise.
      
      testsuite/
      	* g++.dg/abi/mangle64.C: New.
      
      cp/
      	* typeck.c (cp_common_type): Check for all __intN types, not just
      	__int128.
      	* decl.c (grokdeclarator): Likewise.
      	* rtti.c (emit_support_tinfos): Check for all __intN types, not just
      	__int128.
      	* parser.c (cp_lexer_next_token_is_decl_specifier_keyword): Check
      	for all __intN types, not just __int128.
      	(cp_parser_simple_type_specifier): Likewise.
      	* mangle.c (integer_type_codes): Remove int128-specific codes.
      	* cp-tree.h (cp_decl_specifier_seq): Add int_n_idx to store which
      	__intN was specified.
      	* lex.c (init_reswords): Reserve all __intN keywords.
      
      lto/
      	* lto-lang.c (lto_build_c_type_nodes): Check intN types for
      	size-type as well.
      	(lto_init): Initialize all intN types, not just int128.
      
      From-SVN: r216220
      DJ Delorie committed
    • ira.c: Fix typo in comment. · df3e3493
      2014-10-14  Kito Cheng  <kito@0xlab.org>
      
      	* ira.c: Fix typo in comment.
      	* ira.h: Ditto.
      	* ira-build.c: Ditto.
      	* ira-color.c: Ditto.
      	* ira-emit.c: Ditto.
      	* ira-int.h: Ditto.
      	* ira-lives.c: Ditto.
      
      From-SVN: r216218
      Kito Cheng committed
    • re PR rtl-optimization/63475 (Postreload CSE propagates aliased memory operand) · 0777fc02
      	PR rtl-optimization/63475
      	* alias.c (true_dependence_1): Always use get_addr to extract
      	true address operands from x_addr and mem_addr.  Use extracted
      	address operands to check for references with alignment ANDs.
      	Use extracted address operands with find_base_term and
      	base_alias_check. For noncanonicalized operands call canon_rtx with
      	extracted address operand.
      	(write_dependence_1): Ditto.
      	(may_alias_p): Ditto.  Remove unused calls to canon_rtx.
      
      From-SVN: r216217
      Uros Bizjak committed
    • Use strtod instead of strtold in libiberty/d-demangle.c · 2a523cfe
      strtold is currently used to decode templates which have a floating-point
      value encoded inside; but this routine is not available on some systems,
      such as Solaris 2.9 for instance.
      
      This patch fixes the issue by replace the use of strtold by strtod.
      It reduces a bit the precision, but it should still remain acceptable
      in most cases.
      
      libiberty/ChangeLog:
      
              * d-demangle.c: Replace strtold with strtod in global comment.
              (strtold): Remove declaration.
              (strtod): New declaration.
              (dlang_parse_real): Declare value as double instead of long
              double.  Replace call to strtold by call to strtod.
              Update format in call to snprintf.
      
      From-SVN: r216216
      Joel Brobecker committed
    • intro.xml: Update. · 95707918
      	* doc/xml/manual/intro.xml: Update.
      	* doc/xml/manual/status_cxx2011.xml: Update.
      	* doc/html/manual/*: Regenerate.
      
      From-SVN: r216215
      Jonathan Wakely committed
    • 1.cc: Add dg-require-stdint. · facb4d1b
      	* testsuite/20_util/align/1.cc: Add dg-require-stdint.
      	* testsuite/20_util/align/2.cc: Likewise.
      
      From-SVN: r216214
      Jonathan Wakely committed
    • re PR libstdc++/54354 (TODO extended iomanip manipulators std::get_time and… · ffffc732
      re PR libstdc++/54354 (TODO extended iomanip manipulators std::get_time and std::put_time (C++11, section 27.7.5))
      
      2014-10-14  Rüdiger Sonderfeld  <ruediger@c-plusplus.de>
      
      	PR libstdc++/54354
      	* include/std/iomanip (_Put_time): New struct.
      	(put_time): New manipulator.
      	(operator<<): New overloaded function.
      	* testsuite/27_io/manipulators/extended/put_time/char/1.cc: New.
      	* testsuite/27_io/manipulators/extended/put_time/char/2.cc: New.
      	* testsuite/27_io/manipulators/extended/put_time/wchar_t/1.cc: New.
      	* testsuite/27_io/manipulators/extended/put_time/wchar_t/2.cc: New.
      
      From-SVN: r216211
      Rüdiger Sonderfeld committed
    • re PR libstdc++/57440 (Memory usage with future and std containers) · 78bd42c4
      2014-10-14  Kai Tietz  <ktietz@redhat.com>
      
              PR libstdc++/57440
              * config/os/mingw32/os_defines.h (_GTHREAD_USE_MUTEX_INIT_FUNC):
              Define to avoid leak.
              * config/os/mingw32-w64/os_defines.h: Likewise.
      
      From-SVN: r216210
      Kai Tietz committed
    • re PR target/63534 (Bootstrap failure on x86_64/i686-linux) · 4513cb8c
      	PR target/63534
      gcc/
      	* config/i386/i386.c (ix86_expand_split_stack_prologue): Make
      	__morestack local.
      
      From-SVN: r216208
      Evgeny Stupachenko committed
    • Makefile.am (DEFS): Add -DPIC. · 694b4cfa
      	* ubsan/Makefile.am (DEFS): Add -DPIC.
      	* ubsan/Makefile.in: Regenerated.
      
      From-SVN: r216206
      Jakub Jelinek committed
    • line-map.h (linemap_location_from_macro_expansion_p): const struct line_maps * argument. · 3aac0952
      libcpp/ChangeLog:
      
      2014-10-14  Manuel López-Ibáñez  <manu@gcc.gnu.org>
      
      	* include/line-map.h (linemap_location_from_macro_expansion_p):
      	const struct line_maps * argument.
      	(linemap_position_for_line_and_column): const struct line_map *
      	argument.
      	* line-map.c (linemap_add_macro_token): Use correct argument name
      	in comment.
      	(linemap_position_for_line_and_column): const struct line_map *
      	argument.
      	(linemap_macro_map_loc_to_def_point): Fix comment. Make static.
      	(linemap_location_from_macro_expansion_p): const struct line_maps *
      	argument.
      	(linemap_resolve_location): Fix argument names in comment.
      
      From-SVN: r216205
      Manuel López-Ibáñez committed
    • typeck.c (cp_build_unary_op): Accept float vectors. · 48d3af12
      2014-10-14  Marc Glisse  <marc.glisse@inria.fr>
      
      gcc/cp/
      	* typeck.c (cp_build_unary_op) [TRUTH_NOT_EXPR]: Accept float vectors.
      gcc/testsuite/
      	* g++.dg/ext/vector9.C: Test ! with float vectors.
      
      From-SVN: r216201
      Marc Glisse committed
    • AVX-512. 77/n. Use blend for cond-set V32HI and V64QI. · ebe87abf
      gcc/
      	* config/i386/i386.c
      	(ix86_expand_sse_movcc): Handle V64QI and V32HI mode.
      	(ix86_expand_int_vcond): Ditto.
      
      Co-Authored-By: Andrey Turetskiy <andrey.turetskiy@intel.com>
      Co-Authored-By: Anna Tikhonova <anna.tikhonova@intel.com>
      Co-Authored-By: Ilya Tocar <ilya.tocar@intel.com>
      Co-Authored-By: Ilya Verbin <ilya.verbin@intel.com>
      Co-Authored-By: Kirill Yukhin <kirill.yukhin@intel.com>
      Co-Authored-By: Maxim Kuznetsov <maxim.kuznetsov@intel.com>
      Co-Authored-By: Michael Zolotukhin <michael.v.zolotukhin@intel.com>
      
      From-SVN: r216193
      Alexander Ivchenko committed
    • AVX-512. 74/n. Add byte/word max/mix reduction. · 0ab03ea0
      gcc/
      	* config/i386/i386.c
      	(emit_reduc_half): Handle V64QI and V32HI mode.
      	* config/i386/sse.md
      	(define_mode_iterator VI_AVX512BW): New.
      	(define_expand "reduc_<code>_<mode>"): Use VI512_48F_12BW.
      
      Co-Authored-By: Andrey Turetskiy <andrey.turetskiy@intel.com>
      Co-Authored-By: Anna Tikhonova <anna.tikhonova@intel.com>
      Co-Authored-By: Ilya Tocar <ilya.tocar@intel.com>
      Co-Authored-By: Ilya Verbin <ilya.verbin@intel.com>
      Co-Authored-By: Kirill Yukhin <kirill.yukhin@intel.com>
      Co-Authored-By: Maxim Kuznetsov <maxim.kuznetsov@intel.com>
      Co-Authored-By: Michael Zolotukhin <michael.v.zolotukhin@intel.com>
      
      From-SVN: r216192
      Alexander Ivchenko committed
    • AVX-512. 73/n. Extend reduc min/max autogen. · 805e20ad
      gcc/
              * config/i386/sse.md
              (define_mode_iterator REDUC_SMINMAX_MODE): Add V64QI and V32HI modes.
      
      Co-Authored-By: Andrey Turetskiy <andrey.turetskiy@intel.com>
      Co-Authored-By: Anna Tikhonova <anna.tikhonova@intel.com>
      Co-Authored-By: Ilya Tocar <ilya.tocar@intel.com>
      Co-Authored-By: Ilya Verbin <ilya.verbin@intel.com>
      Co-Authored-By: Kirill Yukhin <kirill.yukhin@intel.com>
      Co-Authored-By: Maxim Kuznetsov <maxim.kuznetsov@intel.com>
      Co-Authored-By: Michael Zolotukhin <michael.v.zolotukhin@intel.com>
      
      From-SVN: r216191
      Alexander Ivchenko committed
    • AVX-512. 72/n. Extend VI itterator. · 9945a432
      gcc/
      	* config/i386/i386.c
      	(ix86_expand_vector_logical_operator): Handle V16SF and V8DF modes.
      	* config/i386/sse.md
      	(define_mode_iterator VI): Add V64QI and V32HI modes.
      
      Co-Authored-By: Andrey Turetskiy <andrey.turetskiy@intel.com>
      Co-Authored-By: Anna Tikhonova <anna.tikhonova@intel.com>
      Co-Authored-By: Ilya Tocar <ilya.tocar@intel.com>
      Co-Authored-By: Ilya Verbin <ilya.verbin@intel.com>
      Co-Authored-By: Kirill Yukhin <kirill.yukhin@intel.com>
      Co-Authored-By: Maxim Kuznetsov <maxim.kuznetsov@intel.com>
      Co-Authored-By: Michael Zolotukhin <michael.v.zolotukhin@intel.com>
      
      From-SVN: r216190
      Alexander Ivchenko committed
    • AVX-512. 71/n. Remove redudant iterator attribute. · 7c3a34ae
      gcc/
      	* config/i386/sse.md (define_mode_attr avx2_avx512f): Remove.
      
      Co-Authored-By: Andrey Turetskiy <andrey.turetskiy@intel.com>
      Co-Authored-By: Anna Tikhonova <anna.tikhonova@intel.com>
      Co-Authored-By: Ilya Tocar <ilya.tocar@intel.com>
      Co-Authored-By: Ilya Verbin <ilya.verbin@intel.com>
      Co-Authored-By: Kirill Yukhin <kirill.yukhin@intel.com>
      Co-Authored-By: Maxim Kuznetsov <maxim.kuznetsov@intel.com>
      Co-Authored-By: Michael Zolotukhin <michael.v.zolotukhin@intel.com>
      
      From-SVN: r216189
      Alexander Ivchenko committed
    • typedefs.cc: Rename to alias_decl.cc. · 181e0368
      2014-10-14  Paolo Carlini  <paolo.carlini@oracle.com>
      
      	* testsuite/20_util/add_lvalue_reference/requirements/typedefs.cc:
      	Rename to alias_decl.cc.
      	* testsuite/20_util/add_rvalue_reference/requirements/typedefs.cc:
      	Likewise.
      	* testsuite/20_util/common_type/requirements/typedefs-3.cc: Likewise.
      	* testsuite/20_util/conditional/requirements/typedefs-2.cc: Likewise.
      	* testsuite/20_util/decay/requirements/typedefs-2.cc: Likewise.
      	* testsuite/20_util/enable_if/requirements/typedefs-2.cc: Likewise.
      	* testsuite/20_util/make_signed/requirements/typedefs-3.cc: Likewise.
      	* testsuite/20_util/make_unsigned/requirements/typedefs-3.cc:
      	Likewise.
      	* testsuite/20_util/remove_reference/requirements/typedefs.cc:
      	Likewise.
      	* testsuite/20_util/result_of/requirements/typedefs.cc: Likewise.
      	* testsuite/20_util/underlying_type/requirements/typedefs-3.cc:
      	Likewise.
      
      From-SVN: r216188
      Paolo Carlini committed
    • AVX-512. 70/n. Add vpmaxmin. · c305ca7f
      gcc/
      	* config/i386/sse.md
      	(define_insn "*sse4_1_<code><mode>3<mask_name>"): Add masking.
      	(define_insn "*sse4_1_<code><mode>3<mask_name>"): Ditto.
      
      Co-Authored-By: Andrey Turetskiy <andrey.turetskiy@intel.com>
      Co-Authored-By: Anna Tikhonova <anna.tikhonova@intel.com>
      Co-Authored-By: Ilya Tocar <ilya.tocar@intel.com>
      Co-Authored-By: Ilya Verbin <ilya.verbin@intel.com>
      Co-Authored-By: Kirill Yukhin <kirill.yukhin@intel.com>
      Co-Authored-By: Maxim Kuznetsov <maxim.kuznetsov@intel.com>
      Co-Authored-By: Michael Zolotukhin <michael.v.zolotukhin@intel.com>
      
      From-SVN: r216187
      Alexander Ivchenko committed
    • AVX-512. 69/n. Add vpmulhrsw insn support. · cf25c309
      gcc/
              * config/i386/sse.md
              (define_insn "avx512bw_umulhrswv32hi3<mask_name>"): New.
              (define_expand "<ssse3_avx2>_pmulhrsw<mode>3_mask"): Ditto.
      
      Co-Authored-By: Andrey Turetskiy <andrey.turetskiy@intel.com>
      Co-Authored-By: Anna Tikhonova <anna.tikhonova@intel.com>
      Co-Authored-By: Ilya Tocar <ilya.tocar@intel.com>
      Co-Authored-By: Ilya Verbin <ilya.verbin@intel.com>
      Co-Authored-By: Kirill Yukhin <kirill.yukhin@intel.com>
      Co-Authored-By: Maxim Kuznetsov <maxim.kuznetsov@intel.com>
      Co-Authored-By: Michael Zolotukhin <michael.v.zolotukhin@intel.com>
      
      From-SVN: r216186
      Alexander Ivchenko committed
    • AVX-512. 68/n. Add vpmullw, vpacksdw, pmaddwd insn. · ed3e611e
      gcc/
      	* config/i386/sse.md
      	(define_c_enum "unspec"): Add UNSPEC_PMADDWD512.
      	(define_mode_iterator VI2_AVX2): Add V32HI mode.
      	(define_expand "mul<mode>3<mask_name>"): Add masking.
      	(define_insn "*mul<mode>3<mask_name>"): Ditto.
      	(define_expand "<s>mul<mode>3_highpart<mask_name>"): Ditto.
      	(define_insn "*<s>mul<mode>3_highpart<mask_name>"): Ditto.
      	(define_insn "avx512bw_pmaddwd512<mode><mask_name>"): New.
      	(define_mode_attr SDOT_PMADD_SUF): Ditto.
      	(define_expand "sdot_prod<mode>"): Add <SDOT_PMADD_SUF>.
      	(define_insn "<sse2_avx2>_packssdw<mask_name>"): Add masking.
      	(define_insn "*<ssse3_avx2>_pmulhrsw<mode>3<mask_name>"): Ditto.
      	(define_insn "avx2_packusdw"): Delete.
      	(define_insn "sse4_1_packusdw"): Ditto.
      	(define_insn "<sse4_1_avx2>_packusdw<mask_name>"): New.
      
      Co-Authored-By: Andrey Turetskiy <andrey.turetskiy@intel.com>
      Co-Authored-By: Anna Tikhonova <anna.tikhonova@intel.com>
      Co-Authored-By: Ilya Tocar <ilya.tocar@intel.com>
      Co-Authored-By: Ilya Verbin <ilya.verbin@intel.com>
      Co-Authored-By: Kirill Yukhin <kirill.yukhin@intel.com>
      Co-Authored-By: Maxim Kuznetsov <maxim.kuznetsov@intel.com>
      Co-Authored-By: Michael Zolotukhin <michael.v.zolotukhin@intel.com>
      
      From-SVN: r216185
      Alexander Ivchenko committed
    • AVX-512. 67/n. Update constraints in vec_dup insn. · 1aff6f9a
      gcc/
      	* config/i386/sse.md
      	(define_insn "vec_dup<mode>"): Update constraints.
      
      Co-Authored-By: Andrey Turetskiy <andrey.turetskiy@intel.com>
      Co-Authored-By: Anna Tikhonova <anna.tikhonova@intel.com>
      Co-Authored-By: Ilya Tocar <ilya.tocar@intel.com>
      Co-Authored-By: Ilya Verbin <ilya.verbin@intel.com>
      Co-Authored-By: Kirill Yukhin <kirill.yukhin@intel.com>
      Co-Authored-By: Maxim Kuznetsov <maxim.kuznetsov@intel.com>
      Co-Authored-By: Michael Zolotukhin <michael.v.zolotukhin@intel.com>
      
      From-SVN: r216184
      Alexander Ivchenko committed
    • AVX-512. 66/n. Extend vpalignr insn patterns. · b99ba39a
      gcc/
      	* config/i386/sse.md
      	(define_mode_iterator SSESCALARMODE): Add V4TI mode.
      	(define_insn "<ssse3_avx2>_palignr<mode>_mask"): New.
      	(define_insn "<ssse3_avx2>_palignr<mode>"): Add EVEX version.
      
      Co-Authored-By: Andrey Turetskiy <andrey.turetskiy@intel.com>
      Co-Authored-By: Anna Tikhonova <anna.tikhonova@intel.com>
      Co-Authored-By: Ilya Tocar <ilya.tocar@intel.com>
      Co-Authored-By: Ilya Verbin <ilya.verbin@intel.com>
      Co-Authored-By: Kirill Yukhin <kirill.yukhin@intel.com>
      Co-Authored-By: Maxim Kuznetsov <maxim.kuznetsov@intel.com>
      Co-Authored-By: Michael Zolotukhin <michael.v.zolotukhin@intel.com>
      
      From-SVN: r216183
      Alexander Ivchenko committed
    • AVX-512. 65/n. Add rest of VI1-AVX2: mul insn pattern. · 2ac7a566
      gcc/
      	* config/i386/sse.md
      	(define_expand "mul<mode>3<mask_name>"): Add masking.
      
      Co-Authored-By: Andrey Turetskiy <andrey.turetskiy@intel.com>
      Co-Authored-By: Anna Tikhonova <anna.tikhonova@intel.com>
      Co-Authored-By: Ilya Tocar <ilya.tocar@intel.com>
      Co-Authored-By: Ilya Verbin <ilya.verbin@intel.com>
      Co-Authored-By: Kirill Yukhin <kirill.yukhin@intel.com>
      Co-Authored-By: Maxim Kuznetsov <maxim.kuznetsov@intel.com>
      Co-Authored-By: Michael Zolotukhin <michael.v.zolotukhin@intel.com>
      
      From-SVN: r216182
      Alexander Ivchenko committed
    • AVX-512. 64/n. Add rest of VI1-AVX2: vpack[us]wb. · d281ef42
      gcc/
      	* config/i386/sse.md
      	(define_insn "<sse2_avx2>_packsswb<mask_name>"): Add masking.
      	(define_insn "<sse2_avx2>_packuswb<mask_name>"): Ditto.
      
      Co-Authored-By: Andrey Turetskiy <andrey.turetskiy@intel.com>
      Co-Authored-By: Anna Tikhonova <anna.tikhonova@intel.com>
      Co-Authored-By: Ilya Tocar <ilya.tocar@intel.com>
      Co-Authored-By: Ilya Verbin <ilya.verbin@intel.com>
      Co-Authored-By: Kirill Yukhin <kirill.yukhin@intel.com>
      Co-Authored-By: Maxim Kuznetsov <maxim.kuznetsov@intel.com>
      Co-Authored-By: Michael Zolotukhin <michael.v.zolotukhin@intel.com>
      
      From-SVN: r216181
      Alexander Ivchenko committed
    • AVX-512. 62/n. Add vpmaddubsw,vdbpsadbw insn patterns. · 5f64b496
      gcc/
      	* config/i386/sse.md
      	(define_c_enum "unspec"): Add UNSPEC_DBPSADBW, UNSPEC_PMADDUBSW512.
      	(define_insn "avx512bw_pmaddubsw512<mode><mask_name>"): New.
      	(define_insn "<mask_codefor>avx512bw_dbpsadbw<mode><mask_name>"):
      	Ditto.
      
      Co-Authored-By: Andrey Turetskiy <andrey.turetskiy@intel.com>
      Co-Authored-By: Anna Tikhonova <anna.tikhonova@intel.com>
      Co-Authored-By: Ilya Tocar <ilya.tocar@intel.com>
      Co-Authored-By: Ilya Verbin <ilya.verbin@intel.com>
      Co-Authored-By: Kirill Yukhin <kirill.yukhin@intel.com>
      Co-Authored-By: Maxim Kuznetsov <maxim.kuznetsov@intel.com>
      Co-Authored-By: Michael Zolotukhin <michael.v.zolotukhin@intel.com>
      
      From-SVN: r216180
      Alexander Ivchenko committed
    • AVX-512. 61/n. Update FP logic insn patterns. · 26358fb6
      gcc/
      	* config/i386/sse.md
      	(define_insn "<sse>_andnot<VF_128_256:mode>3<mask_name>"): Add masking,
      	use VF_128_256 mode iterator and update assembler emit code.
      	(define_insn "<sse>_andnot<VF_512:mode>3<mask_name>"): New.
      	(define_expand "<any_logic:code><VF_128_256:mode>3<mask_name>"):
      	Add masking, use VF_128_256 mode iterator.
      	(define_expand "<any_logic:code><VF_512:mode>3<mask_name>"): New.
      	(define_insn "*<any_logic:code><VF_128_256:mode>3<mask_name>"):
      	Add masking, use VF_128_256 mode iterator and update assembler emit
      	code.
      	(define_insn "*<any_logic:code><VF_512:mode>3<mask_name>"): New.
      	(define_mode_attr avx512flogicsuff): Delete.
      	(define_insn "avx512f_<logic><mode>"): Ditto.
      	(define_insn "*andnot<mode>3<mask_name>"): Update MODE_XI, MODE_OI,
      	MODE_TI.
      	(define_insn "<mask_codefor><code><mode>3<mask_name>"): Ditto.
      
      Co-Authored-By: Andrey Turetskiy <andrey.turetskiy@intel.com>
      Co-Authored-By: Anna Tikhonova <anna.tikhonova@intel.com>
      Co-Authored-By: Ilya Tocar <ilya.tocar@intel.com>
      Co-Authored-By: Ilya Verbin <ilya.verbin@intel.com>
      Co-Authored-By: Kirill Yukhin <kirill.yukhin@intel.com>
      Co-Authored-By: Maxim Kuznetsov <maxim.kuznetsov@intel.com>
      Co-Authored-By: Michael Zolotukhin <michael.v.zolotukhin@intel.com>
      
      From-SVN: r216179
      Alexander Ivchenko committed
    • AVX-512. 60/n. Update 128bit ashrv insn pattern. · 06ba0585
      gcc/
      	* config/i386/sse.md
      	(define_mode_iterator VI128_128 [V16QI V8HI V2DI]): Delete.
      	(define_expand "vashr<mode>3<mask_name>"): Add masking,
      	use VI12_128 mode iterator.
      	(define_expand "ashrv2di3<mask_name>"): New.
      
      Co-Authored-By: Andrey Turetskiy <andrey.turetskiy@intel.com>
      Co-Authored-By: Anna Tikhonova <anna.tikhonova@intel.com>
      Co-Authored-By: Ilya Tocar <ilya.tocar@intel.com>
      Co-Authored-By: Ilya Verbin <ilya.verbin@intel.com>
      Co-Authored-By: Kirill Yukhin <kirill.yukhin@intel.com>
      Co-Authored-By: Maxim Kuznetsov <maxim.kuznetsov@intel.com>
      Co-Authored-By: Michael Zolotukhin <michael.v.zolotukhin@intel.com>
      
      From-SVN: r216178
      Alexander Ivchenko committed
    • AVX-512. 59/n. Add vptest[n]m, ucmp, cmpeq insn patterns. · 54967fb0
      gcc/
      	* config/i386/i386.c
      	(ix86_expand_args_builtin): Handle CODE_FOR_avx512vl_cmpv4di3_mask,
      	CODE_FOR_avx512vl_cmpv8si3_mask, CODE_FOR_avx512vl_ucmpv4di3_mask,
      	CODE_FOR_avx512vl_ucmpv8si3_mask, CODE_FOR_avx512vl_cmpv2di3_mask,
      	CODE_FOR_avx512vl_cmpv4si3_mask, CODE_FOR_avx512vl_ucmpv2di3_mask,
      	CODE_FOR_avx512vl_ucmpv4si3_mask.
      	* config/i386/sse.md
      	(define_insn "avx512f_ucmp<mode>3<mask_scalar_merge_name>"): Delete.
      	"<avx512>_ucmp<VI12_AVX512VL:mode>3<mask_scalar_merge_name>"):New.
      	(define_insn
      	"<avx512>_ucmp<VI48_AVX512VL:mode>3<mask_scalar_merge_name>"):Ditto.
      	(define_expand "<avx512>_eq<mode>3<mask_scalar_merge_name>"): Ditto.
      	(define_insn "<avx512>_eq<mode>3<mask_scalar_merge_name>_1"): Ditto.
      	(define_insn "<avx512>_gt<mode>3<mask_scalar_merge_name>"): Ditto.
      	(define_insn "<avx512>_testm<mode>3<mask_scalar_merge_name>"): Ditto.
      	(define_insn "<avx512>_testnm<mode>3<mask_scalar_merge_name>"): Ditto.
      
      Co-Authored-By: Andrey Turetskiy <andrey.turetskiy@intel.com>
      Co-Authored-By: Anna Tikhonova <anna.tikhonova@intel.com>
      Co-Authored-By: Ilya Tocar <ilya.tocar@intel.com>
      Co-Authored-By: Ilya Verbin <ilya.verbin@intel.com>
      Co-Authored-By: Kirill Yukhin <kirill.yukhin@intel.com>
      Co-Authored-By: Maxim Kuznetsov <maxim.kuznetsov@intel.com>
      Co-Authored-By: Michael Zolotukhin <michael.v.zolotukhin@intel.com>
      
      From-SVN: r216177
      Alexander Ivchenko committed