oota-llvm.git
12 years agoRevert r141854 because it was causing failures:
Bill Wendling [Thu, 13 Oct 2011 07:48:07 +0000 (07:48 +0000)]
Revert r141854 because it was causing failures:

http://lab.llvm.org:8011/builders/llvm-x86_64-linux/builds/101

--- Reverse-merging r141854 into '.':
U    test/MC/Disassembler/X86/x86-32.txt
U    test/MC/Disassembler/X86/simple-tests.txt
D    test/CodeGen/X86/bmi.ll
U    lib/Target/X86/X86InstrInfo.td
U    lib/Target/X86/X86ISelLowering.cpp
U    lib/Target/X86/X86.td
U    lib/Target/X86/X86Subtarget.h

git-svn-id: https://llvm.org/svn/llvm-project/llvm/trunk@141857 91177308-0d34-0410-b5e6-96231b3b80d8

12 years agoShould not add instructions to a BB after a return instruction. The machine instructi...
Bill Wendling [Thu, 13 Oct 2011 07:42:32 +0000 (07:42 +0000)]
Should not add instructions to a BB after a return instruction. The machine instruction verifier doesn't like this, nor do I.

git-svn-id: https://llvm.org/svn/llvm-project/llvm/trunk@141856 91177308-0d34-0410-b5e6-96231b3b80d8

12 years agoUse an existing method.
Cameron Zwarich [Thu, 13 Oct 2011 07:36:41 +0000 (07:36 +0000)]
Use an existing method.

git-svn-id: https://llvm.org/svn/llvm-project/llvm/trunk@141855 91177308-0d34-0410-b5e6-96231b3b80d8

12 years agoAdd X86 TZCNT instruction and patterns to select it. Also added core-avx2 processor...
Craig Topper [Thu, 13 Oct 2011 07:09:14 +0000 (07:09 +0000)]
Add X86 TZCNT instruction and patterns to select it. Also added core-avx2 processor which is gcc's name for Haswell.

git-svn-id: https://llvm.org/svn/llvm-project/llvm/trunk@141854 91177308-0d34-0410-b5e6-96231b3b80d8

12 years agoAdd 'implicit EFLAGS' to patterns for popcnt and lzcnt
Craig Topper [Thu, 13 Oct 2011 06:18:52 +0000 (06:18 +0000)]
Add 'implicit EFLAGS' to patterns for popcnt and lzcnt

git-svn-id: https://llvm.org/svn/llvm-project/llvm/trunk@141853 91177308-0d34-0410-b5e6-96231b3b80d8

12 years agoElf_Word is not POD! Stop using it in a DenseMap.
Nick Lewycky [Thu, 13 Oct 2011 03:30:21 +0000 (03:30 +0000)]
Elf_Word is not POD! Stop using it in a DenseMap.

git-svn-id: https://llvm.org/svn/llvm-project/llvm/trunk@141851 91177308-0d34-0410-b5e6-96231b3b80d8

12 years agoIf MI is deleted then remove it from the set. If a new MI is created, it could
Nick Lewycky [Thu, 13 Oct 2011 02:16:18 +0000 (02:16 +0000)]
If MI is deleted then remove it from the set. If a new MI is created, it could
have the same address as the one we deleted, and we don't want that in the set
yet. Noticed by inspection.

git-svn-id: https://llvm.org/svn/llvm-project/llvm/trunk@141849 91177308-0d34-0410-b5e6-96231b3b80d8

12 years agoTabs to spaces.
Nick Lewycky [Thu, 13 Oct 2011 01:09:50 +0000 (01:09 +0000)]
Tabs to spaces.

git-svn-id: https://llvm.org/svn/llvm-project/llvm/trunk@141844 91177308-0d34-0410-b5e6-96231b3b80d8

12 years agoAdd missing braces to pacify GCC's -Wparentheses.
Nick Lewycky [Thu, 13 Oct 2011 00:54:59 +0000 (00:54 +0000)]
Add missing braces to pacify GCC's -Wparentheses.

git-svn-id: https://llvm.org/svn/llvm-project/llvm/trunk@141842 91177308-0d34-0410-b5e6-96231b3b80d8

12 years agoAdd missing ELF constants.
Michael J. Spencer [Thu, 13 Oct 2011 00:16:25 +0000 (00:16 +0000)]
Add missing ELF constants.

git-svn-id: https://llvm.org/svn/llvm-project/llvm/trunk@141840 91177308-0d34-0410-b5e6-96231b3b80d8

12 years agoAlso inflate register classes around inline asm.
Jakob Stoklund Olesen [Wed, 12 Oct 2011 23:37:40 +0000 (23:37 +0000)]
Also inflate register classes around inline asm.

Now that MI->getRegClassConstraint() can also handle inline assembly,
don't bail when recomputing the register class of a virtual register
used by inline asm.

This fixes PR11078.

git-svn-id: https://llvm.org/svn/llvm-project/llvm/trunk@141836 91177308-0d34-0410-b5e6-96231b3b80d8

12 years agoAdd MachineInstr::getRegClassConstraint().
Jakob Stoklund Olesen [Wed, 12 Oct 2011 23:37:36 +0000 (23:37 +0000)]
Add MachineInstr::getRegClassConstraint().

Most instructions have some requirements for their register operands.
Usually, this is expressed as register class constraints in the
MCInstrDesc, but for inline assembly the constraints are encoded in the
flag words.

git-svn-id: https://llvm.org/svn/llvm-project/llvm/trunk@141835 91177308-0d34-0410-b5e6-96231b3b80d8

