diff options
author | Chris Lattner <sabre@nondot.org> | 2003-02-22 23:04:52 +0000 |
---|---|---|
committer | Chris Lattner <sabre@nondot.org> | 2003-02-22 23:04:52 +0000 |
commit | 782752b7a2edbe0889766f0a71c2cb727bd89007 (patch) | |
tree | aac34b2c5d73d76bd8080696c5ee428776d9953c | |
parent | cc139de15a24d576fd98ef4599558016c86b64d6 (diff) |
Add a new interface file for the PromoteMemToReg interface in the Utils library
git-svn-id: https://llvm.org/svn/llvm-project/llvm/trunk@5609 91177308-0d34-0410-b5e6-96231b3b80d8
-rw-r--r-- | include/llvm/Transforms/Utils/PromoteMemToReg.h | 29 |
1 files changed, 29 insertions, 0 deletions
diff --git a/include/llvm/Transforms/Utils/PromoteMemToReg.h b/include/llvm/Transforms/Utils/PromoteMemToReg.h new file mode 100644 index 0000000000..ee8b7c0cb2 --- /dev/null +++ b/include/llvm/Transforms/Utils/PromoteMemToReg.h @@ -0,0 +1,29 @@ +//===- PromoteMemToReg.h - Promote Allocas to Scalars -----------*- C++ -*-===// +// +// This file exposes an interface to promote alloca instructions to SSA +// registers, by using the SSA construction algorithm. +// +//===----------------------------------------------------------------------===// + +#ifndef TRANSFORMS_UTILS_PROMOTEMEMTOREG_H +#define TRANSFORMS_UTILS_PROMOTEMEMTOREG_H + +class AllocaInst; +class DominanceFrontier; +#include <vector> + +/// isAllocaPromotable - Return true if this alloca is legal for promotion. +/// This is true if there are only loads and stores to the alloca... +/// +bool isAllocaPromotable(const AllocaInst *AI); + +/// PromoteMemToReg - Promote the specified list of alloca instructions into +/// scalar registers, inserting PHI nodes as appropriate. This function makes +/// use of DominanceFrontier information. This function does not modify the CFG +/// of the function at all. All allocas must be from the same function. +/// +void PromoteMemToReg(const std::vector<AllocaInst*> &Allocas, + DominanceFrontier &DF); + + +#endif |