Have fast-isel understand llvm.objectsize. Update testcase for slightly
authorEric Christopher <echristo@apple.com>
Thu, 11 Mar 2010 06:20:22 +0000 (06:20 +0000)
committerEric Christopher <echristo@apple.com>
Thu, 11 Mar 2010 06:20:22 +0000 (06:20 +0000)
different codegen.

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

lib/Target/X86/X86FastISel.cpp
test/CodeGen/X86/object-size.ll

index 27807f29024dda9ef01732a4854ef2d810954f48..96b652d39e0d4570fa047003234c26bc4114cc41 100644 (file)
@@ -1166,6 +1166,30 @@ bool X86FastISel::X86VisitIntrinsicCall(IntrinsicInst &I) {
   // FIXME: Handle more intrinsics.
   switch (I.getIntrinsicID()) {
   default: return false;
+  case Intrinsic::objectsize: {
+    ConstantInt *CI = dyn_cast<ConstantInt>(I.getOperand(2));
+    const Type *Ty = I.getCalledFunction()->getReturnType();
+    
+    assert(CI && "Non-constant type in Intrinsic::objectsize?");
+    
+    EVT VT;
+    if (!isTypeLegal(Ty, VT))
+      return false;
+    
+    unsigned OpC = 0;
+    if (VT == MVT::i32)
+      OpC = X86::MOV32ri;
+    else if (VT == MVT::i64)
+      OpC = X86::MOV64ri;
+    else
+      return false;
+    
+    unsigned ResultReg = createResultReg(TLI.getRegClassFor(VT));
+    BuildMI(MBB, DL, TII.get(OpC), ResultReg).
+                                  addImm(CI->getZExtValue() == 0 ? -1ULL : 0);
+    UpdateValueMap(&I, ResultReg);
+    return true;
+  }
   case Intrinsic::dbg_declare: {
     DbgDeclareInst *DI = cast<DbgDeclareInst>(&I);
     X86AddressMode AM;
index eed3cfc851361419a525d817ba56868c68ea5704..bbe6b2341e5832d997e6f3b8889fc1cf20ffb1f3 100644 (file)
@@ -12,7 +12,7 @@ entry:
   %tmp = load i8** @p                             ; <i8*> [#uses=1]
   %0 = call i64 @llvm.objectsize.i64(i8* %tmp, i1 0) ; <i64> [#uses=1]
   %cmp = icmp ne i64 %0, -1                       ; <i1> [#uses=1]
-; X64: movq    $-1, %rax
+; X64: movabsq $-1, %rax
 ; X64: cmpq    $-1, %rax
   br i1 %cmp, label %cond.true, label %cond.false