]> granicus.if.org Git - llvm/log
llvm
8 years ago[PM] Move the collection of call sites to a more appropriate place
Chandler Carruth [Tue, 27 Dec 2016 01:24:50 +0000 (01:24 +0000)]
[PM] Move the collection of call sites to a more appropriate place
inside of `InlineFunction`. Prior to this, call instructions are
specifically being rewritten and replaced within the inlined region,
invalidating some of the call sites.

Several of these regions are using the same technique to walk the
inlined region so this seems clearly safe up to this point.

I've also added a short circuit to the scan for call sites based on what
other code is doing.

With this, the most common crash I've found in the new inliner code is
fixed. I've turned it on for another test case that covers this
scenario.

I'll make my way through most of the other inliner test cases
just to get some easy coverage next.

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

8 years ago[AVX-512][InstCombine] Teach InstCombine to turn packed add/sub/mul/div with rounding...
Craig Topper [Tue, 27 Dec 2016 00:23:16 +0000 (00:23 +0000)]
[AVX-512][InstCombine] Teach InstCombine to turn packed add/sub/mul/div with rounding intrinsics into normal IR operations if the rounding mode is CUR_DIRECTION.

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

8 years ago[PM] Teach the always inliner in the new pass manager to support
Chandler Carruth [Mon, 26 Dec 2016 23:43:27 +0000 (23:43 +0000)]
[PM] Teach the always inliner in the new pass manager to support
removing fully-dead comdats without removing dead entries in comdats
with live members.

This factors the core logic out of the current inliner's internals to
a reusable utility and leverages that in both places. The factored out
code should also be (minorly) more efficient in cases where we have very
few dead functions or dead comdats to consider.

I've added a test case to cover this behavior of the always inliner.
This is the last significant bug in the new PM's always inliner I've
found (so far).

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

8 years ago[doc] Add mention of the difference in optimization level between Release and RelWith...
Mehdi Amini [Mon, 26 Dec 2016 23:42:12 +0000 (23:42 +0000)]
[doc] Add mention of the difference in optimization level between Release and RelWithDebInfo in Cmake.rst

This is surprising to many people.

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

8 years ago[ADT] Add an llvm::erase_if utility to make the standard erase+remove_if
Chandler Carruth [Mon, 26 Dec 2016 23:30:44 +0000 (23:30 +0000)]
[ADT] Add an llvm::erase_if utility to make the standard erase+remove_if
pattern easier to write.

Differential Revision: https://reviews.llvm.org/D28120

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

8 years ago[InstCombine][X86] Add DemandedElts support for PMULDQ/PMULUDQ instructions
Simon Pilgrim [Mon, 26 Dec 2016 23:28:17 +0000 (23:28 +0000)]
[InstCombine][X86] Add DemandedElts support for PMULDQ/PMULUDQ instructions

PMULDQ/PMULUDQ vXi64 instructions only use the even numbered v2Xi32 input elements which SimplifyDemandedVectorElts should try and use.

Differential Revision: https://reviews.llvm.org/D28119

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

8 years ago[ADT] Add a boring std::partition wrapper similar to our std::remove_if
Chandler Carruth [Mon, 26 Dec 2016 23:10:40 +0000 (23:10 +0000)]
[ADT] Add a boring std::partition wrapper similar to our std::remove_if
wrapper.

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

8 years agoclang-format NewGVN files
Daniel Berlin [Mon, 26 Dec 2016 20:06:58 +0000 (20:06 +0000)]
clang-format NewGVN files

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

8 years agoMisc cleanups and simplifications for NewGVN.
Daniel Berlin [Mon, 26 Dec 2016 19:57:25 +0000 (19:57 +0000)]
Misc cleanups and simplifications for NewGVN.
Mostly use a bit more idiomatic C++ where we can,
so we can combine some things later.

Reviewers: davide

Subscribers: llvm-commits

Differential Revision: https://reviews.llvm.org/D28111

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

8 years agoDon't use our own incorrect version of isTriviallyDeadInstruction in NewGVN. Fixes...
Daniel Berlin [Mon, 26 Dec 2016 18:44:36 +0000 (18:44 +0000)]
Don't use our own incorrect version of isTriviallyDeadInstruction in NewGVN. Fixes PR/31472

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

8 years ago[NewGVN] Add a flag to enable the pass via `-mllvm`.
Davide Italiano [Mon, 26 Dec 2016 18:26:19 +0000 (18:26 +0000)]
[NewGVN] Add a flag to enable the pass via `-mllvm`.

NewGVN can be tested passing `-mllvm -enable-newgvn` to clang.

Differential Revision:  https://reviews.llvm.org/D28059

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

8 years ago[NewGVN] Change test to reflect difference between GVN and NewGVN.
Davide Italiano [Mon, 26 Dec 2016 18:10:09 +0000 (18:10 +0000)]
[NewGVN] Change test to reflect difference between GVN and NewGVN.

