From: Robin Dapp Date: Tue, 5 Nov 2024 13:47:07 +0000 (+0100) Subject: i386: Add zero maskload else operand. X-Git-Tag: basepoints/gcc-16~4165 X-Git-Url: http://git.ipfire.org/?a=commitdiff_plain;h=ebf30772415cfd3fa544fc7262b28b948591538f;p=thirdparty%2Fgcc.git i386: Add zero maskload else operand. gcc/ChangeLog: * config/i386/sse.md (maskload): Call maskload..._1. (maskload_1): Rename. --- diff --git a/gcc/config/i386/sse.md b/gcc/config/i386/sse.md index efe32e5149fc..72acd5bde5e4 100644 --- a/gcc/config/i386/sse.md +++ b/gcc/config/i386/sse.md @@ -28650,7 +28650,7 @@ (set_attr "btver2_decode" "vector") (set_attr "mode" "")]) -(define_expand "maskload" +(define_expand "maskload_1" [(set (match_operand:V48_128_256 0 "register_operand") (unspec:V48_128_256 [(match_operand: 2 "register_operand") @@ -28658,13 +28658,28 @@ UNSPEC_MASKMOV))] "TARGET_AVX") +(define_expand "maskload" + [(set (match_operand:V48_128_256 0 "register_operand") + (unspec:V48_128_256 + [(match_operand: 2 "register_operand") + (match_operand:V48_128_256 1 "memory_operand") + (match_operand:V48_128_256 3 "const0_operand")] + UNSPEC_MASKMOV))] + "TARGET_AVX" +{ + emit_insn (gen_maskload_1 (operands[0], + operands[1], + operands[2])); + DONE; +}) + (define_expand "maskload" [(set (match_operand:V48_AVX512VL 0 "register_operand") (vec_merge:V48_AVX512VL (unspec:V48_AVX512VL [(match_operand:V48_AVX512VL 1 "memory_operand")] UNSPEC_MASKLOAD) - (match_dup 0) + (match_operand:V48_AVX512VL 3 "const0_operand") (match_operand: 2 "register_operand")))] "TARGET_AVX512F") @@ -28674,7 +28689,7 @@ (unspec:VI12HFBF_AVX512VL [(match_operand:VI12HFBF_AVX512VL 1 "memory_operand")] UNSPEC_MASKLOAD) - (match_dup 0) + (match_operand:VI12HFBF_AVX512VL 3 "const0_operand") (match_operand: 2 "register_operand")))] "TARGET_AVX512BW")