forked from OSchip/llvm-project
IRgen: Add CreateIRTemp, which creates a temporary alloca but with type converted "not-for-memory". Dunno a better name.
llvm-svn: 96374
This commit is contained in:
parent
27bacafb71
commit
d004918ccb
|
@ -36,7 +36,17 @@ llvm::AllocaInst *CodeGenFunction::CreateTempAlloca(const llvm::Type *Ty,
|
|||
return new llvm::AllocaInst(Ty, 0, Name, AllocaInsertPt);
|
||||
}
|
||||
|
||||
llvm::Value *CodeGenFunction::CreateMemTemp(QualType Ty, const llvm::Twine &Name) {
|
||||
llvm::Value *CodeGenFunction::CreateIRTemp(QualType Ty,
|
||||
const llvm::Twine &Name) {
|
||||
llvm::AllocaInst *Alloc = CreateTempAlloca(ConvertType(Ty), Name);
|
||||
// FIXME: Should we prefer the preferred type alignment here?
|
||||
CharUnits Align = getContext().getTypeAlignInChars(Ty);
|
||||
Alloc->setAlignment(Align.getQuantity());
|
||||
return Alloc;
|
||||
}
|
||||
|
||||
llvm::Value *CodeGenFunction::CreateMemTemp(QualType Ty,
|
||||
const llvm::Twine &Name) {
|
||||
llvm::AllocaInst *Alloc = CreateTempAlloca(ConvertTypeForMem(Ty), Name);
|
||||
// FIXME: Should we prefer the preferred type alignment here?
|
||||
CharUnits Align = getContext().getTypeAlignInChars(Ty);
|
||||
|
|
|
@ -663,6 +663,13 @@ public:
|
|||
llvm::AllocaInst *CreateTempAlloca(const llvm::Type *Ty,
|
||||
const llvm::Twine &Name = "tmp");
|
||||
|
||||
/// CreateIRTemp - Create a temporary IR object of the given type, with
|
||||
/// appropriate alignment. This routine should only be used when an temporary
|
||||
/// value needs to be stored into an alloca (for example, to avoid explicit
|
||||
/// PHI construction), but the type is the IR type, not the type appropriate
|
||||
/// for storing in memory.
|
||||
llvm::Value *CreateIRTemp(QualType T, const llvm::Twine &Name = "tmp");
|
||||
|
||||
/// CreateMemTemp - Create a temporary memory object of the given type, with
|
||||
/// appropriate alignment.
|
||||
llvm::Value *CreateMemTemp(QualType T, const llvm::Twine &Name = "tmp");
|
||||
|
|
Loading…
Reference in New Issue