The current GVN algorithm folds unconditional branches to, it claims,
expose more PRE oportunities. The folding, if really needed,
(which is not sure, as it's not really proved it improves analysis)
can be done by an earlier cleanup pass instead of GVN itself.
Ack'ed/SGTM'd by Daniel Berlin.

Differential Revision:  https://reviews.llvm.org/D28117

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

8 years agoWdocumentation fix
Simon Pilgrim [Mon, 26 Dec 2016 17:48:19 +0000 (17:48 +0000)]
Wdocumentation fix

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

8 years ago[X86][AVX512] Added v64i8 reverse shuffle test (PR31470)
Simon Pilgrim [Mon, 26 Dec 2016 17:38:58 +0000 (17:38 +0000)]
[X86][AVX512] Added v64i8 reverse shuffle test (PR31470)

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

8 years ago[NewGVN] Fold lookupOperandLeader() when there's only one use. NFCI.
Davide Italiano [Mon, 26 Dec 2016 16:19:34 +0000 (16:19 +0000)]
[NewGVN] Fold lookupOperandLeader() when there's only one use. NFCI.

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

8 years ago[InstCombiner] Simplify lib calls to `round{,f}`
Bryant Wong [Mon, 26 Dec 2016 14:29:29 +0000 (14:29 +0000)]
[InstCombiner] Simplify lib calls to `round{,f}`

Differential Revision: https://reviews.llvm.org/D28110

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

8 years agoTest the different scenarios of GlobalDCE and comdats more
Chandler Carruth [Mon, 26 Dec 2016 08:54:01 +0000 (08:54 +0000)]
Test the different scenarios of GlobalDCE and comdats more
systematically and document in the test what all is going on.

This replaces the PR-named test that was the only coverage for GlobalDCE
and comdats previously. I wrote this because I wasn't certain how
comdat DCE was supposed to work and wanted to step through what
GlobalDCE did to fully understand it. After talking to folks and reading
the code and really staring at things it all makes sense but it seemed
good to help write down some of this in a more explicit and fully
covering test case.

For example, it seemed like a bug that GlobalDCE didn't consider comdat
participation of ifuncs. Specifically it seemed like an accident because
testing didn't really cover that case. But in fact, ifuncs specifically
cannot participate in a comdat despite having that API. The new test
case covers this and explicitly documents that DCE gets to fire here
even though there are comdats involved.

Also, we didn't have any positive tests for the challenging cases such
as usage cycles between comdat participants that might make them seem
alive except that there is no external edge into the cycle.

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

8 years ago[AVX-512] Fix some patterns to use extended register classes.
Craig Topper [Mon, 26 Dec 2016 07:26:07 +0000 (07:26 +0000)]
[AVX-512] Fix some patterns to use extended register classes.

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

8 years ago[AVX-512][InstCombine] Teach InstCombine to turn scalar add/sub/mul/div with rounding...
Craig Topper [Mon, 26 Dec 2016 06:33:19 +0000 (06:33 +0000)]
[AVX-512][InstCombine] Teach InstCombine to turn scalar add/sub/mul/div with rounding intrinsics into normal IR operations if the rounding mode is CUR_DIRECTION.

Summary:
I only do this for unmasked cases for now because isel is failing to fold the mask. I'll try to fix that soon.

I'll do the same thing for packed add/sub/mul/div in a future patch.

Reviewers: delena, RKSimon, zvi, craig.topper

Subscribers: llvm-commits

Differential Revision: https://reviews.llvm.org/D27879

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

8 years ago[AVX-512] Don't assume that the rounding mode argument to intrinsics is a constant...
Craig Topper [Mon, 26 Dec 2016 01:40:17 +0000 (01:40 +0000)]
[AVX-512] Don't assume that the rounding mode argument to intrinsics is a constant. While clang will guarantee this, nothing in the backend will.

A non-constant value will now result in an isel error instead of just asserting or crashing due to a bad cast during lowering.

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

8 years agoFix some bad indentation that I or another introduced somehow.
Chandler Carruth [Mon, 26 Dec 2016 01:20:59 +0000 (01:20 +0000)]
Fix some bad indentation that I or another introduced somehow.

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

8 years ago[AVX-512][InstCombine] Teach InstCombine to converted masked vpermv intrinsics into...
Craig Topper [Sun, 25 Dec 2016 23:58:57 +0000 (23:58 +0000)]
[AVX-512][InstCombine] Teach InstCombine to converted masked vpermv intrinsics into shufflevector instructions

Summary:
This patch adds support for converting the masked vpermv intrinsics into shufflevector instructions if the indices are constants.

We also need to wrap a select instruction around the shuffle to take care of the masking part. InstCombine will take care of optimizing the select if the mask is constant so I didn't bother checking for that.

Reviewers: zvi, delena, spatel, RKSimon

Subscribers: llvm-commits

Differential Revision: https://reviews.llvm.org/D27825

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

8 years agoFix `update_test_checks.py` bug that incorrectly truncates IR body.
Bryant Wong [Sun, 25 Dec 2016 23:46:55 +0000 (23:46 +0000)]
Fix `update_test_checks.py` bug that incorrectly truncates IR body.

Differential Revision: https://reviews.llvm.org/D26619

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

8 years ago[ADT] Add a generic concatenating iterator and range (take 2).
Chandler Carruth [Sun, 25 Dec 2016 23:41:14 +0000 (23:41 +0000)]
[ADT] Add a generic concatenating iterator and range (take 2).

This recommits r290512 that was reverted when MSVC failed to compile it. Since
then I've played with various approaches using rextester.com (where I was able
to reproduce the failure) and think that I have a solution thanks in part to
the help of Dave Blaikie! It seems MSVC just has a defective `decltype` in this
version. Manually writing out the type seems to do the trick, even though it is
.... quite complicated.

