Manman Ren
ce48ea7e25
PGO: preserve branch-weight metadata when simplifying Switch
...
Hanlde the case when we split the default edge if the default target has "icmp"
and unconditinal branch.
llvm-svn: 164076
2012-09-17 23:07:43 +00:00
Andrew Trick
3e5546add7
Fix release build after reverting
...
llvm-svn: 164075
2012-09-17 23:05:04 +00:00
Jakob Stoklund Olesen
0bb3dd78c4
Merge into undefined lanes under -new-coalescer.
...
Add LIS::pruneValue() and extendToIndices(). These two functions are
used by the register coalescer when merging two live ranges requires
more than a trivial value mapping as supported by LiveInterval::join().
The pruneValue() function can remove the part of a value number that is
going to conflict in join(). Afterwards, extendToIndices can restore the
live range, using any new dominating value numbers and updating the SSA
form.
Use this complex value mapping to support merging a register into a
vector lane that has a conflicting value, but the clobbered lane is
undef.
llvm-svn: 164074
2012-09-17 23:03:25 +00:00
Jakob Stoklund Olesen
af50f17df4
Stop adding <imp-def> operands when expanding REG_SEQUENCE.
...
These extra operands are not needed by register allocators using
VirtRegRewriter, and RAFast don't need them any longer.
By omitting the <imp-def> operands, it becomes possible for the new
register coalescer to track which lanes are valid and which are undef.
llvm-svn: 164073
2012-09-17 23:03:21 +00:00
Andrew Trick
8e7f202e32
Revert r164061-r164067. Most of the new subtarget emitter.
...
I have to work out the Target/CodeGen header dependencies
before putting this back.
llvm-svn: 164072
2012-09-17 23:00:42 +00:00
Richard Smith
2b006e4231
Remove redundant semicolons to fix -pedantic-errors build break with older Clangs.
...
llvm-svn: 164071
2012-09-17 22:52:05 +00:00
NAKAMURA Takumi
443c8dd57f
llvm/Target/TargetSubtargetInfo.h: Fix case in #include, s#llvm/Codegen/#llvm/CodeGen#.
...
llvm-svn: 164070
2012-09-17 22:34:56 +00:00
Manman Ren
774246a3a9
PGO: preserve branch-weight metadata when simplifying SwitchOnSelect.
...
llvm-svn: 164068
2012-09-17 22:28:55 +00:00
Andrew Trick
e95e9666ea
Don't use NULL as a fake keyword
...
llvm-svn: 164067
2012-09-17 22:26:34 +00:00
Andrew Trick
692b87c18f
InitMCProcessor
...
llvm-svn: 164066
2012-09-17 22:19:12 +00:00
Andrew Trick
f403ee7937
TargetSchedModel API. Implement latency lookup, disabled.
...
llvm-svn: 164065
2012-09-17 22:19:08 +00:00
Andrew Trick
c00f4314ce
comment typo
...
llvm-svn: 164064
2012-09-17 22:19:04 +00:00
Andrew Trick
36e07eb83e
TableGen subtarget emitter. Use getSchedClassIdx.
...
llvm-svn: 164063
2012-09-17 22:19:01 +00:00
Andrew Trick
7a1faa2c8a
TableGen subtarget emitter. Generate resolveSchedClass generated hook for resolving instruction variants.
...
llvm-svn: 164062
2012-09-17 22:18:58 +00:00
Andrew Trick
0923f8183b
TableGen subtarget emitter. Initialize MCSubtargetInfo with the new machine model.
...
llvm-svn: 164061
2012-09-17 22:18:55 +00:00
Andrew Trick
a72fca6bec
TableGen subtarget emitter. Format and emit data tables for the new machine model.
...
llvm-svn: 164060
2012-09-17 22:18:50 +00:00
Andrew Trick
9ef0882b72
TableGen subtarget emitter. Generate data tables for the new machine model.
...
Map the CodeGenSchedule object model onto data tables. The structure
of the data tables is defined in MC, so for convenience we include
MCSchedule.h. The alternative is maintaining a redundant copy of the
table structure definitions. Mapping the object model onto data tables
is sufficiently complicated that it should not be interleaved with
emitting source code. This avoids major problem with the backend for
itinerary generation.
llvm-svn: 164059
2012-09-17 22:18:48 +00:00
Andrew Trick
23f3c65e4b
TableGen subtarget emitter. Emit processor resources for the new machine model.
...
llvm-svn: 164058
2012-09-17 22:18:45 +00:00
Andrew Trick
8fa00f5069
TableGen subtarget parser: Add getProcResourcesIdx().
...
llvm-svn: 164057
2012-09-17 22:18:43 +00:00
Jan Wen Voung
4ce1d7b4f1
Add some cases to x86 OptimizeCompare to handle DEC and INC, too.
...
While we are setting the earlier def to true, also make it live.
llvm-svn: 164056
2012-09-17 22:04:23 +00:00
Manman Ren
2d4c10fc49
PGO: preserve branch-weight metadata when simplifying two branches with a common
...
destination in SimplifyCondBranchToCondBranch.
llvm-svn: 164054
2012-09-17 21:30:40 +00:00
Akira Hatanaka
9068706bb6
Make sure there is enough room for RA. getStackSize needs to be cleaned up but
...
we will do that when we implement the full save/restore.
Patch by Reed Kotler.
llvm-svn: 164051
2012-09-17 20:02:42 +00:00
Michael Ilseman
4f0e00a5b8
Increase the static sizes of some SmallSets. finalizeBundle() is very frequently called for some backends, and growing into an std::set is overkill for these numbers.
...
llvm-svn: 164044
2012-09-17 18:31:15 +00:00
Michael Ilseman
3a8336379c
whitespace
...
llvm-svn: 164043
2012-09-17 18:25:23 +00:00
Michael Liao
b503b323f3
Fix PR13859
...
- Preserve the original NOutVT during casting from vector to integer by
extracting vector elements.
llvm-svn: 164042
2012-09-17 18:05:20 +00:00
Jim Grosbach
4c36349de9
TableGen: Add initializer.
...
Keep GCC's warnings happy. It can't reason out that the state machine won't
ever hit the potentially uninitialized use in OPC_FilterValue.
llvm-svn: 164041
2012-09-17 18:00:53 +00:00
Bill Wendling
636f1a1d99
s/__llvm_gcov_flush/__gcov_flush/g
...
llvm-svn: 164040
2012-09-17 17:57:05 +00:00
Benjamin Kramer
0d874f775a
LLVM_ATTRIBUTE_USED forces emission of a function. To silence unused function warnings use LLVM_ATTRIBUTE_UNUSED.
...
llvm-svn: 164036
2012-09-17 16:46:22 +00:00
Benjamin Kramer
02a4dff492
NewSROA: Provide a full set of operator< for ByteRanges.
...
MSVC8 won't compile lower_bound if one is missing.
llvm-svn: 164035
2012-09-17 16:42:36 +00:00
Axel Naumann
4a1270691e
Fix a few vars that can end up being used without initialization.
...
The cases where no initialization happens should still be checked for logic flaws.
llvm-svn: 164032
2012-09-17 14:20:57 +00:00
Silviu Baranga
7bd2914683
Removed the VMLxForwarding feature for the Cortex-A15 target.
...
llvm-svn: 164030
2012-09-17 14:10:54 +00:00
Tom Stellard
86af62c1ad
Add a MachinePostDominator pass
...
This is used in the AMDIL and R600 backends.
llvm-svn: 164029
2012-09-17 14:08:37 +00:00
Sid Manning
a5a06ea11d
Add Michael Spencer's iterator class for stepping through relocations. Add method that, given a symbol index, will return the symbol's data.
...
llvm-svn: 164026
2012-09-17 12:27:39 +00:00
Nadav Rotem
2ae810a51f
Disable the protection from escaped allocas in an attempt to find violating passes. This may break the buildbots. I plan to revert it in a few hours.
...
llvm-svn: 164024
2012-09-17 10:21:55 +00:00
Craig Topper
77ac52bdcf
Mark unimplemented copy constructors and copy assignment operators as LLVM_DELETED_FUNCTION.
...
llvm-svn: 164017
2012-09-17 07:16:40 +00:00
Craig Topper
f7c99f9f1a
Mark unimplemented copy constructors and copy assignment operators as LLVM_DELETED_FUNCTION.
...
llvm-svn: 164016
2012-09-17 06:59:23 +00:00
Craig Topper
2663e5a7cd
Mark unimplemented copy constructors and copy assignment operators as LLVM_DELETED_FUNCTION.
...
llvm-svn: 164015
2012-09-17 06:43:55 +00:00
Craig Topper
9a86e5a35a
Mark unimplemented copy constructors and copy assignment operators as LLVM_DELETED_FUNCTION.
...
llvm-svn: 164014
2012-09-17 06:31:17 +00:00
Craig Topper
de2f3887d7
Remove a couple unused fields. Not detected by Wunused-private-field because of unimplemented copy constructor and copy assignment operator that make the class look incomplete. Upcoming patch will mark them deleted.
...
llvm-svn: 164013
2012-09-17 06:05:39 +00:00
Michael Liao
ebeedd0ed6
Fix typo
...
llvm-svn: 164012
2012-09-17 04:43:39 +00:00
Craig Topper
7fdbd2820e
Add include of Compiler.h to fix build bot failures.
...
llvm-svn: 164009
2012-09-16 21:56:23 +00:00
Craig Topper
fa8fe0e289
Add includes of Compiler.h to fix build bot failures.
...
llvm-svn: 164008
2012-09-16 21:50:09 +00:00
Craig Topper
23c5a8c450
Use LLVM_DELETED_FUNCTION for copy constructors and copy assignment operators that aren't implemented.
...
llvm-svn: 164007
2012-09-16 21:43:09 +00:00
Craig Topper
5f974ce2c4
Use LLVM_DELETED_FUNCTION for copy constructors and copy assignment operators that aren't implemented.
...
llvm-svn: 164006
2012-09-16 21:37:56 +00:00
Craig Topper
eeb967940e
Add LLVM_OVERRIDE and LLVM_FINAL C++11 compatibility macros.
...
llvm-svn: 164005
2012-09-16 20:53:30 +00:00
Chandler Carruth
9712117a07
Refactor the SROA visitors for partitioning an alloca and building
...
partition use lists a bit. No functionality changed.
These visitors are actually visiting a tuple of a Use and an offset into
the alloca. However, we use the InstVisitor to handle the dispatch over
the users, and so the Use and Offset are stored in class member
variables and set just before each call to visit(). This is fairly
awkward and makes the functions a bit harder to read, but its the only
real option we have until InstVisitor can be rewritten to use variadic
templates.
However, this pattern shouldn't be followed on the helper member
functions where there is no interface constraint from the visitor. We
already were passing the instruction as a normal parameter rather than
use the Use to get at it, start passing the offset as well. This will
become more important in subsequent patches as the offset will in some
cases change while visiting a single instruction.
llvm-svn: 164003
2012-09-16 19:39:50 +00:00
Craig Topper
a583df034a
Add 'virtual' keywoards to output file for overridden functions.
...
llvm-svn: 164002
2012-09-16 18:25:36 +00:00
Craig Topper
462c31b3da
Change unsigned to uint32_t to match base class declaration and other targets.
...
llvm-svn: 164001
2012-09-16 18:10:23 +00:00
Craig Topper
04b4e83cf7
Fix bad comment. No functional change.
...
llvm-svn: 164000
2012-09-16 16:48:25 +00:00
Craig Topper
8dcaf4998c
Add 'virtual' keywoards to output file for overridden functions.
...
llvm-svn: 163999
2012-09-16 16:35:22 +00:00