[llvm-commits] CVS: llvm/lib/CodeGen/IntrinsicLowering.cpp
Chris Lattner
clattner at apple.com
Sun Apr 1 13:59:03 PDT 2007
This is incorrect for the changes you made to the ctpop (etc)
prototypes. They will assert in RAUW.
-Chris
On Apr 1, 2007, at 12:35 AM, Reid Spencer wrote:
>
>
> Changes in directory llvm/lib/CodeGen:
>
> IntrinsicLowering.cpp updated: 1.72 -> 1.73
> ---
> Log message:
>
> For PR1297: http://llvm.org/PR1297 :
> Support overloaded intrinsics bswap, ctpop, cttz, ctlz.
>
>
> ---
> Diffs of the changes: (+4 -17)
>
> IntrinsicLowering.cpp | 21 ++++-----------------
> 1 files changed, 4 insertions(+), 17 deletions(-)
>
>
> Index: llvm/lib/CodeGen/IntrinsicLowering.cpp
> diff -u llvm/lib/CodeGen/IntrinsicLowering.cpp:1.72 llvm/lib/
> CodeGen/IntrinsicLowering.cpp:1.73
> --- llvm/lib/CodeGen/IntrinsicLowering.cpp:1.72 Thu Mar 1 14:24:30
> 2007
> +++ llvm/lib/CodeGen/IntrinsicLowering.cpp Sun Apr 1 02:35:23 2007
> @@ -236,8 +236,6 @@
> return LowerCTPOP(V, IP);
> }
>
> -
> -
> void IntrinsicLowering::LowerIntrinsicCall(CallInst *CI) {
> Function *Callee = CI->getCalledFunction();
> assert(Callee && "Cannot lower an indirect call!");
> @@ -283,30 +281,19 @@
> Type::VoidTy, AbortFCache);
> break;
> }
> - case Intrinsic::ctpop_i8:
> - case Intrinsic::ctpop_i16:
> - case Intrinsic::ctpop_i32:
> - case Intrinsic::ctpop_i64:
> + case Intrinsic::ctpop:
> CI->replaceAllUsesWith(LowerCTPOP(CI->getOperand(1), CI));
> break;
>
> - case Intrinsic::bswap_i16:
> - case Intrinsic::bswap_i32:
> - case Intrinsic::bswap_i64:
> + case Intrinsic::bswap:
> CI->replaceAllUsesWith(LowerBSWAP(CI->getOperand(1), CI));
> break;
>
> - case Intrinsic::ctlz_i8:
> - case Intrinsic::ctlz_i16:
> - case Intrinsic::ctlz_i32:
> - case Intrinsic::ctlz_i64:
> + case Intrinsic::ctlz:
> CI->replaceAllUsesWith(LowerCTLZ(CI->getOperand(1), CI));
> break;
>
> - case Intrinsic::cttz_i8:
> - case Intrinsic::cttz_i16:
> - case Intrinsic::cttz_i32:
> - case Intrinsic::cttz_i64: {
> + case Intrinsic::cttz: {
> // cttz(x) -> ctpop(~X & (X-1))
> Value *Src = CI->getOperand(1);
> Value *NotSrc = BinaryOperator::createNot(Src, Src->getName()
> +".not", CI);
>
>
>
> _______________________________________________
> llvm-commits mailing list
> llvm-commits at cs.uiuc.edu
> http://lists.cs.uiuc.edu/mailman/listinfo/llvm-commits
More information about the llvm-commits
mailing list