12 years agoExtract a method for finding the inline asm flag operand.
Jakob Stoklund Olesen [Wed, 12 Oct 2011 23:37:33 +0000 (23:37 +0000)]
Extract a method for finding the inline asm flag operand.

git-svn-id: https://llvm.org/svn/llvm-project/llvm/trunk@141834 91177308-0d34-0410-b5e6-96231b3b80d8

12 years agoEncode register class constreaints in inline asm instructions.
Jakob Stoklund Olesen [Wed, 12 Oct 2011 23:37:29 +0000 (23:37 +0000)]
Encode register class constreaints in inline asm instructions.

The inline asm operand constraint is initially encoded in the virtual
register for the operand, but that register class may change during
coalescing, and the original constraint is lost.

Encode the original register class as part of the flag word for each
inline asm operand.  This makes it possible to recover the actual
constraint required by inline asm, just like we can for normal
instructions.

git-svn-id: https://llvm.org/svn/llvm-project/llvm/trunk@141833 91177308-0d34-0410-b5e6-96231b3b80d8

12 years agoAttempt to fix MSVC build.
Eli Friedman [Wed, 12 Oct 2011 23:14:41 +0000 (23:14 +0000)]
Attempt to fix MSVC build.

git-svn-id: https://llvm.org/svn/llvm-project/llvm/trunk@141831 91177308-0d34-0410-b5e6-96231b3b80d8

12 years agoWe need to verify that the machine instruction we're using as a replacement for
Bill Wendling [Wed, 12 Oct 2011 23:03:40 +0000 (23:03 +0000)]
We need to verify that the machine instruction we're using as a replacement for
our current machine instruction defines a register with the same register class
as what's being replaced. This showed up in the SPEC 403.gcc benchmark, where it
would ICE because a tail call was expecting one register class but was given
another. (The machine instruction verifier catches this situation.)
<rdar://problem/10270968>

git-svn-id: https://llvm.org/svn/llvm-project/llvm/trunk@141830 91177308-0d34-0410-b5e6-96231b3b80d8

12 years agoUse a utility from MathExtras to clarify a check and avoid undefined behavior. Based...
Eli Friedman [Wed, 12 Oct 2011 22:46:45 +0000 (22:46 +0000)]
Use a utility from MathExtras to clarify a check and avoid undefined behavior.  Based on patch by Ahmed Charles.

git-svn-id: https://llvm.org/svn/llvm-project/llvm/trunk@141829 91177308-0d34-0410-b5e6-96231b3b80d8

12 years agoThe VMAs stored in the symbol table of a MachO file are absolute addresses, not offse...
Owen Anderson [Wed, 12 Oct 2011 22:37:10 +0000 (22:37 +0000)]
The VMAs stored in the symbol table of a MachO file are absolute addresses, not offsets from the section.

git-svn-id: https://llvm.org/svn/llvm-project/llvm/trunk@141828 91177308-0d34-0410-b5e6-96231b3b80d8

12 years agoUse unsigned multiply to hash integers, so we don't end up with undefined behavior...
Eli Friedman [Wed, 12 Oct 2011 22:25:45 +0000 (22:25 +0000)]
Use unsigned multiply to hash integers, so we don't end up with undefined behavior for large signed integers.  Based on patch by Ahmed Charles.

git-svn-id: https://llvm.org/svn/llvm-project/llvm/trunk@141827 91177308-0d34-0410-b5e6-96231b3b80d8

12 years agoRemoved colons from some target datalayout strings in test, since they don't match...
Lang Hames [Wed, 12 Oct 2011 22:24:17 +0000 (22:24 +0000)]
Removed colons from some target datalayout strings in test, since they don't match the required format.

git-svn-id: https://llvm.org/svn/llvm-project/llvm/trunk@141825 91177308-0d34-0410-b5e6-96231b3b80d8

12 years agoDon't label a STAB debugging symbol as a function symbol.
Owen Anderson [Wed, 12 Oct 2011 22:23:12 +0000 (22:23 +0000)]
Don't label a STAB debugging symbol as a function symbol.

git-svn-id: https://llvm.org/svn/llvm-project/llvm/trunk@141824 91177308-0d34-0410-b5e6-96231b3b80d8

12 years agosectionContainsSymbol needs to be based on VMA's rather than section indices to prope...
Owen Anderson [Wed, 12 Oct 2011 22:21:32 +0000 (22:21 +0000)]
sectionContainsSymbol needs to be based on VMA's rather than section indices to properly account for files with segment load commands that contain no sections.

git-svn-id: https://llvm.org/svn/llvm-project/llvm/trunk@141822 91177308-0d34-0410-b5e6-96231b3b80d8

12 years agoFix a couple hash functions so that they do not depend on undefined shifts. Based...
Eli Friedman [Wed, 12 Oct 2011 22:00:26 +0000 (22:00 +0000)]
Fix a couple hash functions so that they do not depend on undefined shifts.  Based on patch by Ahmed Charles.

git-svn-id: https://llvm.org/svn/llvm-project/llvm/trunk@141820 91177308-0d34-0410-b5e6-96231b3b80d8

12 years agoARM addrmode5 represents the 'U' bit of the encoding backwards.
Jim Grosbach [Wed, 12 Oct 2011 21:59:02 +0000 (21:59 +0000)]
ARM addrmode5 represents the 'U' bit of the encoding backwards.

The disassembler needs to use the AM5 factory methods instead of just
building up the immediate directly.

git-svn-id: https://llvm.org/svn/llvm-project/llvm/trunk@141819 91177308-0d34-0410-b5e6-96231b3b80d8

