summaryrefslogtreecommitdiff
path: root/include/llvm/IRBuilder.h
diff options
context:
space:
mode:
authorChandler Carruth <chandlerc@gmail.com>2012-07-16 07:45:06 +0000
committerChandler Carruth <chandlerc@gmail.com>2012-07-16 07:45:06 +0000
commit299493720382ab26e0842eca233fd240dce3b3d6 (patch)
treed9d900033902354b0b64e4f30202880baa69e60b /include/llvm/IRBuilder.h
parent4b31c4d93ff23c4b9a5d9169ff5e6f51731fca17 (diff)
downloadllvm-299493720382ab26e0842eca233fd240dce3b3d6.tar.gz
llvm-299493720382ab26e0842eca233fd240dce3b3d6.tar.bz2
llvm-299493720382ab26e0842eca233fd240dce3b3d6.tar.xz
Add support for attaching branch weight metadata directly from the IRBuilder.
Added a basic unit test for this with CreateCondBr. I didn't go all the way and test the switch side as the boilerplate for setting up the switch IRBuilder unit tests is a lot more. Fortunately, the two share all the interesting code paths. git-svn-id: https://llvm.org/svn/llvm-project/llvm/trunk@160251 91177308-0d34-0410-b5e6-96231b3b80d8
Diffstat (limited to 'include/llvm/IRBuilder.h')
-rw-r--r--include/llvm/IRBuilder.h23
1 files changed, 19 insertions, 4 deletions
diff --git a/include/llvm/IRBuilder.h b/include/llvm/IRBuilder.h
index c6200273b1..d5b6f47f8a 100644
--- a/include/llvm/IRBuilder.h
+++ b/include/llvm/IRBuilder.h
@@ -411,6 +411,17 @@ public:
// Instruction creation methods: Terminators
//===--------------------------------------------------------------------===//
+private:
+ /// \brief Helper to add branch weight metadata onto an instruction.
+ /// \returns The annotated instruction.
+ template <typename InstTy>
+ InstTy *addBranchWeights(InstTy *I, MDNode *Weights) {
+ if (Weights)
+ I->setMetadata(LLVMContext::MD_prof, Weights);
+ return I;
+ }
+
+public:
/// CreateRetVoid - Create a 'ret void' instruction.
ReturnInst *CreateRetVoid() {
return Insert(ReturnInst::Create(Context));
@@ -444,15 +455,19 @@ public:
/// CreateCondBr - Create a conditional 'br Cond, TrueDest, FalseDest'
/// instruction.
- BranchInst *CreateCondBr(Value *Cond, BasicBlock *True, BasicBlock *False) {
- return Insert(BranchInst::Create(True, False, Cond));
+ BranchInst *CreateCondBr(Value *Cond, BasicBlock *True, BasicBlock *False,
+ MDNode *BranchWeights = 0) {
+ return Insert(addBranchWeights(BranchInst::Create(True, False, Cond),
+ BranchWeights));
}
/// CreateSwitch - Create a switch instruction with the specified value,
/// default dest, and with a hint for the number of cases that will be added
/// (for efficient allocation).
- SwitchInst *CreateSwitch(Value *V, BasicBlock *Dest, unsigned NumCases = 10) {
- return Insert(SwitchInst::Create(V, Dest, NumCases));
+ SwitchInst *CreateSwitch(Value *V, BasicBlock *Dest, unsigned NumCases = 10,
+ MDNode *BranchWeights = 0) {
+ return Insert(addBranchWeights(SwitchInst::Create(V, Dest, NumCases),
+ BranchWeights));
}
/// CreateIndirectBr - Create an indirect branch instruction with the