diff options
-rw-r--r-- | lib/Target/X86/X86FastISel.cpp | 8 |
1 files changed, 5 insertions, 3 deletions
diff --git a/lib/Target/X86/X86FastISel.cpp b/lib/Target/X86/X86FastISel.cpp index 0be9dfa06c..c563a56f98 100644 --- a/lib/Target/X86/X86FastISel.cpp +++ b/lib/Target/X86/X86FastISel.cpp @@ -1535,11 +1535,12 @@ bool X86FastISel::X86SelectCall(const Instruction *I) { } unsigned ArgReg; + + // Passing bools around ends up doing a trunc to i1 and passing it. + // Codegen this as an argument + "and 1". if (ArgVal->getType()->isIntegerTy(1) && isa<TruncInst>(ArgVal) && cast<TruncInst>(ArgVal)->getParent() == I->getParent() && ArgVal->hasOneUse()) { - // Passing bools around ends up doing a trunc to i1 and passing it. - // Codegen this as an argument + "and 1". ArgVal = cast<TruncInst>(ArgVal)->getOperand(0); ArgReg = getRegForValue(ArgVal); if (ArgReg == 0) return false; @@ -1551,9 +1552,10 @@ bool X86FastISel::X86SelectCall(const Instruction *I) { ArgVal->hasOneUse(), 1); } else { ArgReg = getRegForValue(ArgVal); - if (ArgReg == 0) return false; } + if (ArgReg == 0) return false; + // FIXME: Only handle *easy* calls for now. if (CS.paramHasAttr(AttrInd, Attribute::InReg) || CS.paramHasAttr(AttrInd, Attribute::StructRet) || |