12 years agoFix APFloat::getSmallestNormalized so the shift doesn't depend on undefined behavior...
Eli Friedman [Wed, 12 Oct 2011 21:56:19 +0000 (21:56 +0000)]
Fix APFloat::getSmallestNormalized so the shift doesn't depend on undefined behavior.  Patch from Ahmed Charles.

git-svn-id: https://llvm.org/svn/llvm-project/llvm/trunk@141818 91177308-0d34-0410-b5e6-96231b3b80d8

12 years agoFix APFloat::getLargest so that it actually returns the correct value. Found by...
Eli Friedman [Wed, 12 Oct 2011 21:51:36 +0000 (21:51 +0000)]
Fix APFloat::getLargest so that it actually returns the correct value.  Found by accident while reviewing a patch to nearby code.

git-svn-id: https://llvm.org/svn/llvm-project/llvm/trunk@141816 91177308-0d34-0410-b5e6-96231b3b80d8

12 years agoSection indices in MachO symbol tables begin at 1, not 0.
Owen Anderson [Wed, 12 Oct 2011 21:43:24 +0000 (21:43 +0000)]
Section indices in MachO symbol tables begin at 1, not 0.

git-svn-id: https://llvm.org/svn/llvm-project/llvm/trunk@141815 91177308-0d34-0410-b5e6-96231b3b80d8

12 years agoFinish supporting cpp #file/line comments in assembler for error messages. So
Kevin Enderby [Wed, 12 Oct 2011 21:38:39 +0000 (21:38 +0000)]
Finish supporting cpp #file/line comments in assembler for error messages. So
for cpp pre-processed assembly we give correct filename and line numbers when
reporting errors in assembly files when using clang and -integrated-as on .s
files. rdar://8998895

git-svn-id: https://llvm.org/svn/llvm-project/llvm/trunk@141814 91177308-0d34-0410-b5e6-96231b3b80d8

12 years agoDisable machine LICM speculation check (for profitability) until I have time to inves...
Evan Cheng [Wed, 12 Oct 2011 21:33:49 +0000 (21:33 +0000)]
Disable machine LICM speculation check (for profitability) until I have time to investigate the regressions.

git-svn-id: https://llvm.org/svn/llvm-project/llvm/trunk@141813 91177308-0d34-0410-b5e6-96231b3b80d8

12 years agoTo find the exiting VN of a LiveInterval from a block, use the previous slot
Cameron Zwarich [Wed, 12 Oct 2011 21:24:54 +0000 (21:24 +0000)]
To find the exiting VN of a LiveInterval from a block, use the previous slot
rather than the previous index. If a block has a single instruction, the
previous index may be in a different basic block.

I have no clue how this used to work on all of test-suite, because now this
failure is seen quite often when trying to compile code with -strong-phi-elim.
This fixes PR10252.

git-svn-id: https://llvm.org/svn/llvm-project/llvm/trunk@141812 91177308-0d34-0410-b5e6-96231b3b80d8

12 years agoThumb2 assembly parsing and encoding for LDC/STC.
Jim Grosbach [Wed, 12 Oct 2011 20:54:17 +0000 (20:54 +0000)]
Thumb2 assembly parsing and encoding for LDC/STC.

git-svn-id: https://llvm.org/svn/llvm-project/llvm/trunk@141811 91177308-0d34-0410-b5e6-96231b3b80d8

12 years agoHoist vector.size() computation out of the loop. No functionality change.
Nick Lewycky [Wed, 12 Oct 2011 20:20:48 +0000 (20:20 +0000)]
Hoist vector.size() computation out of the loop. No functionality change.

git-svn-id: https://llvm.org/svn/llvm-project/llvm/trunk@141807 91177308-0d34-0410-b5e6-96231b3b80d8

12 years agoaddrmode2 is gone from these, so no need for the reg0 operand.
Jim Grosbach [Wed, 12 Oct 2011 18:11:24 +0000 (18:11 +0000)]
addrmode2 is gone from these, so no need for the reg0 operand.

git-svn-id: https://llvm.org/svn/llvm-project/llvm/trunk@141794 91177308-0d34-0410-b5e6-96231b3b80d8

12 years agoARM encoding tests for STC.
Jim Grosbach [Wed, 12 Oct 2011 17:36:13 +0000 (17:36 +0000)]
ARM encoding tests for STC.

git-svn-id: https://llvm.org/svn/llvm-project/llvm/trunk@141787 91177308-0d34-0410-b5e6-96231b3b80d8

12 years agoARM parsing and encoding for the <option> form of LDC/STC instructions.
Jim Grosbach [Wed, 12 Oct 2011 17:34:41 +0000 (17:34 +0000)]
ARM parsing and encoding for the <option> form of LDC/STC instructions.

git-svn-id: https://llvm.org/svn/llvm-project/llvm/trunk@141786 91177308-0d34-0410-b5e6-96231b3b80d8

12 years ago80 columns.
Jim Grosbach [Wed, 12 Oct 2011 16:36:01 +0000 (16:36 +0000)]
80 columns.

git-svn-id: https://llvm.org/svn/llvm-project/llvm/trunk@141781 91177308-0d34-0410-b5e6-96231b3b80d8

12 years agoTidy up. Formatting.
Jim Grosbach [Wed, 12 Oct 2011 16:34:37 +0000 (16:34 +0000)]
Tidy up. Formatting.

git-svn-id: https://llvm.org/svn/llvm-project/llvm/trunk@141780 91177308-0d34-0410-b5e6-96231b3b80d8

