summaryrefslogtreecommitdiffstats
diff options
context:
space:
mode:
authorDaniel Dunbar <daniel@zuster.org>2009-02-02 19:06:38 +0000
committerDaniel Dunbar <daniel@zuster.org>2009-02-02 19:06:38 +0000
commitf5589ac5a917c845475d64cf288c4739d44ca48b (patch)
treeed3375dc9c5b9c5c0f6b35f07463b1d789d2f300
parent8525d83aacc8a9d8b021eae1132dd73de68f2fde (diff)
downloadbcm5719-llvm-f5589ac5a917c845475d64cf288c4739d44ca48b.tar.gz
bcm5719-llvm-f5589ac5a917c845475d64cf288c4739d44ca48b.zip
Shuffle some functions around, no functionality change.
llvm-svn: 63538
-rw-r--r--clang/lib/CodeGen/CGCall.cpp130
1 files changed, 65 insertions, 65 deletions
diff --git a/clang/lib/CodeGen/CGCall.cpp b/clang/lib/CodeGen/CGCall.cpp
index c08b93bd84a..4c423ea5f10 100644
--- a/clang/lib/CodeGen/CGCall.cpp
+++ b/clang/lib/CodeGen/CGCall.cpp
@@ -874,6 +874,71 @@ CodeGenFunction::ExpandTypeToArgs(QualType Ty, RValue RV,
}
}
+/// CreateCoercedLoad - Create a load from \arg SrcPtr interpreted as
+/// a pointer to an object of type \arg Ty.
+///
+/// This safely handles the case when the src type is smaller than the
+/// destination type; in this situation the values of bits which not
+/// present in the src are undefined.
+static llvm::Value *CreateCoercedLoad(llvm::Value *SrcPtr,
+ const llvm::Type *Ty,
+ CodeGenFunction &CGF) {
+ const llvm::Type *SrcTy =
+ cast<llvm::PointerType>(SrcPtr->getType())->getElementType();
+ uint64_t SrcSize = CGF.CGM.getTargetData().getTypePaddedSize(SrcTy);
+ uint64_t DstSize = CGF.CGM.getTargetData().getTypePaddedSize(Ty);
+
+ // If load is legal, just bitcase the src pointer.
+ if (SrcSize == DstSize) {
+ llvm::Value *Casted =
+ CGF.Builder.CreateBitCast(SrcPtr, llvm::PointerType::getUnqual(Ty));
+ return CGF.Builder.CreateLoad(Casted);
+ } else {
+ assert(SrcSize < DstSize && "Coercion is losing source bits!");
+
+ // Otherwise do coercion through memory. This is stupid, but
+ // simple.
+ llvm::Value *Tmp = CGF.CreateTempAlloca(Ty);
+ llvm::Value *Casted =
+ CGF.Builder.CreateBitCast(Tmp, llvm::PointerType::getUnqual(SrcTy));
+ CGF.Builder.CreateStore(CGF.Builder.CreateLoad(SrcPtr), Casted);
+ return CGF.Builder.CreateLoad(Tmp);
+ }
+}
+
+/// CreateCoercedStore - Create a store to \arg DstPtr from \arg Src,
+/// where the source and destination may have different types.
+///
+/// This safely handles the case when the src type is larger than the
+/// destination type; the upper bits of the src will be lost.
+static void CreateCoercedStore(llvm::Value *Src,
+ llvm::Value *DstPtr,
+ CodeGenFunction &CGF) {
+ const llvm::Type *SrcTy = Src->getType();
+ const llvm::Type *DstTy =
+ cast<llvm::PointerType>(DstPtr->getType())->getElementType();
+
+ uint64_t SrcSize = CGF.CGM.getTargetData().getTypePaddedSize(SrcTy);
+ uint64_t DstSize = CGF.CGM.getTargetData().getTypePaddedSize(DstTy);
+
+ // If store is legal, just bitcase the src pointer.
+ if (SrcSize == DstSize) {
+ llvm::Value *Casted =
+ CGF.Builder.CreateBitCast(DstPtr, llvm::PointerType::getUnqual(SrcTy));
+ CGF.Builder.CreateStore(Src, Casted);
+ } else {
+ assert(SrcSize > DstSize && "Coercion is missing bits!");
+
+ // Otherwise do coercion through memory. This is stupid, but
+ // simple.
+ llvm::Value *Tmp = CGF.CreateTempAlloca(SrcTy);
+ CGF.Builder.CreateStore(Src, Tmp);
+ llvm::Value *Casted =
+ CGF.Builder.CreateBitCast(Tmp, llvm::PointerType::getUnqual(DstTy));
+ CGF.Builder.CreateStore(CGF.Builder.CreateLoad(Casted), DstPtr);
+ }
+}
+
/***/
const llvm::FunctionType *
@@ -1112,71 +1177,6 @@ void CodeGenFunction::EmitFunctionProlog(llvm::Function *Fn,
assert(AI == Fn->arg_end() && "Argument mismatch!");
}
-/// CreateCoercedLoad - Create a load from \arg SrcPtr interpreted as
-/// a pointer to an object of type \arg Ty.
-///
-/// This safely handles the case when the src type is smaller than the
-/// destination type; in this situation the values of bits which not
-/// present in the src are undefined.
-static llvm::Value *CreateCoercedLoad(llvm::Value *SrcPtr,
- const llvm::Type *Ty,
- CodeGenFunction &CGF) {
- const llvm::Type *SrcTy =
- cast<llvm::PointerType>(SrcPtr->getType())->getElementType();
- uint64_t SrcSize = CGF.CGM.getTargetData().getTypePaddedSize(SrcTy);
- uint64_t DstSize = CGF.CGM.getTargetData().getTypePaddedSize(Ty);
-
- // If load is legal, just bitcase the src pointer.
- if (SrcSize == DstSize) {
- llvm::Value *Casted =
- CGF.Builder.CreateBitCast(SrcPtr, llvm::PointerType::getUnqual(Ty));
- return CGF.Builder.CreateLoad(Casted);
- } else {
- assert(SrcSize < DstSize && "Coercion is losing source bits!");
-
- // Otherwise do coercion through memory. This is stupid, but
- // simple.
- llvm::Value *Tmp = CGF.CreateTempAlloca(Ty);
- llvm::Value *Casted =
- CGF.Builder.CreateBitCast(Tmp, llvm::PointerType::getUnqual(SrcTy));
- CGF.Builder.CreateStore(CGF.Builder.CreateLoad(SrcPtr), Casted);
- return CGF.Builder.CreateLoad(Tmp);
- }
-}
-
-/// CreateCoercedStore - Create a store to \arg DstPtr from \arg Src,
-/// where the source and destination may have different types.
-///
-/// This safely handles the case when the src type is larger than the
-/// destination type; the upper bits of the src will be lost.
-static void CreateCoercedStore(llvm::Value *Src,
- llvm::Value *DstPtr,
- CodeGenFunction &CGF) {
- const llvm::Type *SrcTy = Src->getType();
- const llvm::Type *DstTy =
- cast<llvm::PointerType>(DstPtr->getType())->getElementType();
-
- uint64_t SrcSize = CGF.CGM.getTargetData().getTypePaddedSize(SrcTy);
- uint64_t DstSize = CGF.CGM.getTargetData().getTypePaddedSize(DstTy);
-
- // If store is legal, just bitcase the src pointer.
- if (SrcSize == DstSize) {
- llvm::Value *Casted =
- CGF.Builder.CreateBitCast(DstPtr, llvm::PointerType::getUnqual(SrcTy));
- CGF.Builder.CreateStore(Src, Casted);
- } else {
- assert(SrcSize > DstSize && "Coercion is missing bits!");
-
- // Otherwise do coercion through memory. This is stupid, but
- // simple.
- llvm::Value *Tmp = CGF.CreateTempAlloca(SrcTy);
- CGF.Builder.CreateStore(Src, Tmp);
- llvm::Value *Casted =
- CGF.Builder.CreateBitCast(Tmp, llvm::PointerType::getUnqual(DstTy));
- CGF.Builder.CreateStore(CGF.Builder.CreateLoad(Casted), DstPtr);
- }
-}
-
void CodeGenFunction::EmitFunctionEpilog(QualType RetTy,
llvm::Value *ReturnValue) {
llvm::Value *RV = 0;
OpenPOWER on IntegriCloud