Original commit message:
This allows both defining convenience iterator/range accessors on types
which walk across N different independent ranges within the object, and
more direct and simple usages with range based for loops such as shown
in the unittest. The same facilities are used for both. They end up
quite small and simple as it happens.

I've also switched an iterator on `Module` to use this. I would like to
add another convenience iterator that includes even more sequences as
part of it and seeing this one already present motivated me to actually
abstract it away and introduce a general utility.

Differential Revision: https://reviews.llvm.org/D28093

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

8 years ago[MemorySSA] Define a restricted upward AccessList splice.
Bryant Wong [Sun, 25 Dec 2016 23:34:07 +0000 (23:34 +0000)]
[MemorySSA] Define a restricted upward AccessList splice.

Differential Revision: https://reviews.llvm.org/D26661

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

8 years ago[AliasAnalysis] Teach BasicAA about memcpy.
Bryant Wong [Sun, 25 Dec 2016 22:42:27 +0000 (22:42 +0000)]
[AliasAnalysis] Teach BasicAA about memcpy.

Differential Revision: https://reviews.llvm.org/D27034

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

8 years agoValue number stores and memory states so we can detect when memory states are equival...
Daniel Berlin [Sun, 25 Dec 2016 22:23:49 +0000 (22:23 +0000)]
Value number stores and memory states so we can detect when memory states are equivalent (IE store of same value to memory).

Reviewers: davide

Subscribers: llvm-commits

Differential Revision: https://reviews.llvm.org/D28084

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

8 years agoRename GVNExpression *ops_ members to *op_* to match conventions in the rest of LLVM
Daniel Berlin [Sun, 25 Dec 2016 22:10:37 +0000 (22:10 +0000)]
Rename GVNExpression *ops_ members to *op_* to match conventions in the rest of LLVM

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

8 years ago[Orc][RPC] Add a ParallelCallGroup utility for dispatching and waiting on
Lang Hames [Sun, 25 Dec 2016 21:55:05 +0000 (21:55 +0000)]
[Orc][RPC] Add a ParallelCallGroup utility for dispatching and waiting on
multiple asynchronous RPC calls.

ParallelCallGroup allows multiple asynchronous calls to be dispatched,
and provides a wait method that blocks until all asynchronous calls have
been executed on the remote and all return value handlers run on the
local machine.

This will allow, for example, the JIT client to issue memory allocation calls
for all sections in parallel, then block until all memory has been allocated
on the remote and the allocated addresses registered with the client, at which
point the JIT client can proceed to applying relocations.

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

8 years ago[Orc][RPC] Clang-format RPCUtils header.
Lang Hames [Sun, 25 Dec 2016 19:55:59 +0000 (19:55 +0000)]
[Orc][RPC] Clang-format RPCUtils header.

Some of the recent RPC call type-checking changes weren't formatted prior to
commit.

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

8 years agoAdd newline to end of file to quiet warnings.
Greg Clayton [Sun, 25 Dec 2016 18:41:47 +0000 (18:41 +0000)]
Add newline to end of file to quiet warnings.

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

8 years agorevert commit 290516
Michael Zuckerman [Sun, 25 Dec 2016 12:45:18 +0000 (12:45 +0000)]
revert commit 290516

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

8 years agoCommit try added new empty line
Michael Zuckerman [Sun, 25 Dec 2016 12:01:34 +0000 (12:01 +0000)]
Commit try added new empty line

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

8 years ago[DebugInfo] Added support for Checksum debug info feature.
Amjad Aboud [Sun, 25 Dec 2016 10:12:09 +0000 (10:12 +0000)]
[DebugInfo] Added support for Checksum debug info feature.

Differential Revision: https://reviews.llvm.org/D27642

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

8 years agoRevert r290512: [ADT] Add a generic concatenating iterator and range.
Chandler Carruth [Sun, 25 Dec 2016 09:36:24 +0000 (09:36 +0000)]
Revert r290512: [ADT] Add a generic concatenating iterator and range.

This code doesn't work on MSVC for reasons that elude me and I've not
yet covinced a workaround to compile cleanly so reverting for now while
I play with it.

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

8 years ago[ADT] Add a generic concatenating iterator and range.
Chandler Carruth [Sun, 25 Dec 2016 08:22:50 +0000 (08:22 +0000)]
[ADT] Add a generic concatenating iterator and range.