12 years agoFix a thinko that Nick noticed. The previous code actually worked as
Dan Gohman [Wed, 12 Oct 2011 15:56:56 +0000 (15:56 +0000)]
Fix a thinko that Nick noticed. The previous code actually worked as
intended, but only by accident.

git-svn-id: https://llvm.org/svn/llvm-project/llvm/trunk@141779 91177308-0d34-0410-b5e6-96231b3b80d8

12 years agolib/Object/ELFObjectFile.cpp: Fix undefined behavior for MC/ELF/many-section.s not...
NAKAMURA Takumi [Wed, 12 Oct 2011 10:28:55 +0000 (10:28 +0000)]
lib/Object/ELFObjectFile.cpp: Fix undefined behavior for MC/ELF/many-section.s not to fail (on msvc).

DenseMap::lookup(k) would return "default constructor value" when k was not met. It would be useless when value type were POD.

git-svn-id: https://llvm.org/svn/llvm-project/llvm/trunk@141774 91177308-0d34-0410-b5e6-96231b3b80d8

12 years agoExpand the check for a landing pad so that it looks at the basic block's
Bill Wendling [Wed, 12 Oct 2011 02:58:01 +0000 (02:58 +0000)]
Expand the check for a landing pad so that it looks at the basic block's
containing loop's header to see if that's a landing pad. If it is, then we don't
want to hoist instructions out of the loop and above the header.

git-svn-id: https://llvm.org/svn/llvm-project/llvm/trunk@141767 91177308-0d34-0410-b5e6-96231b3b80d8

12 years agoUse an existing function.
Jakob Stoklund Olesen [Wed, 12 Oct 2011 01:24:51 +0000 (01:24 +0000)]
Use an existing function.

git-svn-id: https://llvm.org/svn/llvm-project/llvm/trunk@141763 91177308-0d34-0410-b5e6-96231b3b80d8

12 years agoDefine base class LogicNOR and make 32-bit and 64-bit NOR derive from it.
Akira Hatanaka [Wed, 12 Oct 2011 01:05:13 +0000 (01:05 +0000)]
Define base class LogicNOR and make 32-bit and 64-bit NOR derive from it.

git-svn-id: https://llvm.org/svn/llvm-project/llvm/trunk@141761 91177308-0d34-0410-b5e6-96231b3b80d8

12 years agoFix encoding of 32-bit integer instructions. Change names of operands and nodes.
Akira Hatanaka [Wed, 12 Oct 2011 00:56:06 +0000 (00:56 +0000)]
Fix encoding of 32-bit integer instructions. Change names of operands and nodes.
Remove unused classes.

git-svn-id: https://llvm.org/svn/llvm-project/llvm/trunk@141757 91177308-0d34-0410-b5e6-96231b3b80d8

12 years agoMake this use a public accessor too.
Eric Christopher [Wed, 12 Oct 2011 00:38:05 +0000 (00:38 +0000)]
Make this use a public accessor too.

git-svn-id: https://llvm.org/svn/llvm-project/llvm/trunk@141752 91177308-0d34-0410-b5e6-96231b3b80d8

12 years agoAdd missing space.
Nick Lewycky [Wed, 12 Oct 2011 00:14:31 +0000 (00:14 +0000)]
Add missing space.

git-svn-id: https://llvm.org/svn/llvm-project/llvm/trunk@141750 91177308-0d34-0410-b5e6-96231b3b80d8

12 years agoFix indent in comment.
Nick Lewycky [Wed, 12 Oct 2011 00:14:12 +0000 (00:14 +0000)]
Fix indent in comment.

git-svn-id: https://llvm.org/svn/llvm-project/llvm/trunk@141749 91177308-0d34-0410-b5e6-96231b3b80d8

12 years agoFix r141744.
Evan Cheng [Wed, 12 Oct 2011 00:09:14 +0000 (00:09 +0000)]
Fix r141744.
1. The speculation check may not have been performed if the BB hasn't had a load
   LICM candidate.
2. If the candidate would be CSE'ed, then go ahead and speculatively LICM the
   instruction even if it's in high register pressure situation.

git-svn-id: https://llvm.org/svn/llvm-project/llvm/trunk@141747 91177308-0d34-0410-b5e6-96231b3b80d8

12 years agoFix -widen-vmovs liveness issues.
Jakob Stoklund Olesen [Wed, 12 Oct 2011 00:06:23 +0000 (00:06 +0000)]
Fix -widen-vmovs liveness issues.

When widening a copy, we are reading a larger register that may not be
live.  Use an <undef> flag to tell the register scavenger and machine
code verifier that we know the value isn't defined.

We now widen:

  %S6<def> = COPY %S4<kill>, %D3<imp-def>

into:

  %D3<def> = VMOVD %D2<undef>, pred:14, pred:%noreg, %S4<imp-use,kill>

This also keeps the <kill> flag on %S4 so we don't inadvertently kill a
live value in %S5.

Finally, ensure that ARMBaseInstrInfo::setExecutionDomain() preserves
the <undef> flag when converting VMOVD to VORR.

git-svn-id: https://llvm.org/svn/llvm-project/llvm/trunk@141746 91177308-0d34-0410-b5e6-96231b3b80d8

12 years agoRefine r141689 with a tri-state variable.
Evan Cheng [Tue, 11 Oct 2011 23:48:44 +0000 (23:48 +0000)]
Refine r141689 with a tri-state variable.
Also teach MachineLICM to avoid "speculation" when register pressure is high.

git-svn-id: https://llvm.org/svn/llvm-project/llvm/trunk@141744 91177308-0d34-0410-b5e6-96231b3b80d8

