summaryrefslogtreecommitdiffstats
path: root/clang/lib/CodeGen/CodeGenModule.cpp
diff options
context:
space:
mode:
authorSanjiv Gupta <sanjiv.gupta@microchip.com>2008-11-21 07:57:42 +0000
committerSanjiv Gupta <sanjiv.gupta@microchip.com>2008-11-21 07:57:42 +0000
commit371298488b8ac5da2239b5131e9f5f0993c0bce7 (patch)
tree2782d5ef4c6e700d5a8dd86651f40450de5b8824 /clang/lib/CodeGen/CodeGenModule.cpp
parentc5bab9f35eda1045b385d19d552391800e1fdd37 (diff)
downloadbcm5719-llvm-371298488b8ac5da2239b5131e9f5f0993c0bce7.tar.gz
bcm5719-llvm-371298488b8ac5da2239b5131e9f5f0993c0bce7.zip
mem[cpy,set,move] intrinsics are now overloaded.
llvm-svn: 59806
Diffstat (limited to 'clang/lib/CodeGen/CodeGenModule.cpp')
-rw-r--r--clang/lib/CodeGen/CodeGenModule.cpp27
1 files changed, 3 insertions, 24 deletions
diff --git a/clang/lib/CodeGen/CodeGenModule.cpp b/clang/lib/CodeGen/CodeGenModule.cpp
index 7ea52deb2ad..029adba2b16 100644
--- a/clang/lib/CodeGen/CodeGenModule.cpp
+++ b/clang/lib/CodeGen/CodeGenModule.cpp
@@ -757,38 +757,17 @@ llvm::Function *CodeGenModule::getIntrinsic(unsigned IID,const llvm::Type **Tys,
llvm::Function *CodeGenModule::getMemCpyFn() {
if (MemCpyFn) return MemCpyFn;
- llvm::Intrinsic::ID IID;
- switch (Context.Target.getPointerWidth(0)) {
- default: assert(0 && "Unknown ptr width");
- case 16: IID = llvm::Intrinsic::memcpy_i16; break;
- case 32: IID = llvm::Intrinsic::memcpy_i32; break;
- case 64: IID = llvm::Intrinsic::memcpy_i64; break;
- }
- return MemCpyFn = getIntrinsic(IID);
+ return MemCpyFn = getIntrinsic(llvm::Intrinsic::memcpy);
}
llvm::Function *CodeGenModule::getMemMoveFn() {
if (MemMoveFn) return MemMoveFn;
- llvm::Intrinsic::ID IID;
- switch (Context.Target.getPointerWidth(0)) {
- default: assert(0 && "Unknown ptr width");
- case 16: IID = llvm::Intrinsic::memmove_i16; break;
- case 32: IID = llvm::Intrinsic::memmove_i32; break;
- case 64: IID = llvm::Intrinsic::memmove_i64; break;
- }
- return MemMoveFn = getIntrinsic(IID);
+ return MemMoveFn = getIntrinsic(llvm::Intrinsic::memmove);
}
llvm::Function *CodeGenModule::getMemSetFn() {
if (MemSetFn) return MemSetFn;
- llvm::Intrinsic::ID IID;
- switch (Context.Target.getPointerWidth(0)) {
- default: assert(0 && "Unknown ptr width");
- case 16: IID = llvm::Intrinsic::memset_i16; break;
- case 32: IID = llvm::Intrinsic::memset_i32; break;
- case 64: IID = llvm::Intrinsic::memset_i64; break;
- }
- return MemSetFn = getIntrinsic(IID);
+ return MemSetFn = getIntrinsic(llvm::Intrinsic::memset);
}
static void appendFieldAndPadding(CodeGenModule &CGM,
OpenPOWER on IntegriCloud