This allows both defining convenience iterator/range accessors on types
which walk across N different independent ranges within the object, and
more direct and simple usages with range based for loops such as shown
in the unittest. The same facilities are used for both. They end up
quite small and simple as it happens.

I've also switched an iterator on `Module` to use this. I would like to
add another convenience iterator that includes even more sequences as
part of it and seeing this one already present motivated me to actually
abstract it away and introduce a general utility.

Differential Revision: https://reviews.llvm.org/D28093

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

8 years agoMetadataLoader: replace the tracking of ForwardReferences and UnresolvedNodes with...
Mehdi Amini [Sun, 25 Dec 2016 04:22:54 +0000 (04:22 +0000)]
MetadataLoader: replace the tracking of ForwardReferences and UnresolvedNodes with a set-based solution (NFC)

This makes it explicit what is the exact list to handle, and it
looks much more easy to manipulate and understand that the
previous custom tracking of min/max to express the range where
to look for.

Differential Revision: https://reviews.llvm.org/D28089

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

8 years agoMetadataLoader: add an extra assertion in Placeholders flush (NFC)
Mehdi Amini [Sun, 25 Dec 2016 03:55:53 +0000 (03:55 +0000)]
MetadataLoader: add an extra assertion in Placeholders flush (NFC)

We don't expect any forward reference at this point.

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

8 years agoAdd range iterator for blocks in MemoryPhi
Daniel Berlin [Sat, 24 Dec 2016 21:52:10 +0000 (21:52 +0000)]
Add range iterator for blocks in MemoryPhi

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

8 years ago[InstCombine][X86] Add tests showing missed opportunities to simplify PMULUDQ/PMULDQ...
Simon Pilgrim [Sat, 24 Dec 2016 17:30:19 +0000 (17:30 +0000)]
[InstCombine][X86] Add tests showing missed opportunities to simplify PMULUDQ/PMULDQ inputs.

PMULUDQ/PMULDQ - only the even elements (0, 2, 4, 6) of the vXi32 inputs are required.

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

8 years agoTest commit.
Bryant Wong [Sat, 24 Dec 2016 17:26:38 +0000 (17:26 +0000)]
Test commit.

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

8 years ago[NewGVN] Prefer `auto` to explicit type when the latter is obvious.
Davide Italiano [Sat, 24 Dec 2016 17:17:21 +0000 (17:17 +0000)]
[NewGVN] Prefer `auto` to explicit type when the latter is obvious.

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

8 years ago[NewGVN] Simplify several equals() member functions. NFCI.
Davide Italiano [Sat, 24 Dec 2016 17:14:19 +0000 (17:14 +0000)]
[NewGVN] Simplify several equals() member functions. NFCI.

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

8 years ago[PM] Remove vestiges of NoAA. NFCI.
Davide Italiano [Sat, 24 Dec 2016 16:14:05 +0000 (16:14 +0000)]
[PM] Remove vestiges of NoAA. NFCI.

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

8 years agollvm-objdump: sort phdr type strings in advance of adding new ones
Ed Maste [Sat, 24 Dec 2016 14:53:45 +0000 (14:53 +0000)]
llvm-objdump: sort phdr type strings in advance of adding new ones

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

8 years ago[SelectionDAG] Early out from computeKnownBits when we know we will have no common...
Simon Pilgrim [Sat, 24 Dec 2016 12:59:35 +0000 (12:59 +0000)]
[SelectionDAG] Early out from computeKnownBits when we know we will have no common bits.

Avoid extra (recursive) calls to computeKnownBits if we already know that there are no common known bits.

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

8 years ago[PM] Try to improve the comments here to make what's going on more
Chandler Carruth [Sat, 24 Dec 2016 05:11:17 +0000 (05:11 +0000)]
[PM] Try to improve the comments here to make what's going on more
clear.

Based on post-commit review suggestion from Sean. (Thanks!)

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

8 years agoMark isOnlyReachableViaThisEdge as const
Daniel Berlin [Sat, 24 Dec 2016 00:04:07 +0000 (00:04 +0000)]
Mark isOnlyReachableViaThisEdge as const

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

8 years agoAdd an assertion for cl::opt names: they can't start with '-'
Mehdi Amini [Fri, 23 Dec 2016 23:55:26 +0000 (23:55 +0000)]
Add an assertion for cl::opt names: they can't start with '-'

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

8 years agollvm-size: remove leading dash in '-radix' option
Mehdi Amini [Fri, 23 Dec 2016 23:55:08 +0000 (23:55 +0000)]
llvm-size: remove leading dash in '-radix' option

cl::opt does not accept such option

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

8 years agollvm-readobj: remove leading dash in '-a' option (ARMAttributesShort)
Mehdi Amini [Fri, 23 Dec 2016 23:54:52 +0000 (23:54 +0000)]
llvm-readobj: remove leading dash in '-a' option (ARMAttributesShort)

cl::opt does not accept such option

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