12 years agoChange name of class to ArithOverflowR.
Akira Hatanaka [Tue, 11 Oct 2011 23:43:48 +0000 (23:43 +0000)]
Change name of class to ArithOverflowR.

git-svn-id: https://llvm.org/svn/llvm-project/llvm/trunk@141743 91177308-0d34-0410-b5e6-96231b3b80d8

12 years agoDefine class ArithLogicI. Make 32-bit and 64-bit arithmetic and logical
Akira Hatanaka [Tue, 11 Oct 2011 23:38:52 +0000 (23:38 +0000)]
Define class ArithLogicI. Make 32-bit and 64-bit arithmetic and logical
instructions with two register operands derive from it.

git-svn-id: https://llvm.org/svn/llvm-project/llvm/trunk@141742 91177308-0d34-0410-b5e6-96231b3b80d8

12 years agoMake this test more specific. There are 3 stats that matched "machine-licm".
Bob Wilson [Tue, 11 Oct 2011 23:34:31 +0000 (23:34 +0000)]
Make this test more specific.  There are 3 stats that matched "machine-licm".

git-svn-id: https://llvm.org/svn/llvm-project/llvm/trunk@141741 91177308-0d34-0410-b5e6-96231b3b80d8

12 years agoUse public accessors on the scope that is returned.
Eric Christopher [Tue, 11 Oct 2011 23:19:35 +0000 (23:19 +0000)]
Use public accessors on the scope that is returned.

git-svn-id: https://llvm.org/svn/llvm-project/llvm/trunk@141739 91177308-0d34-0410-b5e6-96231b3b80d8

12 years agoFix comment.
Akira Hatanaka [Tue, 11 Oct 2011 23:12:12 +0000 (23:12 +0000)]
Fix comment.

git-svn-id: https://llvm.org/svn/llvm-project/llvm/trunk@141737 91177308-0d34-0410-b5e6-96231b3b80d8

12 years agoDefine classes ArithLogicR and ArithLogicOfR and make 32-bit and 64-bit
Akira Hatanaka [Tue, 11 Oct 2011 23:05:46 +0000 (23:05 +0000)]
Define classes ArithLogicR and ArithLogicOfR and make 32-bit and 64-bit
arithmetic and logical instructions with three register operands derive from
them. Fix instruction encoding too.

git-svn-id: https://llvm.org/svn/llvm-project/llvm/trunk@141736 91177308-0d34-0410-b5e6-96231b3b80d8

12 years agotarget data is a contract with the code generator, not the "processor"
Chris Lattner [Tue, 11 Oct 2011 23:02:17 +0000 (23:02 +0000)]
target data is a contract with the code generator, not the "processor"

git-svn-id: https://llvm.org/svn/llvm-project/llvm/trunk@141734 91177308-0d34-0410-b5e6-96231b3b80d8

12 years agoimprove some of the documentation around target data layout strings.
Chris Lattner [Tue, 11 Oct 2011 23:01:39 +0000 (23:01 +0000)]
improve some of the documentation around target data layout strings.

git-svn-id: https://llvm.org/svn/llvm-project/llvm/trunk@141733 91177308-0d34-0410-b5e6-96231b3b80d8

12 years agoAdd a new wrapper node for a DILexicalBlock that encapsulates it and a
Eric Christopher [Tue, 11 Oct 2011 22:59:11 +0000 (22:59 +0000)]
Add a new wrapper node for a DILexicalBlock that encapsulates it and a
file. Since it should only be used when necessary propagate it through
the backend code generation and tweak testcases accordingly.

This helps with code like in clang's test/CodeGen/debug-info-line.c where
we have multiple #line directives within a single lexical block and want
to generate only a single block that contains each file change.

Part of rdar://10246360

git-svn-id: https://llvm.org/svn/llvm-project/llvm/trunk@141729 91177308-0d34-0410-b5e6-96231b3b80d8

12 years agoFormatting.
Eric Christopher [Tue, 11 Oct 2011 22:59:04 +0000 (22:59 +0000)]
Formatting.

git-svn-id: https://llvm.org/svn/llvm-project/llvm/trunk@141728 91177308-0d34-0410-b5e6-96231b3b80d8

12 years agoSpacing.
Eric Christopher [Tue, 11 Oct 2011 22:58:58 +0000 (22:58 +0000)]
Spacing.

git-svn-id: https://llvm.org/svn/llvm-project/llvm/trunk@141727 91177308-0d34-0410-b5e6-96231b3b80d8

12 years agoN.B. This is with the new EH scheme:
Bill Wendling [Tue, 11 Oct 2011 22:42:31 +0000 (22:42 +0000)]
N.B. This is with the new EH scheme:

The blocks with invokes have branches to the dispatch block, because that more
correctly models the behavior of the CFG. The dispatch of course has edges to
the landing pads. Those landing pads could contain invokes, which then have
branches back to the dispatch. This creates a loop. The machine LICM pass looks
at this loop and thinks it can hoist elements out of it. But because the
dispatch is an alternate entry point into the program, the hoisted instructions
won't be executed.

I wasn't able to get a testcase which was small and could reproduce all of the
time. The function_try_block.cpp in llvm-test was where this showed up.

git-svn-id: https://llvm.org/svn/llvm-project/llvm/trunk@141726 91177308-0d34-0410-b5e6-96231b3b80d8

12 years agoFix function isUnalignedLoadStore.
Akira Hatanaka [Tue, 11 Oct 2011 22:04:01 +0000 (22:04 +0000)]
Fix function isUnalignedLoadStore.

