Make these predicates return true for bit_convert(buildvector)'s as well as
authorChris Lattner <sabre@nondot.org>
Sat, 15 Apr 2006 23:38:00 +0000 (23:38 +0000)
committerChris Lattner <sabre@nondot.org>
Sat, 15 Apr 2006 23:38:00 +0000 (23:38 +0000)
buildvectors.

git-svn-id: https://llvm.org/svn/llvm-project/llvm/trunk@27723 91177308-0d34-0410-b5e6-96231b3b80d8

lib/CodeGen/SelectionDAG/SelectionDAG.cpp

index bcdbef17ec4f11c416664086928b8bfda0c65f55..75281d5a85def0db618e186111c514d97c7fc31c 100644 (file)
@@ -73,6 +73,10 @@ bool ConstantFPSDNode::isExactlyValue(double V) const {
 /// isBuildVectorAllOnes - Return true if the specified node is a
 /// BUILD_VECTOR where all of the elements are ~0 or undef.
 bool ISD::isBuildVectorAllOnes(const SDNode *N) {
+  // Look through a bit convert.
+  if (N->getOpcode() == ISD::BIT_CONVERT)
+    N = N->getOperand(0).Val;
+  
   if (N->getOpcode() != ISD::BUILD_VECTOR) return false;
   
   unsigned i = 0, e = N->getNumOperands();
@@ -117,6 +121,10 @@ bool ISD::isBuildVectorAllOnes(const SDNode *N) {
 /// isBuildVectorAllZeros - Return true if the specified node is a
 /// BUILD_VECTOR where all of the elements are 0 or undef.
 bool ISD::isBuildVectorAllZeros(const SDNode *N) {
+  // Look through a bit convert.
+  if (N->getOpcode() == ISD::BIT_CONVERT)
+    N = N->getOperand(0).Val;
+  
   if (N->getOpcode() != ISD::BUILD_VECTOR) return false;
   
   unsigned i = 0, e = N->getNumOperands();