8 years agollvm-lto2: remove leading '-' for cl::opt declaration
Mehdi Amini [Fri, 23 Dec 2016 23:54:34 +0000 (23:54 +0000)]
llvm-lto2: remove leading '-' for cl::opt declaration

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

8 years agollvm-lto2: Print diagnostics before exiting (NFC)
Mehdi Amini [Fri, 23 Dec 2016 23:54:17 +0000 (23:54 +0000)]
llvm-lto2: Print diagnostics before exiting (NFC)

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

8 years agollvm-lto: pass errs() to the module verifier (NFC)
Mehdi Amini [Fri, 23 Dec 2016 23:53:57 +0000 (23:53 +0000)]
llvm-lto: pass errs() to the module verifier (NFC)

It is more friendly to have the actual diagnostic when the
verifier fails.

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

8 years ago[PM] Remove a bunch of junk that snuck in when I failed at manipulating
Chandler Carruth [Fri, 23 Dec 2016 23:39:31 +0000 (23:39 +0000)]
[PM] Remove a bunch of junk that snuck in when I failed at manipulating
my editor to close and commit the patch. Sorry for the noise.

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

8 years ago[PM] Teach the always inlining test case to be much more strict about
Chandler Carruth [Fri, 23 Dec 2016 23:33:35 +0000 (23:33 +0000)]
[PM] Teach the always inlining test case to be much more strict about
whether functions are removed, and fix the new PM's always inliner to
actually pass this test.

Without this, the new PM's always inliner leaves all the functions
kicking around which won't work out very well given the semantics of
always inline.

Doing this really highlights how frustrating the current alwaysinline
semantic contract is though -- why can we put it on *external*
functions, etc?

Also I've added a number of tricky and interesting test cases for
removing functions with the always inliner. There is one remaining case
not handled -- fully removing comdats -- and I've left a FIXME about
this.

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

8 years ago[PM] Clean up test case and comments a bit. NFC.
Chandler Carruth [Fri, 23 Dec 2016 23:33:32 +0000 (23:33 +0000)]
[PM] Clean up test case and comments a bit. NFC.

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

8 years ago[PM] Add support for building a default AA pipeline to the PassBuilder.
Chandler Carruth [Fri, 23 Dec 2016 20:38:19 +0000 (20:38 +0000)]
[PM] Add support for building a default AA pipeline to the PassBuilder.

Pretty boring and lame as-is but necessary. This is definitely a place
we'll end up with extension hooks longer term. =]

Differential Revision: https://reviews.llvm.org/D28076

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

8 years agoFunction-import: Disable IRVerifier on lazy-loaded modules: the ODR TypeUniquing...
Mehdi Amini [Fri, 23 Dec 2016 19:19:44 +0000 (19:19 +0000)]
Function-import: Disable IRVerifier on lazy-loaded modules: the ODR TypeUniquing generates invalid debug info.

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

8 years agoFix build after r290437 (missing include)
Mehdi Amini [Fri, 23 Dec 2016 18:04:51 +0000 (18:04 +0000)]
Fix build after r290437 (missing include)

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

8 years agoFunctionImport: fix typo '#ifndef NDEBUG' instead of '#ifndef DEBUG'
Mehdi Amini [Fri, 23 Dec 2016 17:59:24 +0000 (17:59 +0000)]
FunctionImport: fix typo '#ifndef NDEBUG' instead of '#ifndef DEBUG'

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

8 years agoAMDGPU: split ret/noret patterns for global atomics
Jan Vesely [Fri, 23 Dec 2016 15:34:51 +0000 (15:34 +0000)]
AMDGPU: split ret/noret patterns for global atomics

Differential Revision: https://reviews.llvm.org/D27989

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

8 years ago[LICM] Plug a leak freeing the ASTs before clearing the map.
Davide Italiano [Fri, 23 Dec 2016 15:02:35 +0000 (15:02 +0000)]
[LICM] Plug a leak freeing the ASTs before clearing the map.

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

8 years ago[MemDep] NFC changes
Piotr Padlewski [Fri, 23 Dec 2016 13:13:32 +0000 (13:13 +0000)]
[MemDep] NFC changes

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

8 years ago[LICM] Work around LICM needs to maintain state across loops.
Davide Italiano [Fri, 23 Dec 2016 13:12:50 +0000 (13:12 +0000)]
[LICM] Work around LICM needs to maintain state across loops.

The pass creates some state which expects to be cleaned up by
a later instance of the same pass. opt-bisect happens to expose
this not ideal design because calling skipLoop() will result in
this state not being cleaned up at times and an assertion firing
in `doFinalization()`. Chandler tells me the new pass manager will
give us options to avoid these design traps, but until it's not ready,
we need a workaround for the current pass infrastructure. Fix provided
by Andy Kaylor, see the review for a complete discussion.

Differential Revision:  https://reviews.llvm.org/D25848

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

8 years ago[AArch64] Cortex-A57 FDIV/FSQRT scheduling fix (W-unit)
Renato Golin [Fri, 23 Dec 2016 12:51:41 +0000 (12:51 +0000)]
[AArch64] Cortex-A57 FDIV/FSQRT scheduling fix (W-unit)

