Forward-port of 41259:
For the llvm.c* intrinsics, we need to truncate or zero extend if we're placing
the results in a larger or smaller location.
llvm-svn: 41260
diff --git a/llvm-gcc-4.2/gcc/llvm-convert.cpp b/llvm-gcc-4.2/gcc/llvm-convert.cpp
index 03b7ec3..2290654 100644
--- a/llvm-gcc-4.2/gcc/llvm-convert.cpp
+++ b/llvm-gcc-4.2/gcc/llvm-convert.cpp
@@ -3849,13 +3849,19 @@
case BUILT_IN_CLZLL: {
Value *Amt = Emit(TREE_VALUE(TREE_OPERAND(exp, 1)), 0);
EmitBuiltinUnaryIntOp(Amt, Result, Intrinsic::ctlz);
+ const Type *DestTy = ConvertType(TREE_TYPE(exp));
+ if (Result->getType() != DestTy)
+ Result = Builder.CreateIntCast(Result, DestTy, "cast");
return true;
}
case BUILT_IN_CTZ: // These GCC builtins always return int.
case BUILT_IN_CTZL:
case BUILT_IN_CTZLL: {
Value *Amt = Emit(TREE_VALUE(TREE_OPERAND(exp, 1)), 0);
- EmitBuiltinUnaryIntOp(Amt, Result, Intrinsic::cttz);
+ EmitBuiltinUnaryIntOp(Amt, Result, Intrinsic::cttz);
+ const Type *DestTy = ConvertType(TREE_TYPE(exp));
+ if (Result->getType() != DestTy)
+ Result = Builder.CreateIntCast(Result, DestTy, "cast");
return true;
}
case BUILT_IN_PARITYLL:
@@ -3872,6 +3878,9 @@
case BUILT_IN_POPCOUNTLL: {
Value *Amt = Emit(TREE_VALUE(TREE_OPERAND(exp, 1)), 0);
EmitBuiltinUnaryIntOp(Amt, Result, Intrinsic::ctpop);
+ const Type *DestTy = ConvertType(TREE_TYPE(exp));
+ if (Result->getType() != DestTy)
+ Result = Builder.CreateIntCast(Result, DestTy, "cast");
return true;
}
case BUILT_IN_SQRT: