Chad Rosier
e7870c71eb
Fix an issue in SimplifySetCC() specific to vector comparisons.
...
When folding X == X we need to check getBooleanContents() to determine if the
result is a vector of ones or a vector of negative ones.
I tried creating a test case, but the problem seems to only be exposed on a
much older version of clang (around r144500).
rdar://10923049
llvm-svn: 153966
2012-04-03 20:11:24 +00:00
Anton Korobeynikov
64a47d779a
Set soname for FreeBSD as well.
...
Patch by Bernard Cafarelli!
llvm-svn: 153965
2012-04-03 19:48:31 +00:00
Eric Christopher
53ef0cf4a5
Fix thinko check for number of operands to be the one that actually
...
might have more than 19 operands. Add a testcase to make sure I
never screw that up again.
Part of rdar://11026482
llvm-svn: 153961
2012-04-03 17:55:42 +00:00
Lang Hames
4c05101031
Matrix simplification in PBQP may push infinite costs onto register options.
...
The colorability heuristic should count these as denied registers.
No test case - this exposed a bug on an out-of-tree target.
llvm-svn: 153958
2012-04-03 16:27:16 +00:00
Dylan Noblesmith
8ab4926be7
ARMDisassembler: drop bogus dependency on ARMCodeGen
...
And indirectly, a dependency on most of the core LLVM optimization
libraries.
llvm-svn: 153957
2012-04-03 15:48:14 +00:00
Dylan Noblesmith
2431e625b9
Object: drop bogus VMCore dependency
...
llvm-svn: 153956
2012-04-03 15:48:10 +00:00
Bill Wendling
e3c2c36927
The speedup doesn't appear to have been from this, but was an anomaly of my testing machine.
...
llvm-svn: 153951
2012-04-03 11:19:21 +00:00
Bill Wendling
3f12fbd290
Reserve space for the eventual filling of the vector. This gives a small speedup.
...
llvm-svn: 153949
2012-04-03 10:50:09 +00:00
Nadav Rotem
d72bf636aa
Add an additional testcase which checks ops with multiple users.
...
llvm-svn: 153939
2012-04-03 07:39:36 +00:00
Anton Korobeynikov
e70c37c738
Make PPCCompilationCallbackC function to be static, so there will be no need to issue call via
...
PLT when LLVM is built as shared library. This mimics the X86 backend towards the approach.
llvm-svn: 153938
2012-04-03 06:59:28 +00:00
Craig Topper
b4929c0302
Tidy up spacing in some tablegen outputs.
...
llvm-svn: 153937
2012-04-03 06:52:47 +00:00
Craig Topper
ce6c05e0df
Add support for AVX enhanced comparison predicates. Patch from Kay Tiong Khoo.
...
llvm-svn: 153935
2012-04-03 05:20:24 +00:00
Bill Wendling
f6c626e3a9
Reformatting. No functionality change.
...
llvm-svn: 153928
2012-04-03 03:56:52 +00:00
Bill Wendling
7680143edf
As Eric pointed out, even a Debug build should be equal. Leave the flag that can turn off comparisons though.
...
llvm-svn: 153927
2012-04-03 03:27:43 +00:00
Akira Hatanaka
c5bbe0b434
Revert r153924. Delete test/MC/Disassembler/Mips and lib/Target/Mips/Disassembler.
...
llvm-svn: 153926
2012-04-03 03:01:13 +00:00
Akira Hatanaka
cecb440c11
Revert r153924. There were buildbot failures.
...
llvm-svn: 153925
2012-04-03 02:51:09 +00:00
Akira Hatanaka
058b0cfb55
MIPS disassembler support.
...
Patch by Vladimir Medic.
llvm-svn: 153924
2012-04-03 02:20:58 +00:00
Andrew Trick
a1e25f74dd
Cleanup set_union usage. The same thing but a bit cleaner now.
...
llvm-svn: 153922
2012-04-03 01:35:52 +00:00
Andrew Trick
a92546a4bb
Use std::set_union instead of nasty custom code.
...
I just noticed Jakob's examples of the proper application of
std::set... routines.
llvm-svn: 153918
2012-04-03 00:47:23 +00:00
Eric Christopher
ba40985484
Add a line number for the scope of the function (starting at the first
...
brace) so that we get more accurate line number information about the
declaration of a given function and the line where the function
first starts.
Part of rdar://11026482
llvm-svn: 153916
2012-04-03 00:43:49 +00:00
Pete Cooper
fb86d3b6bc
Fixes to r153903. Added missing explanation of behaviour when the VirtRegMap is NULL. Also changed it in this case to just avoid updating the map, but live ranges or intervals will still get updated and created
...
llvm-svn: 153914
2012-04-03 00:28:46 +00:00
Bill Wendling
e3ff2c3ce6
Compare the .o files only for release builds. Add an option to bypass the comparison altogether.
...
llvm-svn: 153909
2012-04-02 23:27:43 +00:00
Pete Cooper
426b167bc5
Moved LiveRangeEdit.h so that it can be called from other parts of the backend, not just libCodeGen
...
llvm-svn: 153906
2012-04-02 22:44:18 +00:00
Rafael Espindola
6363adaa9f
Make dominatedBySlowTreeWalk private and assert cases handled by the caller.
...
llvm-svn: 153905
2012-04-02 22:37:54 +00:00
Jakob Stoklund Olesen
97f47c37b6
Allocate virtual registers in ascending order.
...
This is just the fallback tie-breaker ordering, the main allocation
order is still descending size.
Patch by Shamil Kurmangaleev!
llvm-svn: 153904
2012-04-02 22:30:39 +00:00
Pete Cooper
a76a82ef6f
Refactored the LiveRangeEdit interface so that MachineFunction, TargetInstrInfo, MachineRegisterInfo, LiveIntervals, and VirtRegMap are all passed into the constructor and stored as members instead of passed in to each method.
...
llvm-svn: 153903
2012-04-02 22:22:53 +00:00
Bill Wendling
1db4186413
Add an option to turn off the expensive GVN load PRE part of GVN.
...
llvm-svn: 153902
2012-04-02 22:16:50 +00:00
Owen Anderson
157487e7c5
Add predicates for checking whether targets have free FNEG and FABS operations, and prevent the DAGCombiner from turning them into bitwise operations if they do.
...
llvm-svn: 153901
2012-04-02 22:10:29 +00:00
Lang Hames
dbc3175c89
During two-address lowering, rescheduling an instruction does not untie
...
operands. Make TryInstructionTransform return false to reflect this.
Fixes PR11861.
llvm-svn: 153892
2012-04-02 19:58:43 +00:00
Rafael Espindola
40e34629cb
No need to run llvm-as.
...
llvm-svn: 153890
2012-04-02 19:44:20 +00:00
Akira Hatanaka
f37a1c4323
Initial 64 bit direct object support.
...
This patch allows llvm to recognize that a 64 bit object file is being produced
and that the subsequently generated ELF header has the correct information.
The test case checks for both big and little endian flavors.
Patch by Jack Carter.
llvm-svn: 153889
2012-04-02 19:25:22 +00:00
Hal Finkel
63edfabaaf
The binutils for the IBM BG/P are too old to support CFI.
...
llvm-svn: 153886
2012-04-02 19:09:04 +00:00
Hal Finkel
d6e526ae11
Add triple support for the IBM BG/P and BG/Q supercomputers.
...
llvm-svn: 153882
2012-04-02 18:31:33 +00:00
Eric Christopher
6c4e6016b5
Turn on the accelerator tables for Darwin.
...
llvm-svn: 153880
2012-04-02 17:58:52 +00:00
Stepan Dyatkovskiy
0ddc03ebad
Fast fix for PR12343:
...
http://llvm.org/bugs/show_bug.cgi?id=12343
We have not trivial way for splitting edges that are goes from indirect branch. We can do it with some tricks, but it should be additionally discussed. And it is still dangerous due to difficulty of indirect branches controlling.
Fix forbids this case for unswitching.
llvm-svn: 153879
2012-04-02 17:16:45 +00:00
Roman Divacky
2460282f66
Implement the SVR4 byval alignment for aggregates. Fixing a FIXME.
...
llvm-svn: 153876
2012-04-02 15:49:30 +00:00
Silviu Baranga
af228a1538
Second part for the 153874 one
...
llvm-svn: 153875
2012-04-02 15:46:46 +00:00
Silviu Baranga
77d372b45e
Added fix in TableGen instruction decoder generation. The decoder now breaks for every leaf node.
...
llvm-svn: 153874
2012-04-02 15:20:39 +00:00
Rafael Espindola
1fb406b0fb
Add missing 'd'.
...
llvm-svn: 153872
2012-04-02 13:02:57 +00:00
Bill Wendling
ea61af7ff2
Hack the hack. If we have a situation where an ASM object is defined but isn't
...
reflected in the LLVM IR (as a declare or something), then treat it like a data
object.
N.B. This isn't 100% correct. The ASM parser should supply more information so
that we know what type of object it is, and what attributes it should have.
llvm-svn: 153870
2012-04-02 10:01:21 +00:00
Benjamin Kramer
d960cf6265
Emit the asm writer's mnemonic table with SequenceToOffsetTable.
...
This way we can get AVX v-prefixed instructions tail merged with the normal insns.
llvm-svn: 153869
2012-04-02 09:13:46 +00:00
Benjamin Kramer
2f6189e2a5
Move getOpcodeName from the various target InstPrinters into the superclass MCInstPrinter.
...
All implementations used the same code.
llvm-svn: 153866
2012-04-02 08:32:38 +00:00
Craig Topper
52dc5e74e5
Reorder fields in MatchEntry and OperandMatchEntry to reduce padding. A bit tricky due to the target specific sizes for some of the fields so the ordering is only optimal for the targets in the tree.
...
llvm-svn: 153865
2012-04-02 07:48:39 +00:00
Nadav Rotem
a9ec0e024f
Optimizing swizzles of complex shuffles may generate additional complex shuffles.
...
Do not try to optimize swizzles of shuffles if the source shuffle has more than
a single user, except when the source shuffle is also a swizzle.
llvm-svn: 153864
2012-04-02 07:11:12 +00:00
Craig Topper
fe02cb5e8b
Remove getInstructionName from MCInstPrinter implementations in favor of using the instruction name table from MCInstrInfo. Reduces static data in the InstPrinter implementations.
...
llvm-svn: 153863
2012-04-02 07:01:04 +00:00
Eric Christopher
53e22c484b
Fix CXXFLAGS for huge_val.m4.
...
Patch by Jeremy Huddleston!
llvm-svn: 153862
2012-04-02 06:54:01 +00:00
Craig Topper
dbc259a436
Make MCInstrInfo available to the MCInstPrinter. This will be used to remove getInstructionName and the static data it contains since the same tables are already in MCInstrInfo.
...
llvm-svn: 153860
2012-04-02 06:09:36 +00:00
Bill Wendling
8ee5b8754f
It could come about that we parse the inline ASM before we get a potential
...
definition for it. In that case, we want to wait for the potential definition
before we create a symbol for it.
llvm-svn: 153859
2012-04-02 03:33:31 +00:00
Craig Topper
949f3bef7a
Use SequenceToOffsetTable to generate instruction name table for AsmWriter.
...
llvm-svn: 153857
2012-04-02 00:47:39 +00:00
Chandler Carruth
f2c6dfc460
Start cleaning up the InlineCost class. This switches to sentinel values
...
rather than a bitfield, a great suggestion by Chris during code review.
There is still quite a bit of cruft in the interface, but that requires
sorting out some awkward uses of the cost inside the actual inliner.
No functionality changed intended here.
llvm-svn: 153853
2012-04-01 22:44:09 +00:00