According to the Cortex-A57 doc, FDIV/FSQRT instructions should use F0 unit
(W-unit in AArch64SchedA57.td, the same as cryptography instructions),
not F1 unit (X-unit in td, like ASIMD absolute diff accum SABA/UABA).

This patch changes FDIV/FSQRT scheduling declarations to use A57UnitW
instead of A57UnitX. Also, latencies for those instructions are
corrected.

Patch by Andrew Zhogin.

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

8 years agoRevert r290423 because it broke the sanitizer-x86_64-linux-autoconf buildbot.
Florian Hahn [Fri, 23 Dec 2016 12:26:11 +0000 (12:26 +0000)]
Revert r290423 because it broke the sanitizer-x86_64-linux-autoconf buildbot.

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

8 years ago[framelowering] Skip dbg values when getting next/previous instruction.
Florian Hahn [Fri, 23 Dec 2016 11:35:00 +0000 (11:35 +0000)]
[framelowering] Skip dbg values when getting next/previous instruction.

Summary:
In mergeSPUpdates, debug values need to be ignored when getting the
previous element, otherwise debug data could have an impact on codegen.

In eliminateCallFramePseudoInstr, debug values after the erased element
could have an impact on codegen and should be skipped.

Closes PR31319 (https://llvm.org/bugs/show_bug.cgi?id=31319)

Reviewers: mkuper, MatzeB, aprantl

Subscribers: gbedwell, llvm-commits

Differential Revision: https://reviews.llvm.org/D27688

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

8 years ago[NewGVN] Remove (for now) unused code. NFCI.
Davide Italiano [Fri, 23 Dec 2016 10:28:30 +0000 (10:28 +0000)]
[NewGVN] Remove (for now) unused code. NFCI.

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

8 years ago[ThinLTO] Verify lazy-loaded source module for function importing when assertions...
Mehdi Amini [Fri, 23 Dec 2016 05:16:19 +0000 (05:16 +0000)]
[ThinLTO] Verify lazy-loaded source module for function importing when assertions are enabled (NFC)

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

8 years agoMetadataLoader: split the creation of a single metadata out of a Record into its...
Mehdi Amini [Fri, 23 Dec 2016 03:59:18 +0000 (03:59 +0000)]
MetadataLoader: split the creation of a single metadata out of a Record into its own function (NFC)

This is pure code motion, will just make it more reusable when I'll
attempt to lazy-load Metadats on-demand.

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

8 years ago[WebAssembly] Annotate call and load/store immediates.
Dan Gohman [Fri, 23 Dec 2016 03:23:52 +0000 (03:23 +0000)]
[WebAssembly] Annotate call and load/store immediates.

These will be used to guide the binary encoding of these immediates.

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

8 years agoMake the canonicalisation on shifts benifit to more case.
Zijiao Ma [Fri, 23 Dec 2016 02:56:07 +0000 (02:56 +0000)]
Make the canonicalisation on shifts benifit to more case.

1.Fix pessimized case in FIXME.
2.Add tests for it.
3.The canonicalisation on shifts results in different sequence for
  tests of machine-licm.Correct some check lines.

Differential Revision: https://reviews.llvm.org/D27916

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

8 years agoMetadataLoader: Reinitialize MinFwdRef/MaxFwdRef after resolving cycles (NFC)
Mehdi Amini [Fri, 23 Dec 2016 02:20:12 +0000 (02:20 +0000)]
MetadataLoader: Reinitialize MinFwdRef/MaxFwdRef after resolving cycles (NFC)

This put the Loader back in a consistent state.

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

8 years agoMetadataLoader: Add an assertion for the implicit invariant of PlaceHolder while...
Mehdi Amini [Fri, 23 Dec 2016 02:20:09 +0000 (02:20 +0000)]
MetadataLoader: Add an assertion for the implicit invariant of PlaceHolder while loading Metadata (NFC)

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

8 years agoMetadataLoader: Make sure every member of MetadataLoader are initialized (NFC)
Mehdi Amini [Fri, 23 Dec 2016 02:20:07 +0000 (02:20 +0000)]
MetadataLoader: Make sure every member of MetadataLoader are initialized (NFC)

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

8 years agoMetadataLoader: Refactor "IsImporting" into the Pimpl for the MetadataLoader (NFC)
Mehdi Amini [Fri, 23 Dec 2016 02:20:02 +0000 (02:20 +0000)]
MetadataLoader: Refactor "IsImporting" into the Pimpl for the MetadataLoader (NFC)

Keeping all the state together will make it easier to handle.

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

8 years agoFix some DOS-style line endings that I suspect snuck in from one of the
Chandler Carruth [Fri, 23 Dec 2016 02:02:26 +0000 (02:02 +0000)]
Fix some DOS-style line endings that I suspect snuck in from one of the
frustrating Subversion clients that fails to do line ending translation
of text files.

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

8 years agoKillTheDoctor.cpp: Appease cases on case-senstitive host, like mingw on linux.
NAKAMURA Takumi [Fri, 23 Dec 2016 01:39:26 +0000 (01:39 +0000)]
KillTheDoctor.cpp: Appease cases on case-senstitive host, like mingw on linux.

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

8 years agoKillTheDoctor: Add a required system lib, psapi. KillTheDoctor itself uses Win32...
NAKAMURA Takumi [Fri, 23 Dec 2016 01:39:20 +0000 (01:39 +0000)]
KillTheDoctor: Add a required system lib, psapi. KillTheDoctor itself uses Win32 API directly.

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

8 years agoEnable '-Wstring-conversion' and fix some bad asserts that it helped
Chandler Carruth [Fri, 23 Dec 2016 01:38:06 +0000 (01:38 +0000)]
Enable '-Wstring-conversion' and fix some bad asserts that it helped
find.

Notable is the assert in NewGVN which had no effect because of the bug.

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

8 years agoDon't consider allocsize functions to be allocation functions.
George Burgess IV [Fri, 23 Dec 2016 01:18:09 +0000 (01:18 +0000)]
Don't consider allocsize functions to be allocation functions.

This patch fixes some ASAN unittest failures on FreeBSD. See the
cfe-commits email thread for r290169 for more on those.

According to the LangRef, the allocsize attribute only tells us about
the number of bytes that exist at the memory location pointed to by the
return value of a function. It does not necessarily mean that the
function will only ever allocate. So, we need to be very careful about
treating functions with allocsize as general allocation functions. This
patch makes us fully conservative in this regard, though I suspect that
we have room to be a bit more aggressive if we want.

This has a FIXME that can be fixed by a relatively straightforward
refactor; I just wanted to keep this patch minimal. If this sticks, I'll
come back and fix it in a few days.

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

8 years agoNFC code motion in ImplicitNullChecks
Sanjoy Das [Fri, 23 Dec 2016 00:41:24 +0000 (00:41 +0000)]
NFC code motion in ImplicitNullChecks

Extract out two large lambdas into top level member functions.

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

8 years agoReimplement depedency tracking in the ImplicitNullChecks pass
Sanjoy Das [Fri, 23 Dec 2016 00:41:21 +0000 (00:41 +0000)]
Reimplement depedency tracking in the ImplicitNullChecks pass

Summary:
This change rewrites a core component in the ImplicitNullChecks pass for
greater simplicity since the original design was over-complicated for no
good reason.  Please review this as essentially a new pass.  The change
is almost NFC and I've added a test case for a scenario that this new
code handles that wasn't handled earlier.

The implicit null check pass, at its core, is a code hoisting transform.
It differs from "normal" code transforms in that it speculates
potentially faulting instructions (by design), but a lot of the usual
hazard detection logic (register read-after-write etc.) still applies.
We previously detected hazards by keeping track of registers defined and
used by machine instructions over an instruction range, but that was
unwieldy and did not actually confer any performance benefits.  The
intent was to have linear time complexity over the number of machine
instructions considered, but it ended up being N^2 is practice.

This new version is more obviously O(N^2) (with N capped to 8 by
default) in hazard detection.  It does not attempt to be clever in
tracking register uses or defs (the previous cleverness here was a
source of bugs).

Once this is checked in, I'll extract out the `IsSuitableMemoryOp` and
`CanHoistLoadInst` lambda into member functions (they're too complicated
to be inline lambdas) and do some other related NFC cleanups.

Reviewers: reames, anna, atrick

Subscribers: mcrosier, llvm-commits

Differential Revision: https://reviews.llvm.org/D27592

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

8 years ago[ObjectYAML] Fixing a compiler warning
Chris Bieneman [Thu, 22 Dec 2016 22:58:07 +0000 (22:58 +0000)]
[ObjectYAML] Fixing a compiler warning

Accidentally re-defined the variable instead of setting it. Oops!

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

8 years ago[GlobalISel] More fix for the size vs. type typo. NFC.
Quentin Colombet [Thu, 22 Dec 2016 22:50:34 +0000 (22:50 +0000)]
[GlobalISel] More fix for the size vs. type typo. NFC.

I missed those in my previous commit (r290378).

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

8 years ago[ObjectYAML] Support for DWARF debug_info section
Chris Bieneman [Thu, 22 Dec 2016 22:44:27 +0000 (22:44 +0000)]
[ObjectYAML] Support for DWARF debug_info section

This patch adds support for YAML<->DWARF for debug_info sections.

This re-lands r290147, reverted in 290148, re-landed in r290204 after fixing the issue that caused bots to fail (thank you UBSan!), and reverted again in r290209 due to failures on big endian systems.

After adding support for preserving endianness, this should be good now.

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

8 years ago[AArch64] Simplify indexed-memory testcase. NFC.
Ahmed Bougacha [Thu, 22 Dec 2016 22:27:05 +0000 (22:27 +0000)]
[AArch64] Simplify indexed-memory testcase. NFC.

We're only testing the addressing mode on the stores; we don't
need to load/store pointers we can simply pass/return.

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

8 years ago[cfi] Emit jump tables as a function-level inline asm.
Evgeniy Stepanov [Thu, 22 Dec 2016 22:22:35 +0000 (22:22 +0000)]
[cfi] Emit jump tables as a function-level inline asm.

Use a dummy private function with inline asm calls instead of module
level asm blocks for CFI jumptables.

The main advantage is that now jumptable codegen can be affected by
the function attributes (like target_cpu on ARM). Module level asm
gets the default subtarget based on the target triple, which is often
not good enough.

This change also uses asm constraints/arguments to reference
jumptable targets and aliases directly. We no longer do asm name
mangling in an IR pass.

Differential Revision: https://reviews.llvm.org/D28012

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

8 years ago[ObjectYAML] Fixing big endian bots from r290381
Chris Bieneman [Thu, 22 Dec 2016 22:16:04 +0000 (22:16 +0000)]
[ObjectYAML] Fixing big endian bots from r290381

Bot URL:
http://lab.llvm.org:8011/builders/clang-s390x-linux/builds/2505

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

8 years ago[ObjectYAML] MachO support for endianness
Chris Bieneman [Thu, 22 Dec 2016 21:58:03 +0000 (21:58 +0000)]
[ObjectYAML] MachO support for endianness

This patch adds support to the macho<->yaml tools for preserving endianness in MachO structures and DWARF data.

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

8 years ago[MachineVerifier] Check that even generic vregs comply to regclass constraints.
Quentin Colombet [Thu, 22 Dec 2016 21:56:39 +0000 (21:56 +0000)]
[MachineVerifier] Check that even generic vregs comply to regclass constraints.

We used to not check generic vregs, but that is actually a mistake given
nothing in the GlobalISel pipeline is going to fix the constraints on
target specific instructions. Therefore, the target has to have them
right from the start.

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

8 years ago[AArch64] Change a test to use a generic instr instead of a target specific one.
Quentin Colombet [Thu, 22 Dec 2016 21:56:37 +0000 (21:56 +0000)]
[AArch64] Change a test to use a generic instr instead of a target specific one.

Target specific instructions have requirements that are not compatible
with what we want to test here. Namely, target specific instructions
must have their operands properly mapped on register classes.

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

8 years ago[MIRParser] Fix a typo in comment and error message.
Quentin Colombet [Thu, 22 Dec 2016 21:56:35 +0000 (21:56 +0000)]
[MIRParser] Fix a typo in comment and error message.

We have long switched from size to type.

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

8 years ago[AArch64][CallLowering] Constraint registers on target specific instruction
Quentin Colombet [Thu, 22 Dec 2016 21:56:31 +0000 (21:56 +0000)]
[AArch64][CallLowering] Constraint registers on target specific instruction

The InstructionSelect pass will not look at target specific instructions
since they are already selected. As a result, the operands of target
specific instructions must be properly constrained, because it is not
going to fix them.

This fixes invalid register classes on call instruction.

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

8 years ago[MIRParser] Non-generic virtual register may have a type.
Quentin Colombet [Thu, 22 Dec 2016 21:56:29 +0000 (21:56 +0000)]
[MIRParser] Non-generic virtual register may have a type.

When generic virtual registers get constrained, because of a use on a
target specific operation for instance, we end up with regular virtual
registers with a type and that's perfectly fine.

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

8 years ago[RegisterBankInfo] Allow to set a register class when nothing else is set
Quentin Colombet [Thu, 22 Dec 2016 21:56:26 +0000 (21:56 +0000)]
[RegisterBankInfo] Allow to set a register class when nothing else is set

This is going to be needed to be able to constraint register class on
target specific instruction while the RegBankSelect pass did not run
yet.

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

8 years ago[GlobalISel] Refactor the logic to constraint registers.
Quentin Colombet [Thu, 22 Dec 2016 21:56:19 +0000 (21:56 +0000)]
[GlobalISel] Refactor the logic to constraint registers.

Move the logic to constraint register from InstructionSelector to a
utility function. It will be required by other passes in the GlobalISel
pipeline.

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

8 years agoAMDGPU: Invert cmp + select with constant
Matt Arsenault [Thu, 22 Dec 2016 21:40:08 +0000 (21:40 +0000)]
AMDGPU: Invert cmp + select with constant

Canonicalize a select with a constant to the false side. This
enables more instruction shrinking opportunities since an
inline immediate can be used for the false side of v_cndmask_b32_e32.

This seems to usually be better but causes some code size regressions
in some tests.

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

8 years ago[PowerPC] Add ppc support to update_llc_test_checks.py, and ppc tests. NFC.
Tim Shen [Thu, 22 Dec 2016 20:59:39 +0000 (20:59 +0000)]
[PowerPC] Add ppc support to update_llc_test_checks.py, and ppc tests. NFC.

Reviewers: chandlerc, hfinkel, echristo, iteratee

Subscribers: mehdi_amini, nemanjai, llvm-commits

Differential Revision: https://reviews.llvm.org/D28036

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