git-svn-id: https://llvm.org/svn/llvm-project/llvm/trunk@141722 91177308-0d34-0410-b5e6-96231b3b80d8

12 years agoARM assembly parsing and encoding for LDC{2}{L}/STC{2}{L} instructions.
Jim Grosbach [Tue, 11 Oct 2011 21:55:36 +0000 (21:55 +0000)]
ARM assembly parsing and encoding for LDC{2}{L}/STC{2}{L} instructions.

Fill out the rest of the encoding information, update to properly mark
the LDC/STC instructions as predicable while the LDC2/STC2 instructions are
not, and adjust the parser accordingly.

git-svn-id: https://llvm.org/svn/llvm-project/llvm/trunk@141721 91177308-0d34-0410-b5e6-96231b3b80d8

12 years agoRemove unused PatLeaf.
Akira Hatanaka [Tue, 11 Oct 2011 21:53:08 +0000 (21:53 +0000)]
Remove unused PatLeaf.

git-svn-id: https://llvm.org/svn/llvm-project/llvm/trunk@141720 91177308-0d34-0410-b5e6-96231b3b80d8

12 years agoChange the names of 64-bit logical instructions so that they match the names of
Akira Hatanaka [Tue, 11 Oct 2011 21:48:01 +0000 (21:48 +0000)]
Change the names of 64-bit logical instructions so that they match the names of
the real instructions.

git-svn-id: https://llvm.org/svn/llvm-project/llvm/trunk@141718 91177308-0d34-0410-b5e6-96231b3b80d8

12 years agoRevert r141529. This is causing failures in the test-suite, like bigstack and ReedSol...
Bill Wendling [Tue, 11 Oct 2011 21:40:47 +0000 (21:40 +0000)]
Revert r141529. This is causing failures in the test-suite, like bigstack and ReedSolomon. Boo...

git-svn-id: https://llvm.org/svn/llvm-project/llvm/trunk@141716 91177308-0d34-0410-b5e6-96231b3b80d8

12 years agoRemove redundancy in setcc patterns using multiclass.
Akira Hatanaka [Tue, 11 Oct 2011 21:40:01 +0000 (21:40 +0000)]
Remove redundancy in setcc patterns using multiclass.

git-svn-id: https://llvm.org/svn/llvm-project/llvm/trunk@141715 91177308-0d34-0410-b5e6-96231b3b80d8

12 years agoFix PR11106 by correcting a typo that has been in the code for over a year. This
Cameron Zwarich [Tue, 11 Oct 2011 21:26:40 +0000 (21:26 +0000)]
Fix PR11106 by correcting a typo that has been in the code for over a year. This
would have never worked, since the element type of a vector type is never a
vector type. Also fix the conditional to be more direct in checking whether
EltTy is a vector type.

git-svn-id: https://llvm.org/svn/llvm-project/llvm/trunk@141713 91177308-0d34-0410-b5e6-96231b3b80d8

12 years agoUse sltiu instead of sltu when a register operand and immediate are compared.
Akira Hatanaka [Tue, 11 Oct 2011 20:44:43 +0000 (20:44 +0000)]
Use sltiu instead of sltu when a register operand and immediate are compared.

git-svn-id: https://llvm.org/svn/llvm-project/llvm/trunk@141708 91177308-0d34-0410-b5e6-96231b3b80d8

12 years agoUpdate test for r141704.
Jim Grosbach [Tue, 11 Oct 2011 20:18:50 +0000 (20:18 +0000)]
Update test for r141704.

git-svn-id: https://llvm.org/svn/llvm-project/llvm/trunk@141705 91177308-0d34-0410-b5e6-96231b3b80d8

12 years agoARM addressing mode cleanup for LDC/STC.
Jim Grosbach [Tue, 11 Oct 2011 20:17:35 +0000 (20:17 +0000)]
ARM addressing mode cleanup for LDC/STC.

We parse at least some forms of the instructions now. Encoding is
pretty screwed up, still, though.

git-svn-id: https://llvm.org/svn/llvm-project/llvm/trunk@141704 91177308-0d34-0410-b5e6-96231b3b80d8

12 years agoClean up a few references to System/. We still have docs/SystemLibrary.html
Daniel Dunbar [Tue, 11 Oct 2011 20:02:52 +0000 (20:02 +0000)]
Clean up a few references to System/. We still have docs/SystemLibrary.html
lying around...

git-svn-id: https://llvm.org/svn/llvm-project/llvm/trunk@141703 91177308-0d34-0410-b5e6-96231b3b80d8

