| Commit message (Collapse) | Author | Age | Files | Lines |
| |
|
|
|
|
|
|
|
|
|
|
|
|
|
|
| |
This is already done for shifts. Allow it for rotations as well. E.g.:
(rotl:i32 x, (trunc (and y, 31))) -> (rotl:i32 x, (and (trunc y), 31))
Use the newly factored-out distributeTruncateThroughAnd.
With this patch and some X86.td tweaks we should be able to remove redundant
masking of the rotation amount like in the example above. HW implicitly
performs this masking.
The testcase will be added as part of the X86 patch.
llvm-svn: 203316
|
| |
|
|
|
|
|
|
|
|
|
|
|
|
|
|
| |
This is the new idiom:
x<<(y&31) | x>>((0-y)&31)
which is recognized as:
x ROTL (y&31)
The change refines matchRotateSub. In
Neg & (OpSize - 1) == (OpSize - Pos) & (OpSize - 1), if Pos is
Pos' & (OpSize - 1) we can just use Pos' instead of Pos.
llvm-svn: 203315
|
| |
|
|
|
|
|
|
|
|
| |
Slightly change the wording in the function comment. Originally, it can be
misunderstood as we turned the input into two subsequent rotates.
Better connect the comment which talks about Mask and the code which used
LoBits. Renamed variable to MaskLoBits.
llvm-svn: 203314
|
| |
|
|
|
|
|
|
|
|
|
|
|
|
|
| |
be split and the result type widened.
When the condition of a vselect has to be split it makes no sense widening the
vselect and thereby widening the condition. We end up in an endless loop of
widening (vselect result type) and splitting (condition mask type) doing this.
Instead, split both the condition and the vselect and widen the result.
I ran this over the test suite with i686 and mattr=+sse and saw no regressions.
Fixes PR18036.
llvm-svn: 203311
|
| |
|
|
|
|
|
| |
horrible/fragile.
rdar://problem/16264854
llvm-svn: 203309
|
| |
|
|
| |
llvm-svn: 203307
|
| |
|
|
| |
llvm-svn: 203306
|
| |
|
|
| |
llvm-svn: 203305
|
| |
|
|
|
|
|
|
|
|
|
|
|
|
|
| |
First: refactor out the emission of entries into the .debug_loc section
into its own routine.
Second: add a new class ByteStreamer that can be used to either emit
using an AsmPrinter or hash using DIEHash the series of bytes that
would be emitted. Use this in all of the location emission routines
for the .debug_loc section.
No functional change intended outside of a few additional comments
in verbose assembly.
llvm-svn: 203304
|
| |
|
|
|
|
| |
to the hash.
llvm-svn: 203303
|
| |
|
|
| |
llvm-svn: 203301
|
| |
|
|
|
|
| |
This breaks linux buildbots. Go figure.
llvm-svn: 203300
|
| |
|
|
| |
llvm-svn: 203298
|
| |
|
|
| |
llvm-svn: 203297
|
| |
|
|
|
|
| |
Suggested by Adrian Prantl in code review for r203187.
llvm-svn: 203296
|
| |
|
|
| |
llvm-svn: 203295
|
| |
|
|
|
|
| |
Looks like GCC implements the lambda->function pointer conversion differently.
llvm-svn: 203294
|
| |
|
|
|
|
| |
No functionality change.
llvm-svn: 203288
|
| |
|
|
|
|
| |
declaration.
llvm-svn: 203287
|
| |
|
|
| |
llvm-svn: 203286
|
| |
|
|
|
|
| |
EXPECT_TRUE/FALSE is also more idiomatic for booleans than EXPECT_EQ
llvm-svn: 203284
|
| |
|
|
|
| |
Reviewed-by: Michel Dänzer <michel.daenzer@amd.com>
llvm-svn: 203281
|
| |
|
|
|
|
|
|
| |
These are sometimes created by the shrink to boolean optimization in the
globalopt pass.
Reviewed-by: Michel Dänzer <michel.daenzer@amd.com>
llvm-svn: 203280
|
| |
|
|
|
|
| |
No functionality change.
llvm-svn: 203276
|
| |
|
|
|
|
|
|
|
|
| |
Previously, the assertions in PointerIntPair would try to calculate the value
(1 << NumLowBitsAvailable); the inferred type here is 'int', so if there were
more than 31 bits available we'd get a shift overflow.
Also, add a rudimentary unit test file for PointerIntPair.
llvm-svn: 203273
|
| |
|
|
|
|
|
|
|
|
| |
files.
Patch by Konrad Kleine.
Differential Revision: http://llvm-reviews.chandlerc.com/D2967
llvm-svn: 203272
|
| |
|
|
|
|
| |
It has a lot of them with complex types. C++11 really shines here.
llvm-svn: 203270
|
| |
|
|
|
|
|
| |
The integrated assembler now works for ppc. Since this was the last use of the
bg/p predicate and Hal says that it is now dead, drop the predicate too.
llvm-svn: 203269
|
| |
|
|
| |
llvm-svn: 203267
|
| |
|
|
| |
llvm-svn: 203265
|
| |
|
|
|
|
|
|
|
| |
This is a straightfoward replacement, it makes debugging a little
easier.
This has no functional impact.
llvm-svn: 203264
|
| |
|
|
|
|
|
| |
For incoming improvements to inlined functions and lexical blocks
suggested by Adrian Prantl in review of r203187.
llvm-svn: 203263
|
| |
|
|
|
|
| |
Patch from Sean McBride <sean@rogue-research.com>!
llvm-svn: 203258
|
| |
|
|
|
|
| |
Using const is orthogonal to guidelines on using auto& and auto*.
llvm-svn: 203257
|
| |
|
|
|
|
|
|
| |
spec
Code review feedback to r203187 from Oliver Stannard. Thanks!
llvm-svn: 203256
|
| |
|
|
| |
llvm-svn: 203254
|
| |
|
|
|
|
|
|
| |
Be case-insensitive when processing .unreq directives.
Patch by Lin Zuojian!
llvm-svn: 203251
|
| |
|
|
|
|
|
|
| |
type_traits.h
Simplify the remaining ones a bit.
llvm-svn: 203249
|
| |
|
|
| |
llvm-svn: 203246
|
| |
|
|
| |
llvm-svn: 203243
|
| |
|
|
|
|
| |
No functionality change.
llvm-svn: 203242
|
| |
|
|
|
|
|
|
|
|
| |
The target was marking SIGN_EXTEND as Custom because it wanted to optimize
certain sign-extended shifts. In all other respects the extension is Legal,
so it'd be better to do the optimization in PerformDAGCombine instead.
No functional change intended.
llvm-svn: 203234
|
| |
|
|
|
|
|
|
|
| |
This helps the instruction selector to lower an i64 * i64 -> i128
multiplication into a single instruction on targets which support it.
Patch by Manuel Jacob.
llvm-svn: 203230
|
| |
|
|
|
|
|
|
|
|
|
|
| |
Sequences of insertelement/extractelements are sometimes used to build
vectorsr; this code tries to put them back together into shuffles, but
could only produce a completely uniform shuffle types (<N x T> from two
<N x T> sources).
This should allow shuffles with different numbers of elements on the
input and output sides as well.
llvm-svn: 203229
|
| |
|
|
|
|
|
| |
This changes the interface to be more explicit that ownership is being
transferred.
llvm-svn: 203223
|
| |
|
|
| |
llvm-svn: 203221
|
| |
|
|
|
|
| |
class.
llvm-svn: 203220
|
| |
|
|
|
|
| |
Differential Revision: http://llvm-reviews.chandlerc.com/D2982
llvm-svn: 203218
|
| |
|
|
|
|
| |
Removed whitespace
llvm-svn: 203216
|
| |
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
| |
Summary:
llvm/MC/MCSectionMachO.h and llvm/Support/MachO.h both had the same
definitions for the section flags. Instead, grab the definitions out of
support.
No functionality change.
Reviewers: grosbach, Bigcheese, rafael
Reviewed By: rafael
CC: llvm-commits
Differential Revision: http://llvm-reviews.chandlerc.com/D2998
llvm-svn: 203211
|