aboutsummaryrefslogtreecommitdiff
diff options
context:
space:
mode:
authorKewen Lin <linkw@linux.ibm.com>2024-01-09 23:06:13 -0600
committerKewen Lin <linkw@linux.ibm.com>2024-01-09 23:06:13 -0600
commit6660904c3f5872262f466b5cbbd48fb11e9fe966 (patch)
tree11ad044d7b3d4a22050541e7adba1643a8bcc02f
parentcf5f6a048e376ab0d2f7bc283c158605e1166061 (diff)
downloadgcc-6660904c3f5872262f466b5cbbd48fb11e9fe966.zip
gcc-6660904c3f5872262f466b5cbbd48fb11e9fe966.tar.gz
gcc-6660904c3f5872262f466b5cbbd48fb11e9fe966.tar.bz2
rs6000: Eliminate zext fed by vclzlsbb [PR111480]
As PR111480 shows, commit r14-4079 only optimizes the case of vctzlsbb but not for the similar vclzlsbb. This patch is to consider vclzlsbb as well and avoid the failure on the reported test case. It also simplifies the patterns with iterator and attribute. PR target/111480 gcc/ChangeLog: * config/rs6000/vsx.md (VCZLSBB): New int iterator. (vczlsbb_char): New int attribute. (vclzlsbb_<mode>, vctzlsbb_<mode>): Merge to ... (vc<vczlsbb_char>zlsbb_<mode>): ... this. (*vctzlsbb_zext_<mode>): Rename to ... (*vc<vczlsbb_char>zlsbb_zext_<mode>): ... this, and extend it to cover vclzlsbb.
-rw-r--r--gcc/config/rs6000/vsx.md41
1 files changed, 18 insertions, 23 deletions
diff --git a/gcc/config/rs6000/vsx.md b/gcc/config/rs6000/vsx.md
index 4c1725a..6111cc9 100644
--- a/gcc/config/rs6000/vsx.md
+++ b/gcc/config/rs6000/vsx.md
@@ -411,6 +411,12 @@
(V2DF "d")
(V4SF "w")])
+;; Iterator and attribute for vector count leading/trailing
+;; zero least-significant bits byte
+(define_int_iterator VCZLSBB [UNSPEC_VCLZLSBB
+ UNSPEC_VCTZLSBB])
+(define_int_attr vczlsbb_char [(UNSPEC_VCLZLSBB "l")
+ (UNSPEC_VCTZLSBB "t")])
;; VSX moves
@@ -5855,35 +5861,24 @@
"vcmpnezw %0,%1,%2"
[(set_attr "type" "vecsimple")])
-;; Vector Count Leading Zero Least-Significant Bits Byte
-(define_insn "vclzlsbb_<mode>"
- [(set (match_operand:SI 0 "register_operand" "=r")
- (unspec:SI
- [(match_operand:VSX_EXTRACT_I 1 "altivec_register_operand" "v")]
- UNSPEC_VCLZLSBB))]
- "TARGET_P9_VECTOR"
- "vclzlsbb %0,%1"
- [(set_attr "type" "vecsimple")])
-
-;; Vector Count Trailing Zero Least-Significant Bits Byte
-(define_insn "*vctzlsbb_zext_<mode>"
+;; Vector Count Leading/Trailing Zero Least-Significant Bits Byte
+(define_insn "*vc<vczlsbb_char>zlsbb_zext_<mode>"
[(set (match_operand:DI 0 "register_operand" "=r")
- (zero_extend:DI
- (unspec:SI
- [(match_operand:VSX_EXTRACT_I 1 "altivec_register_operand" "v")]
- UNSPEC_VCTZLSBB)))]
+ (zero_extend:DI
+ (unspec:SI
+ [(match_operand:VSX_EXTRACT_I 1 "altivec_register_operand" "v")]
+ VCZLSBB)))]
"TARGET_P9_VECTOR"
- "vctzlsbb %0,%1"
+ "vc<vczlsbb_char>zlsbb %0,%1"
[(set_attr "type" "vecsimple")])
-;; Vector Count Trailing Zero Least-Significant Bits Byte
-(define_insn "vctzlsbb_<mode>"
+(define_insn "vc<vczlsbb_char>zlsbb_<mode>"
[(set (match_operand:SI 0 "register_operand" "=r")
- (unspec:SI
- [(match_operand:VSX_EXTRACT_I 1 "altivec_register_operand" "v")]
- UNSPEC_VCTZLSBB))]
+ (unspec:SI
+ [(match_operand:VSX_EXTRACT_I 1 "altivec_register_operand" "v")]
+ VCZLSBB))]
"TARGET_P9_VECTOR"
- "vctzlsbb %0,%1"
+ "vc<vczlsbb_char>zlsbb %0,%1"
[(set_attr "type" "vecsimple")])
;; Vector Extract Unsigned Byte Left-Indexed