12 years agoSupport/DataTypes.h: Clean up some types and add matching (but presumably
Daniel Dunbar [Tue, 11 Oct 2011 20:02:49 +0000 (20:02 +0000)]
Support/DataTypes.h: Clean up some types and add matching (but presumably
unused) code from .cmake to DataTypes.h.in so that the files are essentially in
sync module differences in autoconf/cmake replacement syntax.

git-svn-id: https://llvm.org/svn/llvm-project/llvm/trunk@141702 91177308-0d34-0410-b5e6-96231b3b80d8

12 years agoRemove extra semicolon.
Eli Friedman [Tue, 11 Oct 2011 19:53:40 +0000 (19:53 +0000)]
Remove extra semicolon.

git-svn-id: https://llvm.org/svn/llvm-project/llvm/trunk@141699 91177308-0d34-0410-b5e6-96231b3b80d8

12 years agoAdd patterns for conditional branches with 64-bit register operands.
Akira Hatanaka [Tue, 11 Oct 2011 19:09:09 +0000 (19:09 +0000)]
Add patterns for conditional branches with 64-bit register operands.

git-svn-id: https://llvm.org/svn/llvm-project/llvm/trunk@141696 91177308-0d34-0410-b5e6-96231b3b80d8

12 years agoAdd support for 64-bit set-on-less-than instructions.
Akira Hatanaka [Tue, 11 Oct 2011 18:53:46 +0000 (18:53 +0000)]
Add support for 64-bit set-on-less-than instructions.

git-svn-id: https://llvm.org/svn/llvm-project/llvm/trunk@141695 91177308-0d34-0410-b5e6-96231b3b80d8

12 years agoAdd support for conditional branch instructions with 64-bit register operands.
Akira Hatanaka [Tue, 11 Oct 2011 18:49:17 +0000 (18:49 +0000)]
Add support for conditional branch instructions with 64-bit register operands.

git-svn-id: https://llvm.org/svn/llvm-project/llvm/trunk@141694 91177308-0d34-0410-b5e6-96231b3b80d8

12 years agoAdd dominance check for the instruction being hoisted.
Devang Patel [Tue, 11 Oct 2011 18:09:58 +0000 (18:09 +0000)]
Add dominance check for the instruction being hoisted.

For example, MachineLICM should not hoist a load that is not guaranteed to be executed.
Radar 10254254.

git-svn-id: https://llvm.org/svn/llvm-project/llvm/trunk@141689 91177308-0d34-0410-b5e6-96231b3b80d8

12 years agoFixed docs to reflect the proper default value and behaviour of the natural stack...
Lang Hames [Tue, 11 Oct 2011 17:50:14 +0000 (17:50 +0000)]
Fixed docs to reflect the proper default value and behaviour of the natural stack alignment.

git-svn-id: https://llvm.org/svn/llvm-project/llvm/trunk@141687 91177308-0d34-0410-b5e6-96231b3b80d8

12 years agoExpose MachOObjectFile externally, like we do for COFF. First step in reducing the...
Owen Anderson [Tue, 11 Oct 2011 17:32:27 +0000 (17:32 +0000)]
Expose MachOObjectFile externally, like we do for COFF.  First step in reducing the amount of special-purpose code needed for llvm-objdump.

git-svn-id: https://llvm.org/svn/llvm-project/llvm/trunk@141684 91177308-0d34-0410-b5e6-96231b3b80d8

12 years agoARM parse alignment specifier for NEON load/store instructions.
Jim Grosbach [Tue, 11 Oct 2011 17:29:55 +0000 (17:29 +0000)]
ARM parse alignment specifier for NEON load/store instructions.

git-svn-id: https://llvm.org/svn/llvm-project/llvm/trunk@141682 91177308-0d34-0410-b5e6-96231b3b80d8

12 years agoMention the cmake build guide on the main docs page.
Duncan Sands [Tue, 11 Oct 2011 16:35:07 +0000 (16:35 +0000)]
Mention the cmake build guide on the main docs page.

git-svn-id: https://llvm.org/svn/llvm-project/llvm/trunk@141674 91177308-0d34-0410-b5e6-96231b3b80d8

12 years agoARM Rename operand sub-structure 'Mem' to 'Memory' for a bit more clarity.
Jim Grosbach [Tue, 11 Oct 2011 15:59:20 +0000 (15:59 +0000)]
ARM Rename operand sub-structure 'Mem' to 'Memory' for a bit more clarity.

git-svn-id: https://llvm.org/svn/llvm-project/llvm/trunk@141671 91177308-0d34-0410-b5e6-96231b3b80d8

12 years agoAdd support for legalization of vector SHL/SRA/SRL instructions
Nadav Rotem [Tue, 11 Oct 2011 14:36:35 +0000 (14:36 +0000)]
Add support for legalization of vector SHL/SRA/SRL instructions

git-svn-id: https://llvm.org/svn/llvm-project/llvm/trunk@141667 91177308-0d34-0410-b5e6-96231b3b80d8

12 years agoImplement the emitFrameIndexDebugValue and getDebugValueLocation hooks.
Richard Osborne [Tue, 11 Oct 2011 12:55:35 +0000 (12:55 +0000)]
Implement the emitFrameIndexDebugValue and getDebugValueLocation hooks.

This fixes an assert due to the operands of the DBG_VALUE instruction not
being as expected (PR11105).

git-svn-id: https://llvm.org/svn/llvm-project/llvm/trunk@141666 91177308-0d34-0410-b5e6-96231b3b80d8

12 years agoFix a iterator out of bounds error, that triggers rarely.
Kalle Raiskila [Tue, 11 Oct 2011 12:55:18 +0000 (12:55 +0000)]
Fix a iterator out of bounds error, that triggers rarely.

git-svn-id: https://llvm.org/svn/llvm-project/llvm/trunk@141665 91177308-0d34-0410-b5e6-96231b3b80d8

12 years agollvm-objdump.cpp: Use PRIx64 as format specifier for int64_t.
NAKAMURA Takumi [Tue, 11 Oct 2011 12:51:50 +0000 (12:51 +0000)]
llvm-objdump.cpp: Use PRIx64 as format specifier for int64_t.

git-svn-id: https://llvm.org/svn/llvm-project/llvm/trunk@141664 91177308-0d34-0410-b5e6-96231b3b80d8

12 years agoAdd -D__STDC_FORMAT_MACROS to use PRIx64.
NAKAMURA Takumi [Tue, 11 Oct 2011 12:51:44 +0000 (12:51 +0000)]
Add -D__STDC_FORMAT_MACROS to use PRIx64.

git-svn-id: https://llvm.org/svn/llvm-project/llvm/trunk@141663 91177308-0d34-0410-b5e6-96231b3b80d8

12 years agocmake/modules/HandleLLVMOptions.cmake: Reorder __STDC_CONSTANT_MACROS and __STDC_LIMI...
NAKAMURA Takumi [Tue, 11 Oct 2011 12:51:36 +0000 (12:51 +0000)]
cmake/modules/HandleLLVMOptions.cmake: Reorder __STDC_CONSTANT_MACROS and __STDC_LIMIT_MACROS.

git-svn-id: https://llvm.org/svn/llvm-project/llvm/trunk@141662 91177308-0d34-0410-b5e6-96231b3b80d8

12 years agoAdd support for legalization of vector trunc-store where the saved scalar type is...
Nadav Rotem [Tue, 11 Oct 2011 11:25:16 +0000 (11:25 +0000)]
Add support for legalization of vector trunc-store where the saved scalar type is illegal (for example, v2i16 on systems where the smallest store size is i32)

git-svn-id: https://llvm.org/svn/llvm-project/llvm/trunk@141661 91177308-0d34-0410-b5e6-96231b3b80d8

12 years agoCleanup the trunc-store legalization code and add asserts.
Nadav Rotem [Tue, 11 Oct 2011 10:04:25 +0000 (10:04 +0000)]
Cleanup the trunc-store legalization code and add asserts.

git-svn-id: https://llvm.org/svn/llvm-project/llvm/trunk@141659 91177308-0d34-0410-b5e6-96231b3b80d8

12 years agoUpdate to a newer doxygen version. PR8214. Patch by Jeremy Huddleston.
Bill Wendling [Tue, 11 Oct 2011 07:25:38 +0000 (07:25 +0000)]
Update to a newer doxygen version. PR8214. Patch by Jeremy Huddleston.

git-svn-id: https://llvm.org/svn/llvm-project/llvm/trunk@141657 91177308-0d34-0410-b5e6-96231b3b80d8

12 years agoAdd HasPOPCNT predicate to the POPCNT instructions. Also mark POPCNT as modifying...
Craig Topper [Tue, 11 Oct 2011 07:13:09 +0000 (07:13 +0000)]
Add HasPOPCNT predicate to the POPCNT instructions. Also mark POPCNT as modifying EFLAGS.

git-svn-id: https://llvm.org/svn/llvm-project/llvm/trunk@141656 91177308-0d34-0410-b5e6-96231b3b80d8

12 years agoMinor modifications to make the Hello World example resemble the Hello World
Bill Wendling [Tue, 11 Oct 2011 07:03:52 +0000 (07:03 +0000)]
Minor modifications to make the Hello World example resemble the Hello World
pass in the tree. Also some minor formatting changes.
PR9413

git-svn-id: https://llvm.org/svn/llvm-project/llvm/trunk@141655 91177308-0d34-0410-b5e6-96231b3b80d8

12 years agoMake Ivy Bridge 16-bit floating point conversion instructions require AVX.
Craig Topper [Tue, 11 Oct 2011 07:01:37 +0000 (07:01 +0000)]
Make Ivy Bridge 16-bit floating point conversion instructions require AVX.

git-svn-id: https://llvm.org/svn/llvm-project/llvm/trunk@141654 91177308-0d34-0410-b5e6-96231b3b80d8

12 years agoApparently, sometimes llvm-nm doesn't put the undefined symbol at the top. Take
Nick Lewycky [Tue, 11 Oct 2011 06:58:11 +0000 (06:58 +0000)]
Apparently, sometimes llvm-nm doesn't put the undefined symbol at the top. Take
that into account and test for no U's showing up in the middle, which is what
we really wanted to test for.

git-svn-id: https://llvm.org/svn/llvm-project/llvm/trunk@141653 91177308-0d34-0410-b5e6-96231b3b80d8

12 years agoTest case for X86 LZCNT instruction selection.
Craig Topper [Tue, 11 Oct 2011 06:47:01 +0000 (06:47 +0000)]
Test case for X86 LZCNT instruction selection.

git-svn-id: https://llvm.org/svn/llvm-project/llvm/trunk@141652 91177308-0d34-0410-b5e6-96231b3b80d8

12 years agoAdd X86 LZCNT instruction. Including instruction selection support.
Craig Topper [Tue, 11 Oct 2011 06:44:02 +0000 (06:44 +0000)]
Add X86 LZCNT instruction. Including instruction selection support.

git-svn-id: https://llvm.org/svn/llvm-project/llvm/trunk@141651 91177308-0d34-0410-b5e6-96231b3b80d8

12 years agoUse the proper name for "externally visible" linkage -- 'external'. This is the
Bill Wendling [Tue, 11 Oct 2011 06:41:28 +0000 (06:41 +0000)]
Use the proper name for "externally visible" linkage -- 'external'. This is the
keyword in LLVM for externally visible linkage.
PR10636

git-svn-id: https://llvm.org/svn/llvm-project/llvm/trunk@141649 91177308-0d34-0410-b5e6-96231b3b80d8

12 years agoReword the SetVector description to reflect reality.
Bill Wendling [Tue, 11 Oct 2011 06:33:56 +0000 (06:33 +0000)]
Reword the SetVector description to reflect reality.
Patch by Michael Ilseman!

git-svn-id: https://llvm.org/svn/llvm-project/llvm/trunk@141648 91177308-0d34-0410-b5e6-96231b3b80d8