Andrew Trick
6cba50cbb4
Replaced ReInitMCSubtargetInfo with InitMCProcessor.
...
Now where we used to call ReInitMCSubtargetInfo, we actually recompute
the same information as InitMCSubtargetInfo instead of only setting
the feature bits.
llvm-svn: 164105
2012-09-18 05:33:15 +00:00
Craig Topper
4662d8cd85
Add LLVM_DELETED_FUNCTION to coding standards.
...
llvm-svn: 164101
2012-09-18 04:43:40 +00:00
Craig Topper
04a52acb1d
Fix a typo. No functional change.
...
llvm-svn: 164100
2012-09-18 04:43:05 +00:00
Andrew Trick
1a1e7664ae
Let NULL slip through again.
...
llvm-svn: 164099
2012-09-18 04:18:39 +00:00
Andrew Trick
e3e6fae309
TargetSchedModel API. Implement latency lookup, disabled.
...
llvm-svn: 164098
2012-09-18 04:03:34 +00:00
Andrew Trick
73e100e6f5
comment typo
...
llvm-svn: 164097
2012-09-18 04:03:30 +00:00
Andrew Trick
418db6184f
TableGen subtarget emitter. Use getSchedClassIdx.
...
llvm-svn: 164096
2012-09-18 03:55:55 +00:00
Andrew Trick
b7b658d440
TableGen subtarget emitter. Generate resolveSchedClass generated hook for resolving instruction variants.
...
llvm-svn: 164095
2012-09-18 03:41:43 +00:00
Andrew Trick
c2ee4420fd
TableGen subtarget emitter. Remove unnecessary header dependence.
...
llvm-svn: 164094
2012-09-18 03:32:57 +00:00
Craig Topper
06c859569e
Mark unimplemented operator new as LLVM_DELETED_FUNCTION.
...
llvm-svn: 164093
2012-09-18 03:25:49 +00:00
Andrew Trick
65c7aae93f
TableGen subtarget emitter. Initialize MCSubtargetInfo with the new machine model.
...
llvm-svn: 164092
2012-09-18 03:18:56 +00:00
Craig Topper
e65078e3c3
Mark constructors, destructors, and operator new commented as 'do not implement' with LLVM_DELETED_FUNCTION instead.
...
llvm-svn: 164091
2012-09-18 02:05:45 +00:00
Craig Topper
5a3d1cefa5
Mark unimplemented copy constructors and copy assignment operators as LLVM_DELETED_FUNCTION.
...
llvm-svn: 164090
2012-09-18 02:01:41 +00:00
Evan Cheng
82c85585f9
Use vld1 / vst2 for unaligned v2f64 load / store. e.g. Use vld1.16 for 2-byte
...
aligned address. Based on patch by David Peixotto.
Also use vld1.64 / vst1.64 with 128-bit alignment to take advantage of alignment
hints. rdar://12090772, rdar://12238782
llvm-svn: 164089
2012-09-18 01:42:45 +00:00
Craig Topper
24762462b0
Mark asm matcher conversion table as const.
...
llvm-svn: 164088
2012-09-18 01:41:49 +00:00
Evan Cheng
83f8b20257
Fix some funky indentation.
...
llvm-svn: 164087
2012-09-18 01:34:40 +00:00
Craig Topper
5f44668251
Fix typo in comment. No functional change.
...
llvm-svn: 164086
2012-09-18 01:13:36 +00:00
Manman Ren
e628d655cf
PGO: preserve branch-weight metadata when simplifying Switch to a sub, an icmp
...
and a conditional branch; also when removing dead cases from a switch.
llvm-svn: 164084
2012-09-18 00:47:33 +00:00
Andrew Trick
2b04a12c0c
Backout the wrong subtarget emitter fix
...
llvm-svn: 164078
2012-09-17 23:14:15 +00:00
Manman Ren
77511d5a11
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
1956ad7efe
Fix release build after reverting
...
llvm-svn: 164075
2012-09-17 23:05:04 +00:00
Jakob Stoklund Olesen
b761721812
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
b004b398e9
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
150c97940b
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
f96c884c89
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
71a6ab5ec1
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
5cee74c6a1
PGO: preserve branch-weight metadata when simplifying SwitchOnSelect.
...
llvm-svn: 164068
2012-09-17 22:28:55 +00:00
Andrew Trick
cc6a5dbc2b
Don't use NULL as a fake keyword
...
llvm-svn: 164067
2012-09-17 22:26:34 +00:00
Andrew Trick
9400ee3c79
InitMCProcessor
...
llvm-svn: 164066
2012-09-17 22:19:12 +00:00
Andrew Trick
3d3f796f3f
TargetSchedModel API. Implement latency lookup, disabled.
...
llvm-svn: 164065
2012-09-17 22:19:08 +00:00
Andrew Trick
81e5a058f2
comment typo
...
llvm-svn: 164064
2012-09-17 22:19:04 +00:00
Andrew Trick
22072f5bf2
TableGen subtarget emitter. Use getSchedClassIdx.
...
llvm-svn: 164063
2012-09-17 22:19:01 +00:00
Andrew Trick
7403ff5282
TableGen subtarget emitter. Generate resolveSchedClass generated hook for resolving instruction variants.
...
llvm-svn: 164062
2012-09-17 22:18:58 +00:00
Andrew Trick
8a499d1f62
TableGen subtarget emitter. Initialize MCSubtargetInfo with the new machine model.
...
llvm-svn: 164061
2012-09-17 22:18:55 +00:00
Andrew Trick
f5182127b1
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
ef09f46517
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
cf41195b6a
TableGen subtarget emitter. Emit processor resources for the new machine model.
...
llvm-svn: 164058
2012-09-17 22:18:45 +00:00
Andrew Trick
d15e58e200
TableGen subtarget parser: Add getProcResourcesIdx().
...
llvm-svn: 164057
2012-09-17 22:18:43 +00:00
Jan Wen Voung
bd8575d1d7
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
d4fb9f6c48
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
c0b9726fe7
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
69e2a0ad21
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
eeca6d927d
whitespace
...
llvm-svn: 164043
2012-09-17 18:25:23 +00:00
Michael Liao
b8b653397e
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
68def8a302
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
17ebc7c313
s/__llvm_gcov_flush/__gcov_flush/g
...
llvm-svn: 164040
2012-09-17 17:57:05 +00:00
Benjamin Kramer
2844c979a6
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
4f7721c005
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
bcdf671ac4
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
aa267976b5
Removed the VMLxForwarding feature for the Cortex-A15 target.
...
llvm-svn: 164030
2012-09-17 14:10:54 +00:00