Michael Ilseman
52059da858
New utility for expanding integer division for targets that don't support it.
...
Implementation derived from compiler-rt's implementation of signed and unsigned integer division.
llvm-svn: 164173
2012-09-18 22:02:40 +00:00
Evan Cheng
1de7ec8c7c
MOVi16 (movw) is only legal on cpus with V6T2 support. rdar://12300648
...
llvm-svn: 164169
2012-09-18 21:24:16 +00:00
Benjamin Kramer
ef878a832b
FileCheck: Fix off-by-one bug that made CHECK-NOT: ignore the next character after the colon.
...
llvm-svn: 164165
2012-09-18 20:51:39 +00:00
Roman Divacky
947148aa45
Add test for r164155 and remove two tests superseded by ppc64-calls.ll.
...
llvm-svn: 164162
2012-09-18 19:51:44 +00:00
Jan Sjödin
4d0c299f39
Add hidden flag to exclude aliases from output.
...
llvm-svn: 164158
2012-09-18 18:47:58 +00:00
Rafael Espindola
99c2acbb05
Add a MapVector class. It provides a regular set iteration, but
...
also provides a insertion order iteration over the values.
llvm-svn: 164157
2012-09-18 18:43:21 +00:00
Roman Divacky
09adf3decc
Fix the isLocalCall() by checking for linker weakness as well.
...
llvm-svn: 164155
2012-09-18 18:27:49 +00:00
Andrew Trick
f2b70d9f3a
TargetSchedule: cleanup computeOperandLatency logic & diagnostics.
...
llvm-svn: 164154
2012-09-18 18:20:02 +00:00
Andrew Trick
9b63513ac6
misched: Make ScheduleDAGInstrs use the TargetSchedule interface.
...
llvm-svn: 164153
2012-09-18 18:20:00 +00:00
Akira Hatanaka
40cf08dd08
Revert r164051.
...
llvm-svn: 164150
2012-09-18 18:08:25 +00:00
Andrew Trick
402edbbe39
LSR critical edge splitting fix for PR13756.
...
llvm-svn: 164147
2012-09-18 17:51:33 +00:00
Chandler Carruth
d356fd02a9
Fix getCommonType in a different way from the way I fixed it when
...
working on FCA splitting. Instead of refusing to form a common type when
there are uses of a subsection of the alloca as well as a use of the
entire alloca, just skip the subsection uses and continue looking for
a whole-alloca use with a type that we can use.
This produces slightly prettier IR I think, and also fixes the other
failure in the test.
llvm-svn: 164146
2012-09-18 17:49:37 +00:00
Benjamin Kramer
a59ef5795d
Fix build for compilers that don't understand injected class names properly.
...
llvm-svn: 164142
2012-09-18 17:11:47 +00:00
Roman Divacky
0be33598ce
Avoid symbol name clash when filling TOC.
...
Patch by Adhemerval Zanella.
llvm-svn: 164141
2012-09-18 17:10:37 +00:00
Benjamin Kramer
73a9e4a1f9
SROA: Use CRTP for OpSplitter to get rid of virtual dispatch and the virtual-dtor warnings that come with it.
...
llvm-svn: 164140
2012-09-18 17:06:32 +00:00
Roman Divacky
d4f6f421a9
On PPC64 emit the environment pointer. Patch by Adhemerval Zanella.
...
llvm-svn: 164139
2012-09-18 16:55:29 +00:00
Roman Divacky
762930637c
Optimize local func calls to not emit nop for TOC restoration.
...
Patch by Adhemerval Zanella.
llvm-svn: 164138
2012-09-18 16:47:58 +00:00
Roman Divacky
be42c1e0aa
Add PowerPC64 relocation definitions. Patch by Adhemerval Zanella!
...
llvm-svn: 164137
2012-09-18 16:38:02 +00:00
Benjamin Kramer
65f8c88242
SROA: Replace the member function template contraption for recursively splitting aggregates into a real class.
...
No intended functionality change.
llvm-svn: 164135
2012-09-18 16:20:46 +00:00
Roman Divacky
24653d41e9
Add test for r164132.
...
llvm-svn: 164134
2012-09-18 16:19:10 +00:00
Roman Divacky
5dd4ccb402
When creating MCAsmBackend pass the CPU string as well. In X86AsmBackend
...
store this and use it to not emit long nops when the CPU is geode which
doesnt support them.
Fixes PR11212.
llvm-svn: 164132
2012-09-18 16:08:49 +00:00
NAKAMURA Takumi
eb2c8f0fc6
SROA.cpp: Appease msvc.
...
...I don't know why this could appease msvc...baad.
llvm-svn: 164130
2012-09-18 15:29:02 +00:00
NAKAMURA Takumi
78e009d799
llvm/test/DebugInfo: Move two tests, 2010-04-13-PubType.ll and linkage-name.ll to X86.
...
llvm-svn: 164129
2012-09-18 14:57:11 +00:00
Benjamin Kramer
d4d37db071
XFAIL SROA test until Chandler can get to it.
...
llvm-svn: 164128
2012-09-18 14:27:53 +00:00
Dmitri Gribenko
be88f563bf
Coding standards: fix typo: '= deleted' -> '= delete'.
...
llvm-svn: 164126
2012-09-18 14:00:58 +00:00
Tom Stellard
1b5585a350
Make MachinePostDominatorTree::DT private
...
llvm-svn: 164125
2012-09-18 13:49:54 +00:00
Benjamin Kramer
9bc3efc81c
LNT builders have picked up new SROA, disable it to get the remaining builders green again.
...
llvm-svn: 164124
2012-09-18 13:43:00 +00:00
Chandler Carruth
a34f3567e0
Fix a warning in release builds and a test case I forgot to update with
...
a fix to getCommonType in the previous patch.
llvm-svn: 164120
2012-09-18 13:02:06 +00:00
Chandler Carruth
42cb9cb14f
Add a major missing piece to the new SROA pass: aggressive splitting of
...
FCAs. This is essential in order to promote allocas that are used in
struct returns by frontends like Clang. The FCA load would block the
rest of the pass from firing, resulting is significant regressions with
the bullet benchmark in the nightly test suite.
Thanks to Duncan for repeated discussions about how best to do this, and
to both him and Benjamin for review.
This appears to have blocked many places where the pass tries to fire,
and so I'm expect somewhat different results with this fix added.
As with the last big patch, I'm including a change to enable the SROA by
default *temporarily*. Ben is going to remove this as soon as the LNT
bots pick up the patch. I'm just trying to get a round of LNT numbers
from the stable machines in the lab.
NOTE: Four clang tests are expected to fail in the brief window where
this is enabled. Sorry for the noise!
llvm-svn: 164119
2012-09-18 12:57:43 +00:00
Richard Osborne
b68053e266
Fix instcombine to obey requested alignment when merging allocas.
...
llvm-svn: 164117
2012-09-18 09:31:44 +00:00
James Molloy
ea05256b58
More domain conversion; convert VFP VMOVS to NEON instructions in more cases - when we may clobber the other S-lane by converting an S to a D instruction, make an effort to work out if the S lane is clobberable or not.
...
llvm-svn: 164114
2012-09-18 08:31:15 +00:00
Craig Topper
7ecfa6d960
Make custom operand parsing mnemonic indices use the same mnemonic table as the match table. Reorder fields in OperandMatchEntry to provide the least amount of padding for in tree targets.
...
llvm-svn: 164109
2012-09-18 07:02:21 +00:00
Craig Topper
e2cfeb30a1
Use variable type for index into mnemonic table. Shrinks size of index field on in tree targets. Saving static data space.
...
llvm-svn: 164108
2012-09-18 06:10:45 +00:00
Andrew Trick
ba7b921fcb
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
1740e05c31
Add LLVM_DELETED_FUNCTION to coding standards.
...
llvm-svn: 164101
2012-09-18 04:43:40 +00:00
Craig Topper
3215f836b5
Fix a typo. No functional change.
...
llvm-svn: 164100
2012-09-18 04:43:05 +00:00
Andrew Trick
a67b2a702c
Let NULL slip through again.
...
llvm-svn: 164099
2012-09-18 04:18:39 +00:00
Andrew Trick
6e6d597b1c
TargetSchedModel API. Implement latency lookup, disabled.
...
llvm-svn: 164098
2012-09-18 04:03:34 +00:00
Andrew Trick
ea28dbdf93
comment typo
...
llvm-svn: 164097
2012-09-18 04:03:30 +00:00
Andrew Trick
a88f1bddc6
TableGen subtarget emitter. Use getSchedClassIdx.
...
llvm-svn: 164096
2012-09-18 03:55:55 +00:00
Andrew Trick
c6c88151bb
TableGen subtarget emitter. Generate resolveSchedClass generated hook for resolving instruction variants.
...
llvm-svn: 164095
2012-09-18 03:41:43 +00:00
Andrew Trick
1188e439b2
TableGen subtarget emitter. Remove unnecessary header dependence.
...
llvm-svn: 164094
2012-09-18 03:32:57 +00:00
Craig Topper
bac8168fb3
Mark unimplemented operator new as LLVM_DELETED_FUNCTION.
...
llvm-svn: 164093
2012-09-18 03:25:49 +00:00
Andrew Trick
ab722bdd50
TableGen subtarget emitter. Initialize MCSubtargetInfo with the new machine model.
...
llvm-svn: 164092
2012-09-18 03:18:56 +00:00
Craig Topper
d4f8b3cb55
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
b1d83e8c72
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
90ae8f8442
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
9150610db7
Mark asm matcher conversion table as const.
...
llvm-svn: 164088
2012-09-18 01:41:49 +00:00
Evan Cheng
c573599137
Fix some funky indentation.
...
llvm-svn: 164087
2012-09-18 01:34:40 +00:00
Craig Topper
aae8fb801e
Fix typo in comment. No functional change.
...
llvm-svn: 164086
2012-09-18 01:13:36 +00:00