[multiversion] Implement the old pass manager's TTI wrapper pass in
authorChandler Carruth <chandlerc@gmail.com>
Sun, 1 Feb 2015 12:26:09 +0000 (12:26 +0000)
committerChandler Carruth <chandlerc@gmail.com>
Sun, 1 Feb 2015 12:26:09 +0000 (12:26 +0000)
commit5ec2b1d11ad4986da2691aceea2ac09cc3230e56
tree46d805787f5a21637a3cfffbc9ef336029ff6e3b
parentfdb9c573f754364bddee53e75049e9ddd6cc457a
[multiversion] Implement the old pass manager's TTI wrapper pass in
terms of the new pass manager's TargetIRAnalysis.

Yep, this is one of the nicer bits of the new pass manager's design.
Passes can in many cases operate in a vacuum and so we can just nest
things when convenient. This is particularly convenient here as I can
now consolidate all of the TargetMachine logic on this analysis.

The most important change here is that this pushes the function we need
TTI for all the way into the TargetMachine, and re-creates the TTI
object for each function rather than re-using it for each function.
We're now prepared to teach the targets to produce function-specific TTI
objects with specific subtargets cached, etc.

One piece of feedback I'd love here is whether its worth renaming any of
this stuff. None of the names really seem that awesome to me at this
point, but TargetTransformInfoWrapperPass is particularly ... odd.
TargetIRAnalysisWrapper might make more sense. I would want to do that
rename separately anyways, but let me know what you think.

llvm-svn: 227731
llvm/include/llvm/Analysis/TargetTransformInfo.h
llvm/lib/Analysis/TargetTransformInfo.cpp
llvm/lib/CodeGen/LLVMTargetMachine.cpp
llvm/lib/LTO/LTOCodeGenerator.cpp
llvm/lib/Target/TargetMachineC.cpp
llvm/tools/opt/opt.cpp