Tom Stellard [Thu, 6 Apr 2017 17:41:41 +0000 (17:41 +0000)]
Merging r296698:
------------------------------------------------------------------------
r296698 | rnk | 2017-03-01 17:41:12 -0500 (Wed, 01 Mar 2017) | 10 lines
[Constant Hoisting] Avoid inserting instructions before EH pads
Now that terminators can be EH pads, this code needs to iterate over the
immediate dominators of the EH pad to find a valid insertion point.
Fix for PR32107
Patch by Robert Olliff!
Differential Revision: https://reviews.llvm.org/D30511
------------------------------------------------------------------------
git-svn-id: https://llvm.org/svn/llvm-project/llvm/branches/release_40@299670
91177308-0d34-0410-b5e6-
96231b3b80d8
Tom Stellard [Tue, 4 Apr 2017 18:38:19 +0000 (18:38 +0000)]
Merging r298705:
------------------------------------------------------------------------
r298705 | tstellar | 2017-03-24 12:13:18 -0400 (Fri, 24 Mar 2017) | 11 lines
stable-merge-request.sh: Add a script for submitting merge requests via bugzilla
Summary:
This script will automatically create a new stable merge request bug in
bugzilla for the given svn revision and release number.
Reviewers: hans
Subscribers: llvm-commits
Differential Revision: https://reviews.llvm.org/D30905
------------------------------------------------------------------------
git-svn-id: https://llvm.org/svn/llvm-project/llvm/branches/release_40@299455
91177308-0d34-0410-b5e6-
96231b3b80d8
Tom Stellard [Tue, 4 Apr 2017 15:23:53 +0000 (15:23 +0000)]
Merging r298551:
------------------------------------------------------------------------
r298551 | kzhuravl | 2017-03-22 17:48:18 -0400 (Wed, 22 Mar 2017) | 4 lines
[AMDGPU] Fix bug 31610
Differential Revision: https://reviews.llvm.org/D31258
------------------------------------------------------------------------
git-svn-id: https://llvm.org/svn/llvm-project/llvm/branches/release_40@299441
91177308-0d34-0410-b5e6-
96231b3b80d8
Tom Stellard [Tue, 4 Apr 2017 01:17:09 +0000 (01:17 +0000)]
Partial merge of r293110 into the 4.0 branch
Avoid printing optimization remarks from llc unless they are enabled.
Fixes http://llvm.org/PR32184
git-svn-id: https://llvm.org/svn/llvm-project/llvm/branches/release_40@299409
91177308-0d34-0410-b5e6-
96231b3b80d8
Tom Stellard [Thu, 23 Mar 2017 19:17:39 +0000 (19:17 +0000)]
Bump version to 4.0.1
git-svn-id: https://llvm.org/svn/llvm-project/llvm/branches/release_40@298635
91177308-0d34-0410-b5e6-
96231b3b80d8
Hans Wennborg [Tue, 7 Mar 2017 20:44:17 +0000 (20:44 +0000)]
ReleaseNotes: fix indent
git-svn-id: https://llvm.org/svn/llvm-project/llvm/branches/release_40@297204
91177308-0d34-0410-b5e6-
96231b3b80d8
Hans Wennborg [Tue, 7 Mar 2017 20:43:19 +0000 (20:43 +0000)]
ReleaseNotes: fix the VS version; follow-up to r297097
git-svn-id: https://llvm.org/svn/llvm-project/llvm/branches/release_40@297203
91177308-0d34-0410-b5e6-
96231b3b80d8
Hans Wennborg [Tue, 7 Mar 2017 17:36:53 +0000 (17:36 +0000)]
Merging r297075:
------------------------------------------------------------------------
r297075 | hans | 2017-03-06 13:10:40 -0800 (Mon, 06 Mar 2017) | 1 line
Disable gvn-hoist (PR32153)
------------------------------------------------------------------------
git-svn-id: https://llvm.org/svn/llvm-project/llvm/branches/release_40@297165
91177308-0d34-0410-b5e6-
96231b3b80d8
Hans Wennborg [Tue, 7 Mar 2017 17:33:14 +0000 (17:33 +0000)]
Merging r296992:
------------------------------------------------------------------------
r296992 | sanjoy | 2017-03-05 15:49:17 -0800 (Sun, 05 Mar 2017) | 7 lines
[SCEV] Decrease the recursion threshold for CompareValueComplexity
Fixes PR32142.
r287232 accidentally increased the recursion threshold for
CompareValueComplexity from 2 to 32. This change reverses that change
by introducing a separate flag for CompareValueComplexity's threshold.
------------------------------------------------------------------------
git-svn-id: https://llvm.org/svn/llvm-project/llvm/branches/release_40@297164
91177308-0d34-0410-b5e6-
96231b3b80d8
Hans Wennborg [Mon, 6 Mar 2017 23:43:34 +0000 (23:43 +0000)]
ReleaseNotes: reformulate compiler version change text
git-svn-id: https://llvm.org/svn/llvm-project/llvm/branches/release_40@297097
91177308-0d34-0410-b5e6-
96231b3b80d8
Renato Golin [Mon, 6 Mar 2017 22:56:55 +0000 (22:56 +0000)]
[notes] adding vulcan rename to release notes
git-svn-id: https://llvm.org/svn/llvm-project/llvm/branches/release_40@297090
91177308-0d34-0410-b5e6-
96231b3b80d8
Hans Wennborg [Thu, 2 Mar 2017 16:44:46 +0000 (16:44 +0000)]
Merging r296642:
------------------------------------------------------------------------
r296642 | hans | 2017-03-01 09:15:08 -0800 (Wed, 01 Mar 2017) | 5 lines
[GVNHoist] Don't hoist unsafe scalars at -Oz (PR31729)
Based on Aditya Kumar's patch:
Differential Revision: https://reviews.llvm.org/D29092
------------------------------------------------------------------------
git-svn-id: https://llvm.org/svn/llvm-project/llvm/branches/release_40@296761
91177308-0d34-0410-b5e6-
96231b3b80d8
Pekka Jaaskelainen [Wed, 1 Mar 2017 15:44:10 +0000 (15:44 +0000)]
Added pocl and TCE to releasenotes. Both of them now work with LLVM 4.0
git-svn-id: https://llvm.org/svn/llvm-project/llvm/branches/release_40@296633
91177308-0d34-0410-b5e6-
96231b3b80d8
Craig Topper [Wed, 1 Mar 2017 08:04:06 +0000 (08:04 +0000)]
ReleaseNotes: Add some X86 target bullets.
git-svn-id: https://llvm.org/svn/llvm-project/llvm/branches/release_40@296587
91177308-0d34-0410-b5e6-
96231b3b80d8
Hans Wennborg [Tue, 28 Feb 2017 19:32:31 +0000 (19:32 +0000)]
ReleaseNotes: mention the versioning scheme change
git-svn-id: https://llvm.org/svn/llvm-project/llvm/branches/release_40@296509
91177308-0d34-0410-b5e6-
96231b3b80d8
Hans Wennborg [Mon, 27 Feb 2017 20:53:28 +0000 (20:53 +0000)]
Merging r296093 and r296260:
------------------------------------------------------------------------
r296093 | ctopper | 2017-02-23 22:38:24 -0800 (Thu, 23 Feb 2017) | 1 line
[ExecutionDepsFix] Use range-based for loop. NFC
------------------------------------------------------------------------
------------------------------------------------------------------------
r296260 | ctopper | 2017-02-25 10:12:25 -0800 (Sat, 25 Feb 2017) | 18 lines
[ExecutionDepsFix] Don't make copies of LiveReg objects when collecting operands for soft instructions
Summary:
While collecting operands we make copies of the LiveReg objects which are stored in the LiveRegs array. If the instruction uses the same register multiple times we end up with multiple copies. Later we iterate through the collected list of LiveReg objects and merge DomainValues. In the process of doing this the merge function can change the contents of the original LiveReg object in the LiveRegs array, but not the copies that have been made. So when we get to the second usage of the register we end up seeing a stale copy of the LiveReg object.
To fix this I've stopped copying and now just store a pointer to the original LiveReg object. Another option might be to avoid adding the same register to the Regs array twice, but this approach seemed simpler.
The included test case exposes this bug due to an AVX-512 masked OR instruction using the same register for the passthru operand and one of the inputs to the OR operation.
Fixes PR30284.
Reviewers: RKSimon, stoklund, MatzeB, spatel, myatsina
Reviewed By: RKSimon
Subscribers: llvm-commits
Differential Revision: https://reviews.llvm.org/D30242
------------------------------------------------------------------------
git-svn-id: https://llvm.org/svn/llvm-project/llvm/branches/release_40@296380
91177308-0d34-0410-b5e6-
96231b3b80d8
Hans Wennborg [Mon, 27 Feb 2017 17:01:04 +0000 (17:01 +0000)]
Merging r295116:
------------------------------------------------------------------------
r295116 | dim | 2017-02-14 14:49:49 -0800 (Tue, 14 Feb 2017) | 18 lines
Disable wrapping llvm-xray YAML output
Summary:
The YAML output produced by llvm-xray is supposed to be wrapped at the
arbitrary default of 70 columns set by `yaml:Output`. Unfortunately,
the wrapping is rather unpredictable, and can easily go past the set
number of columns, depending on the execution environment.
To make the YAML output environment-independent, disable wrapping
instead.
Reviewers: dberris
Reviewed By: dberris
Subscribers: fhahn, llvm-commits
Differential Revision: https://reviews.llvm.org/D29962
------------------------------------------------------------------------
git-svn-id: https://llvm.org/svn/llvm-project/llvm/branches/release_40@296357
91177308-0d34-0410-b5e6-
96231b3b80d8
Simon Dardis [Mon, 27 Feb 2017 13:25:42 +0000 (13:25 +0000)]
[ReleaseNotes] Add MIPS release notes.
git-svn-id: https://llvm.org/svn/llvm-project/llvm/branches/release_40@296340
91177308-0d34-0410-b5e6-
96231b3b80d8
Hans Wennborg [Fri, 24 Feb 2017 23:48:15 +0000 (23:48 +0000)]
RelaseNotes: tweaks
git-svn-id: https://llvm.org/svn/llvm-project/llvm/branches/release_40@296202
91177308-0d34-0410-b5e6-
96231b3b80d8
Hans Wennborg [Fri, 24 Feb 2017 23:38:14 +0000 (23:38 +0000)]
ReleaseNotes: drop empty sections
git-svn-id: https://llvm.org/svn/llvm-project/llvm/branches/release_40@296200
91177308-0d34-0410-b5e6-
96231b3b80d8
Hans Wennborg [Fri, 24 Feb 2017 23:35:53 +0000 (23:35 +0000)]
ReleaseNotes: drop in-progress warning
git-svn-id: https://llvm.org/svn/llvm-project/llvm/branches/release_40@296199
91177308-0d34-0410-b5e6-
96231b3b80d8
Hans Wennborg [Fri, 24 Feb 2017 22:33:47 +0000 (22:33 +0000)]
Revert r288115 for PR31847.
------------------------------------------------------------------------
r288115 | abataev | 2016-11-29 09:21:14 +0100 (Tue, 29 Nov 2016) | 8 lines
[SLPVectorizer] Improved support of partial tree vectorization.
Currently SLP vectorizer tries to vectorize a binary operation and dies
immediately after unsuccessful the first unsuccessfull attempt. Patch
tries to improve the situation, trying to vectorize all binary
operations of all children nodes in the binop tree.
Differential Revision: https://reviews.llvm.org/D25517
------------------------------------------------------------------------
git-svn-id: https://llvm.org/svn/llvm-project/llvm/branches/release_40@296185
91177308-0d34-0410-b5e6-
96231b3b80d8
Hans Wennborg [Fri, 24 Feb 2017 18:56:41 +0000 (18:56 +0000)]
Merging r295990:
------------------------------------------------------------------------
r295990 | jvesely | 2017-02-23 08:12:21 -0800 (Thu, 23 Feb 2017) | 5 lines
AMDGPU/SI: Fix trunc i16 pattern
Hit on ASICs that support 16bit instructions.
Differential Revision: https://reviews.llvm.org/D30281
------------------------------------------------------------------------
git-svn-id: https://llvm.org/svn/llvm-project/llvm/branches/release_40@296158
91177308-0d34-0410-b5e6-
96231b3b80d8
Hans Wennborg [Fri, 24 Feb 2017 18:53:54 +0000 (18:53 +0000)]
Merging r296003:
------------------------------------------------------------------------
r296003 | mcrosier | 2017-02-23 10:49:03 -0800 (Thu, 23 Feb 2017) | 32 lines
[Reassociate] Add negated value of negative constant to the Duplicates list.
In OptimizeAdd, we scan the operand list to see if there are any common factors
between operands that can be factored out to reduce the number of multiplies
(e.g., 'A*A+A*B*C+D' -> 'A*(A+B*C)+D'). For each operand of the operand list, we
only consider unique factors (which is tracked by the Duplicate set). Now if we
find a factor that is a negative constant, we add the negated value as a factor
as well, because we can percolate the negate out. However, we mistakenly don't
add this negated constant to the Duplicates set.
Consider the expression A*2*-2 + B. Obviously, nothing to factor.
For the added value A*2*-2 we over count 2 as a factor without this change,
which causes the assert reported in PR30256. The problem is that this code is
assuming that all the multiply operands of the add are already reassociated.
This change avoids the issue by making OptimizeAdd tolerate multiplies which
haven't been completely optimized; this sort of works, but we're doing wasted
work: we'll end up revisiting the add later anyway.
Another possible approach would be to enforce RPO iteration order more strongly.
If we have RedoInsts, we process them immediately in RPO order, rather than
waiting until we've finished processing the whole function. Intuitively, it
seems like the natural approach: reassociation works on expression trees, so
the optimization only works in one direction. That said, I'm not sure how
practical that is given the current Reassociate; the "optimal" form for an
expression depends on its use list (see all the uses of "user_back()"), so
Reassociate is really an iterative optimization of sorts, so any changes here
would probably get messy.
PR30256
Differential Revision: https://reviews.llvm.org/D30228
------------------------------------------------------------------------
git-svn-id: https://llvm.org/svn/llvm-project/llvm/branches/release_40@296156
91177308-0d34-0410-b5e6-
96231b3b80d8
Hans Wennborg [Fri, 24 Feb 2017 18:37:22 +0000 (18:37 +0000)]
Merging r296030:
------------------------------------------------------------------------
r296030 | hans | 2017-02-23 14:29:00 -0800 (Thu, 23 Feb 2017) | 7 lines
Revert r282872 "CVP. Turn marking adds as no wrap on by default"
While not CVP's fault, this caused miscompiles (PR31181). Reverting
until those are resolved.
(This also reverts the follow-ups r288154 and r288161 which removed the
flag.)
------------------------------------------------------------------------
git-svn-id: https://llvm.org/svn/llvm-project/llvm/branches/release_40@296148
91177308-0d34-0410-b5e6-
96231b3b80d8
Hans Wennborg [Thu, 23 Feb 2017 18:39:15 +0000 (18:39 +0000)]
Merging r295762:
------------------------------------------------------------------------
r295762 | eugenis | 2017-02-21 12:17:34 -0800 (Tue, 21 Feb 2017) | 3 lines
Fix PR31896.
Address of an alias of a global with offset is incorrectly lowered as an address of the global (i.e. ignoring offset).
------------------------------------------------------------------------
git-svn-id: https://llvm.org/svn/llvm-project/llvm/branches/release_40@296002
91177308-0d34-0410-b5e6-
96231b3b80d8
Hans Wennborg [Thu, 23 Feb 2017 00:14:14 +0000 (00:14 +0000)]
Backport r293433, ARM: support `-mlong-calls` with AEABI TLS on ELF
Support lowering AEABI TLS access (__aeabi_read_tp) with long calls.
This requires adjusting the call sequence to use an indirect call to get
full addressability.
Resolves PR31769!
By Saleem Abdulrasool!
git-svn-id: https://llvm.org/svn/llvm-project/llvm/branches/release_40@295910
91177308-0d34-0410-b5e6-
96231b3b80d8
Hans Wennborg [Tue, 21 Feb 2017 19:01:56 +0000 (19:01 +0000)]
Merging r293273:
------------------------------------------------------------------------
r293273 | chandlerc | 2017-01-27 02:27:32 -0800 (Fri, 27 Jan 2017) | 19 lines
[LICM] When we are recomputing the alias sets for a subloop, we cannot
skip sub-subloops.
The logic to skip subloops dated from when this code was shared with the
cached case. Once it was factored out to only run in the case of
recomputed subloops it became a dangerous bug. If a subsubloop contained
an interfering instruction it would be silently skipped from the alias
sets for LICM.
With the old pass manager this was extremely hard to trigger as it would
require failing to visit these subloops with the LICM pass but then
visiting the outer loop somehow. I've not yet contrived any test case
that actually manages to trigger this.
But with the new pass manager we don't do the cross-loop caching hack
that the old PM does and so we recompute alias set information from
first principles. While this seems much cleaner and simpler it exposed
this bug and would subtly miscompile code due to failing to correctly
model the aliasing constraints of deeply nested loops.
------------------------------------------------------------------------
git-svn-id: https://llvm.org/svn/llvm-project/llvm/branches/release_40@295748
91177308-0d34-0410-b5e6-
96231b3b80d8
Hans Wennborg [Tue, 21 Feb 2017 18:53:27 +0000 (18:53 +0000)]
Merging r295486 and r295490:
------------------------------------------------------------------------
r295486 | adrian | 2017-02-17 11:42:32 -0800 (Fri, 17 Feb 2017) | 6 lines
Debug Info: Sort frame index expressions before emitting them.
This fixes PR31381, which caused an assertion and/or invalid debug info.
This affects debug variables that have multiple fragments in the MMI
side (i.e.: in the stack frame) table.
rdar://problem/
30571676
------------------------------------------------------------------------
------------------------------------------------------------------------
r295490 | adrian | 2017-02-17 12:02:26 -0800 (Fri, 17 Feb 2017) | 1 line
Fix windows bots by locking down the target triple on this testcase.
------------------------------------------------------------------------
git-svn-id: https://llvm.org/svn/llvm-project/llvm/branches/release_40@295747
91177308-0d34-0410-b5e6-
96231b3b80d8
Hans Wennborg [Tue, 21 Feb 2017 18:46:57 +0000 (18:46 +0000)]
Merging r295512:
------------------------------------------------------------------------
r295512 | matze | 2017-02-17 15:15:03 -0800 (Fri, 17 Feb 2017) | 8 lines
AArch64LoadStoreOptimizer: Correctly clear kill flags
When promoting the Load of a Store-Load pair to a COPY all kill flags
between the store and the load need to be cleared.
rdar://
30402435
Differential Revision: https://reviews.llvm.org/D30110
------------------------------------------------------------------------
git-svn-id: https://llvm.org/svn/llvm-project/llvm/branches/release_40@295744
91177308-0d34-0410-b5e6-
96231b3b80d8
Hans Wennborg [Tue, 21 Feb 2017 18:30:34 +0000 (18:30 +0000)]
ReleaseNotes: GVNHoist; by Sepastian Pop
git-svn-id: https://llvm.org/svn/llvm-project/llvm/branches/release_40@295743
91177308-0d34-0410-b5e6-
96231b3b80d8
Hans Wennborg [Thu, 16 Feb 2017 21:50:00 +0000 (21:50 +0000)]
Merging r293124:
------------------------------------------------------------------------
r293124 | mkuper | 2017-01-25 17:04:11 -0800 (Wed, 25 Jan 2017) | 9 lines
[LoopUnroll] Properly update loopinfo for runtime unrolling by 2
Even when we don't create a remainder loop (that is, when we unroll by 2), we
may duplicate nested loops into the remainder. This is complicated by the fact
the remainder may itself be either inserted into an outer loop, or at the top
level. In the latter case, we may need to create new top-level loops.
Differential Revision: https://reviews.llvm.org/D29156
------------------------------------------------------------------------
git-svn-id: https://llvm.org/svn/llvm-project/llvm/branches/release_40@295380
91177308-0d34-0410-b5e6-
96231b3b80d8
Hans Wennborg [Thu, 16 Feb 2017 21:17:54 +0000 (21:17 +0000)]
Merging r295230:
------------------------------------------------------------------------
r295230 | arnolds | 2017-02-15 12:43:43 -0800 (Wed, 15 Feb 2017) | 11 lines
AddressSanitizer: don't track swifterror memory addresses
They are register promoted by ISel and so it makes no sense to treat them as
memory.
Inserting calls to the thread sanitizer would also generate invalid IR.
You would hit:
"swifterror value can only be loaded and stored from, or as a swifterror
argument!"
------------------------------------------------------------------------
git-svn-id: https://llvm.org/svn/llvm-project/llvm/branches/release_40@295377
91177308-0d34-0410-b5e6-
96231b3b80d8
Hans Wennborg [Thu, 16 Feb 2017 21:15:37 +0000 (21:15 +0000)]
Merging r295215:
------------------------------------------------------------------------
r295215 | arnolds | 2017-02-15 10:57:06 -0800 (Wed, 15 Feb 2017) | 11 lines
ThreadSanitizer: don't track swifterror memory addresses
They are register promoted by ISel and so it makes no sense to treat them as
memory.
Inserting calls to the thread sanitizer would also generate invalid IR.
You would hit:
"swifterror value can only be loaded and stored from, or as a swifterror
argument!"
------------------------------------------------------------------------
git-svn-id: https://llvm.org/svn/llvm-project/llvm/branches/release_40@295376
91177308-0d34-0410-b5e6-
96231b3b80d8
Hans Wennborg [Thu, 16 Feb 2017 21:11:04 +0000 (21:11 +0000)]
Merging r295213:
------------------------------------------------------------------------
r295213 | mkuper | 2017-02-15 10:37:26 -0800 (Wed, 15 Feb 2017) | 10 lines
[DAG] Don't try to create an INSERT_SUBVECTOR with an illegal source
We currently can't legalize those, but we should really not be creating
them in the first place, since legalization would probably look similar to the
way we legalize CONCAT_VECTORS - basically replace the INSERT with a BUILD.
This fixes PR311956.
Differential Revision: https://reviews.llvm.org/D29961
------------------------------------------------------------------------
git-svn-id: https://llvm.org/svn/llvm-project/llvm/branches/release_40@295374
91177308-0d34-0410-b5e6-
96231b3b80d8
Kai Nacke [Thu, 16 Feb 2017 19:35:37 +0000 (19:35 +0000)]
Add external project LDC to release notes.
LDC, the LLVM-based D compiler, is already ready for LLVM 4.0.
git-svn-id: https://llvm.org/svn/llvm-project/llvm/branches/release_40@295367
91177308-0d34-0410-b5e6-
96231b3b80d8
Hans Wennborg [Thu, 16 Feb 2017 17:59:33 +0000 (17:59 +0000)]
Merging r292271:
------------------------------------------------------------------------
r292271 | aaron | 2017-01-17 21:48:31 +0000 (Tue, 17 Jan 2017) | 2 lines
Silence some Sphinx diagnostics in an attempt to get the documentation builder back to green (http://lab.llvm.org:8011/builders/llvm-sphinx-docs/builds/1895).
------------------------------------------------------------------------
git-svn-id: https://llvm.org/svn/llvm-project/llvm/branches/release_40@295344
91177308-0d34-0410-b5e6-
96231b3b80d8
Hans Wennborg [Wed, 15 Feb 2017 22:36:35 +0000 (22:36 +0000)]
Merging r294129:
------------------------------------------------------------------------
r294129 | gberry | 2017-02-05 10:28:14 -0800 (Sun, 05 Feb 2017) | 16 lines
[SelectionDAG] In InstrEmitter, handle EXTRACT_SUBREG of a physical register.
Summary:
Without this change, the getVR() call would hit an assert since it was
being passed a physical register.
Update the AArch64/ldst-opt.ll test with a case that triggers this
behavior by adding a run with strict-align, which causes an unaligned
STR XZR instruction to be split into byte stores, creating an
EXTRACT_SUBREG of XZR that triggers the original problem.
Reviewers: bogner, qcolombet, MatzeB, atrick
Subscribers: aemerson, mcrosier, llvm-commits
Differential Revision: https://reviews.llvm.org/D29495
------------------------------------------------------------------------
git-svn-id: https://llvm.org/svn/llvm-project/llvm/branches/release_40@295250
91177308-0d34-0410-b5e6-
96231b3b80d8
Hans Wennborg [Wed, 15 Feb 2017 22:34:24 +0000 (22:34 +0000)]
Merging r294003:
------------------------------------------------------------------------
r294003 | abataev | 2017-02-03 04:28:40 -0800 (Fri, 03 Feb 2017) | 8 lines
[SelectionDAG] Fix for PR30775: Assertion `NodeToMatch->getOpcode() !=
ISD::DELETED_NODE && "NodeToMatch was removed partway through
selection"' failed.
NodeToMatch can be modified during matching, but code does not handle
this situation.
Differential Revision: https://reviews.llvm.org/D29292
------------------------------------------------------------------------
git-svn-id: https://llvm.org/svn/llvm-project/llvm/branches/release_40@295249
91177308-0d34-0410-b5e6-
96231b3b80d8
Hans Wennborg [Wed, 15 Feb 2017 19:12:45 +0000 (19:12 +0000)]
Merging r294982:
------------------------------------------------------------------------
r294982 | arnolds | 2017-02-13 11:58:28 -0800 (Mon, 13 Feb 2017) | 6 lines
swiftcc: Don't emit tail calls from callers with swifterror parameters
Backends don't support this yet. They would have to move to the swifterror
register before the tail call to make sure it is live-in to the call.
rdar://
30495920
------------------------------------------------------------------------
git-svn-id: https://llvm.org/svn/llvm-project/llvm/branches/release_40@295219
91177308-0d34-0410-b5e6-
96231b3b80d8
Oren Ben Simhon [Wed, 15 Feb 2017 10:50:01 +0000 (10:50 +0000)]
Added a section about Regcall and Vectorcall calling convention changes.
git-svn-id: https://llvm.org/svn/llvm-project/llvm/branches/release_40@295165
91177308-0d34-0410-b5e6-
96231b3b80d8
Hans Wennborg [Wed, 15 Feb 2017 01:06:12 +0000 (01:06 +0000)]
Merging r294527:
------------------------------------------------------------------------
r294527 | arnolds | 2017-02-08 14:30:47 -0800 (Wed, 08 Feb 2017) | 14 lines
[ARM/AArch ISel] SwiftCC: First parameters that are marked swiftself are not 'this returns'
We mark X0 as preserved by a call that passes the returned parameter.
x0 = ...
fun(x0) // no implicit def of x0
This no longer is valid if we pass the parameter in a different register then
the returned value as is the case with a swiftself parameter (passed in x20).
x20 = ...
fun(x20) // there should be an implict def of x8
rdar://
30425845
------------------------------------------------------------------------
git-svn-id: https://llvm.org/svn/llvm-project/llvm/branches/release_40@295135
91177308-0d34-0410-b5e6-
96231b3b80d8
Hans Wennborg [Tue, 14 Feb 2017 17:39:39 +0000 (17:39 +0000)]
Merging r294551:
------------------------------------------------------------------------
r294551 | arnolds | 2017-02-08 17:52:17 -0800 (Wed, 08 Feb 2017) | 10 lines
SwiftCC: swifterror register cannot be as the base register
Functions that have a dynamic alloca require a base register which is defined to
be X19 on AArch64 and r6 on ARM. We have defined the swifterror register to be
the same register. Use a different callee save register for swifterror instead:
X21 on AArch64
R8 on ARM
rdar://
30433803
------------------------------------------------------------------------
git-svn-id: https://llvm.org/svn/llvm-project/llvm/branches/release_40@295079
91177308-0d34-0410-b5e6-
96231b3b80d8
Hans Wennborg [Tue, 14 Feb 2017 17:20:43 +0000 (17:20 +0000)]
ReleaseNotes: coroutines; by Gor Nishanov
git-svn-id: https://llvm.org/svn/llvm-project/llvm/branches/release_40@295070
91177308-0d34-0410-b5e6-
96231b3b80d8
Hans Wennborg [Tue, 14 Feb 2017 17:19:38 +0000 (17:19 +0000)]
ReleaseNotes: llvm-cov blurb; by Vedant Kumar
git-svn-id: https://llvm.org/svn/llvm-project/llvm/branches/release_40@295069
91177308-0d34-0410-b5e6-
96231b3b80d8
Mehdi Amini [Tue, 14 Feb 2017 04:49:31 +0000 (04:49 +0000)]
[ThinLTO] Make a copy of buffer identifier in ThinLTOCodeGenerator
This is anticipating a crash with ThinLTO and Xcode 8.3.
git-svn-id: https://llvm.org/svn/llvm-project/llvm/branches/release_40@295024
91177308-0d34-0410-b5e6-
96231b3b80d8
Dylan McKay [Fri, 10 Feb 2017 23:13:12 +0000 (23:13 +0000)]
Add release notes for the AVR backend
git-svn-id: https://llvm.org/svn/llvm-project/llvm/branches/release_40@294803
91177308-0d34-0410-b5e6-
96231b3b80d8
Hans Wennborg [Fri, 10 Feb 2017 22:42:53 +0000 (22:42 +0000)]
ReleaseNotes: ADCE; patch by David Callahan
git-svn-id: https://llvm.org/svn/llvm-project/llvm/branches/release_40@294797
91177308-0d34-0410-b5e6-
96231b3b80d8
Matthias Braun [Thu, 9 Feb 2017 23:25:27 +0000 (23:25 +0000)]
ReleaseNotes.rst: Add a section about .mir testing
git-svn-id: https://llvm.org/svn/llvm-project/llvm/branches/release_40@294656
91177308-0d34-0410-b5e6-
96231b3b80d8
Matthias Braun [Thu, 9 Feb 2017 21:45:33 +0000 (21:45 +0000)]
RegisterCoalescer: Fix joinReservedPhysReg()
Merging r294268:
joinReservedPhysReg() can only deal with a liverange in a single basic
block when copying from a vreg into a physreg.
See also rdar://
30306405
Differential Revision: https://reviews.llvm.org/D29436
Fixes http://llvm.org/PR31889
git-svn-id: https://llvm.org/svn/llvm-project/llvm/branches/release_40@294631
91177308-0d34-0410-b5e6-
96231b3b80d8
Matthias Braun [Thu, 9 Feb 2017 21:45:29 +0000 (21:45 +0000)]
RegisterCoalescer: Cleanup joinReservedPhysReg(); NFC
Merging r293856:
- Factor out a common subexpression
- Add some helpful comments
- Fix printing of a register in a debug message
Preparation for http://llvm.org/PR31889
git-svn-id: https://llvm.org/svn/llvm-project/llvm/branches/release_40@294630
91177308-0d34-0410-b5e6-
96231b3b80d8
Hans Wennborg [Thu, 9 Feb 2017 00:13:15 +0000 (00:13 +0000)]
build_llvm_package.bat: remove lldb, as it doesn't work
git-svn-id: https://llvm.org/svn/llvm-project/llvm/branches/release_40@294535
91177308-0d34-0410-b5e6-
96231b3b80d8
Hans Wennborg [Wed, 8 Feb 2017 17:28:49 +0000 (17:28 +0000)]
Docs: drop minor version
git-svn-id: https://llvm.org/svn/llvm-project/llvm/branches/release_40@294485
91177308-0d34-0410-b5e6-
96231b3b80d8
Hans Wennborg [Wed, 8 Feb 2017 17:14:38 +0000 (17:14 +0000)]
Merging r292949:
------------------------------------------------------------------------
r292949 | rnk | 2017-01-24 08:57:55 -0800 (Tue, 24 Jan 2017) | 6 lines
[CodeView] Fix off-by-one error in def range gap emission
Also fixes a much worse bug where we emitted the wrong gap size for the
def range uncovered by the test for this issue.
Fixes PR31726.
------------------------------------------------------------------------
git-svn-id: https://llvm.org/svn/llvm-project/llvm/branches/release_40@294479
91177308-0d34-0410-b5e6-
96231b3b80d8
Hans Wennborg [Wed, 8 Feb 2017 17:04:11 +0000 (17:04 +0000)]
Release notes for ilist changes, by Duncan
git-svn-id: https://llvm.org/svn/llvm-project/llvm/branches/release_40@294478
91177308-0d34-0410-b5e6-
96231b3b80d8
Hans Wennborg [Wed, 8 Feb 2017 17:02:53 +0000 (17:02 +0000)]
Merging r294349 and r294357:
------------------------------------------------------------------------
r294349 | dexonsmith | 2017-02-07 13:03:50 -0800 (Tue, 07 Feb 2017) | 12 lines
ADT: Add explicit conversions for reverse ilist iterators
Add explicit conversions between forward and reverse ilist iterators.
These follow the conversion conventions of std::reverse_iterator, which
are off-by-one: the newly-constructed "reverse" iterator dereferences to
the previous node of the one sent in. This has the benefit of
converting reverse ranges in place:
- If [I, E) is a valid range,
- then [reverse(E), reverse(I)) gives the same range in reverse order.
ilist_iterator::getReverse() is unchanged: it returns a reverse iterator
to the *same* node.
------------------------------------------------------------------------
------------------------------------------------------------------------
r294357 | dblaikie | 2017-02-07 13:31:03 -0800 (Tue, 07 Feb 2017) | 1 line
Fix some missing negations in the traits checking from r294349
------------------------------------------------------------------------
git-svn-id: https://llvm.org/svn/llvm-project/llvm/branches/release_40@294477
91177308-0d34-0410-b5e6-
96231b3b80d8
Hans Wennborg [Wed, 8 Feb 2017 16:50:40 +0000 (16:50 +0000)]
Merging r294348:
------------------------------------------------------------------------
r294348 | hans | 2017-02-07 12:37:45 -0800 (Tue, 07 Feb 2017) | 6 lines
[X86] Disable conditional tail calls (PR31257)
They are currently modelled incorrectly (as calls, which clobber
registers, confusing e.g. Machine Copy Propagation).
Reverting until we figure out the proper solution.
------------------------------------------------------------------------
git-svn-id: https://llvm.org/svn/llvm-project/llvm/branches/release_40@294476
91177308-0d34-0410-b5e6-
96231b3b80d8
Hans Wennborg [Wed, 8 Feb 2017 16:47:33 +0000 (16:47 +0000)]
Forgot to add this in r294473
git-svn-id: https://llvm.org/svn/llvm-project/llvm/branches/release_40@294474
91177308-0d34-0410-b5e6-
96231b3b80d8
Hans Wennborg [Wed, 8 Feb 2017 16:42:21 +0000 (16:42 +0000)]
MachineCopyPropagation: Respect implicit operands of COPY
Cherry pick llvm r294088 to 4.0 branch with slight changes to the way
undef operands are handled.
git-svn-id: https://llvm.org/svn/llvm-project/llvm/branches/release_40@294473
91177308-0d34-0410-b5e6-
96231b3b80d8
Hans Wennborg [Tue, 7 Feb 2017 21:15:12 +0000 (21:15 +0000)]
Merging r294318:
------------------------------------------------------------------------
r294318 | adrian | 2017-02-07 09:35:41 -0800 (Tue, 07 Feb 2017) | 12 lines
Fix the bitcode upgrade for DIGlobalVariable in a DIImportedEntity context.
The bitcode upgrade for DIGlobalVariable unconditionally wrapped
DIGlobalVariables in a DIGlobalVariableExpression. When a
DIGlobalVariable is referenced by a DIImportedEntity, however, this is
wrong. This patch fixes the bitcode upgrade by deferring the creation
of DIGlobalVariableExpressions until we know the context of the
DIGlobalVariable.
<rdar://problem/
30134279>
Differential Revision: https://reviews.llvm.org/D29349
------------------------------------------------------------------------
git-svn-id: https://llvm.org/svn/llvm-project/llvm/branches/release_40@294352
91177308-0d34-0410-b5e6-
96231b3b80d8
Hans Wennborg [Tue, 7 Feb 2017 19:09:04 +0000 (19:09 +0000)]
Merging r293017 and r294267:
------------------------------------------------------------------------
r293017 | chapuni | 2017-01-24 20:26:29 -0800 (Tue, 24 Jan 2017) | 5 lines
Rewind instantiations of OuterAnalysisManagerProxy in r289317, r291651, and r291662.
I found root class should be instantiated for variadic tempate to instantiate static member explicitly.
This will fix failures in mingw DLL build.
------------------------------------------------------------------------
------------------------------------------------------------------------
r294267 | chandlerc | 2017-02-06 17:50:48 -0800 (Mon, 06 Feb 2017) | 18 lines
Revert r293017 and fix the actual underlying issue.
The patch committed in r293017, as discussed on the list, doesn't really
make sense but was causing an actual issue to go away.
The issue turns out to be that in one place the extra template arguments
were dropped from the OuterAnalysisManagerProxy. This in turn caused the
types used in one set of places to access the key to be completely
different from the types used in another set of places for both Loop and
CGSCC cases where there are extra arguments.
I have literally no idea how anything seemed to work with this bug in
place. It blows my mind. But it did except for mingw64 in a DLL build.
I've added a really handy static assert that helps ensure we don't break
this in the future. It immediately diagnoses the issue with a compile
failure and a very clear error message. Much better that staring at
backtraces on a build bot. =]
------------------------------------------------------------------------
git-svn-id: https://llvm.org/svn/llvm-project/llvm/branches/release_40@294335
91177308-0d34-0410-b5e6-
96231b3b80d8
Hans Wennborg [Mon, 6 Feb 2017 21:27:55 +0000 (21:27 +0000)]
Merging r294203:
------------------------------------------------------------------------
r294203 | john.brawn | 2017-02-06 10:07:20 -0800 (Mon, 06 Feb 2017) | 9 lines
[AArch64] Fix incorrect MachinePointerInfo in splitStoreSplat
When splitting up one store into several in splitStoreSplat we have to
make sure we get the MachinePointerInfo right, otherwise alias
analysis thinks they all store to the same location. This can then
cause invalid scheduling later on.
Differential Revision: https://reviews.llvm.org/D29446
------------------------------------------------------------------------
git-svn-id: https://llvm.org/svn/llvm-project/llvm/branches/release_40@294242
91177308-0d34-0410-b5e6-
96231b3b80d8
Dimitry Andric [Sun, 5 Feb 2017 12:01:07 +0000 (12:01 +0000)]
Merging r294102:
------------------------------------------------------------------------
r294102 | dim | 2017-02-04 23:24:55 +0100 (Sat, 04 Feb 2017) | 13 lines
Add lld to the test-release.sh script
Building lld is enabled by default, but it can be disabled using the
-no-lld option.
Reviewers: tstellarAMD, rengolin, hans
Reviewed By: hans
Subscribers: grosser, wdng, emaste, llvm-commits
Differential Revision: https://reviews.llvm.org/D29539
------------------------------------------------------------------------
git-svn-id: https://llvm.org/svn/llvm-project/llvm/branches/release_40@294123
91177308-0d34-0410-b5e6-
96231b3b80d8
Hans Wennborg [Thu, 2 Feb 2017 22:19:34 +0000 (22:19 +0000)]
Merging r293345:
------------------------------------------------------------------------
r293345 | spatel | 2017-01-27 15:26:27 -0800 (Fri, 27 Jan 2017) | 19 lines
[InstCombine] move icmp transforms that might be recognized as min/max and inf-loop (PR31751)
This is a minimal patch to avoid the infinite loop in:
https://llvm.org/bugs/show_bug.cgi?id=31751
But the general problem is bigger: we're not canonicalizing all of the min/max forms reported
by value tracking's matchSelectPattern(), and we don't define min/max consistently. Some code
uses matchSelectPattern(), other code uses matchers like m_Umax, and others have their own
inline definitions which may be subtly different from any of the above.
The reason that the test cases in this patch need a cast op to trigger is because we don't
(yet) canonicalize all min/max forms based on matchSelectPattern() in
canonicalizeMinMaxWithConstant(), but we do make min/max+cast transforms based on
matchSelectPattern() in visitSelectInst().
The location of the icmp transforms that trigger the inf-loop seems arbitrary at best, so
I'm moving those behind the min/max fence in visitICmpInst() as the quick fix.
------------------------------------------------------------------------
git-svn-id: https://llvm.org/svn/llvm-project/llvm/branches/release_40@293947
91177308-0d34-0410-b5e6-
96231b3b80d8
Hans Wennborg [Thu, 2 Feb 2017 21:44:30 +0000 (21:44 +0000)]
Merging r292167:
------------------------------------------------------------------------
r292167 | davide | 2017-01-16 14:01:41 -0800 (Mon, 16 Jan 2017) | 3 lines
[llvm-objdump] Dump PT_OPENBSD_{BOOTDATA,RANDOMIZE,WXNEEDED}.
PR: 31641
------------------------------------------------------------------------
Merging r292169:
------------------------------------------------------------------------
r292169 | davide | 2017-01-16 14:58:26 -0800 (Mon, 16 Jan 2017) | 3 lines
[llvm-objdump] Dump PT_GNU_RELRO as part of -p.
PR: 31641
------------------------------------------------------------------------
Merging r292170:
------------------------------------------------------------------------
r292170 | davide | 2017-01-16 15:13:46 -0800 (Mon, 16 Jan 2017) | 3 lines
[llvm-objdump] Dump PT_NOTE as part of -p.
PR: 31641
------------------------------------------------------------------------
git-svn-id: https://llvm.org/svn/llvm-project/llvm/branches/release_40@293942
91177308-0d34-0410-b5e6-
96231b3b80d8
Hans Wennborg [Thu, 2 Feb 2017 21:34:25 +0000 (21:34 +0000)]
Merging r293635:
------------------------------------------------------------------------
r293635 | nha | 2017-01-31 06:35:37 -0800 (Tue, 31 Jan 2017) | 16 lines
[DAGCombine] require UnsafeFPMath for re-association of addition
Summary:
The affected transforms all implicitly use associativity of addition,
for which we usually require unsafe math to be enabled.
The "Aggressive" flag is only meant to convey information about the
performance of the fused ops relative to a fmul+fadd sequence.
Fixes Bug 31626.
Reviewers: spatel, hfinkel, mehdi_amini, arsenm, tstellarAMD
Subscribers: jholewinski, nemanjai, wdng, llvm-commits
Differential Revision: https://reviews.llvm.org/D28675
------------------------------------------------------------------------
git-svn-id: https://llvm.org/svn/llvm-project/llvm/branches/release_40@293940
91177308-0d34-0410-b5e6-
96231b3b80d8
Hans Wennborg [Wed, 1 Feb 2017 22:00:37 +0000 (22:00 +0000)]
Merging r293542:
------------------------------------------------------------------------
r293542 | arsenm | 2017-01-30 11:50:17 -0800 (Mon, 30 Jan 2017) | 7 lines
LSR: Don't drop address space when type doesn't match
For targets with different addressing modes in each address space,
if this is dropped querying isLegalAddressingMode later with this
will give a nonsense result, breaking the isLegalUse assertions.
This is a candidate for the 4.0 release branch.
------------------------------------------------------------------------
git-svn-id: https://llvm.org/svn/llvm-project/llvm/branches/release_40@293819
91177308-0d34-0410-b5e6-
96231b3b80d8
Hans Wennborg [Wed, 1 Feb 2017 19:45:51 +0000 (19:45 +0000)]
Merging r293730:
------------------------------------------------------------------------
r293730 | matze | 2017-01-31 17:31:36 -0800 (Tue, 31 Jan 2017) | 3 lines
MCMacho: Allow __thread_ptr section after dwarf sections
Differential Revision: https://reviews.llvm.org/D29315
------------------------------------------------------------------------
git-svn-id: https://llvm.org/svn/llvm-project/llvm/branches/release_40@293807
91177308-0d34-0410-b5e6-
96231b3b80d8
Hans Wennborg [Wed, 1 Feb 2017 19:41:46 +0000 (19:41 +0000)]
Merging r293673:
------------------------------------------------------------------------
r293673 | matze | 2017-01-31 10:37:53 -0800 (Tue, 31 Jan 2017) | 6 lines
InterleaveAccessPass: Avoid constructing invalid shuffle masks
Fix a bug where we would construct shufflevector instructions addressing
invalid elements.
Differential Revision: https://reviews.llvm.org/D29313
------------------------------------------------------------------------
git-svn-id: https://llvm.org/svn/llvm-project/llvm/branches/release_40@293805
91177308-0d34-0410-b5e6-
96231b3b80d8
Hans Wennborg [Wed, 1 Feb 2017 19:40:39 +0000 (19:40 +0000)]
Merging r293309:
------------------------------------------------------------------------
r293309 | mssimpso | 2017-01-27 09:33:16 -0800 (Fri, 27 Jan 2017) | 20 lines
[ARM/AArch64] Relocate and update InterleavedAccessPass tests (NFC)
The interleaved access pass is an IR-to-IR transformation that runs before code
generation. It matches interleaved memory operations to target-specific
intrinsics (that are later lowered to load and store multiple instructions on
ARM/AArch64). We place tests for similar passes (e.g., GlobalMergePass) under
test/Transforms. This patch moves the InterleavedAccessPass tests out of
test/CodeGen and into target-specific directories under
test/Transforms/InterleavedAccess.
Although the pass is an IR pass, many of the existing tests were llc tests
rather opt tests. For example, the tests would check for ldN/stN instructions
generated by llc rather than the intrinsic calls the pass actually inserts.
Thus, this patch updates all tests to be opt tests that check for the inserted
intrinsics. We already have separate CodeGen tests that ensure we lower the
interleaved access intrinsics to their corresponding ldN/stN instructions. In
addition to migrating the tests to opt, this patch also performs some minor
clean-up (to ensure consistent naming, etc.).
Differential Revision: https://reviews.llvm.org/D29184
------------------------------------------------------------------------
git-svn-id: https://llvm.org/svn/llvm-project/llvm/branches/release_40@293804
91177308-0d34-0410-b5e6-
96231b3b80d8
Hans Wennborg [Wed, 1 Feb 2017 18:42:29 +0000 (18:42 +0000)]
Merging r293727:
------------------------------------------------------------------------
r293727 | davide | 2017-01-31 17:01:22 -0800 (Tue, 31 Jan 2017) | 3 lines
[IPSCCP] Teach how to not propagate return values of naked functions.
Differential Revision: https://reviews.llvm.org/D29360
------------------------------------------------------------------------
git-svn-id: https://llvm.org/svn/llvm-project/llvm/branches/release_40@293796
91177308-0d34-0410-b5e6-
96231b3b80d8
Hans Wennborg [Wed, 1 Feb 2017 16:56:48 +0000 (16:56 +0000)]
Merging r293658:
------------------------------------------------------------------------
r293658 | arnolds | 2017-01-31 09:53:49 -0800 (Tue, 31 Jan 2017) | 1 line
Don't combine stores to a swifterror pointer operand to a different type
------------------------------------------------------------------------
git-svn-id: https://llvm.org/svn/llvm-project/llvm/branches/release_40@293781
91177308-0d34-0410-b5e6-
96231b3b80d8
Hans Wennborg [Wed, 1 Feb 2017 16:54:47 +0000 (16:54 +0000)]
Merging r293230:
------------------------------------------------------------------------
r293230 | yuyichao | 2017-01-26 15:50:18 -0800 (Thu, 26 Jan 2017) | 11 lines
CMake is funky on detecting Intel 17 as GCC compatible.
Summary: This adds a fallback in case that the Intel compiler is failed to be detected correctly.
Reviewers: chapuni
Reviewed By: chapuni
Subscribers: llvm-commits, mgorny
Differential Revision: https://reviews.llvm.org/D27610
------------------------------------------------------------------------
git-svn-id: https://llvm.org/svn/llvm-project/llvm/branches/release_40@293780
91177308-0d34-0410-b5e6-
96231b3b80d8
Hans Wennborg [Tue, 31 Jan 2017 18:33:00 +0000 (18:33 +0000)]
Merging r293629:
------------------------------------------------------------------------
r293629 | sbaranga | 2017-01-31 06:04:15 -0800 (Tue, 31 Jan 2017) | 15 lines
[InstCombine] Make sure that LHS and RHS have the same type in
transformToIndexedCompare
If they don't have the same type, the size of the constant
index would need to be adjusted (and this wouldn't be always
possible).
Alternatively we could try the analysis with the initial
RHS value, which would guarantee that the two sides have
the same type. However it is unlikely that in practice this
would pass our transformation requirements.
Fixes PR31808 (https://llvm.org/bugs/show_bug.cgi?id=31808).
------------------------------------------------------------------------
git-svn-id: https://llvm.org/svn/llvm-project/llvm/branches/release_40@293669
91177308-0d34-0410-b5e6-
96231b3b80d8
Hans Wennborg [Tue, 31 Jan 2017 18:23:49 +0000 (18:23 +0000)]
Merging r292117:
------------------------------------------------------------------------
r292117 | sdardis | 2017-01-16 05:55:58 -0800 (Mon, 16 Jan 2017) | 14 lines
[mips] Correct c.cond.fmt instruction definition.
Permit explicit $fcc<X> operand in c.cond.fmt instruction.
Add c.cond.fmt to the MIPS to microMIPS instruction mapping table.
Check that $fcc1 - $fcc7 are unusable for MIPS-I to MIPS-III for
c.cond.fmt, bc1t, bc1f.
Reviewers: seanbruno, zoran.jovanovic, vkalintiris
Differential Revision: https://reviews.llvm.org/D24510
------------------------------------------------------------------------
git-svn-id: https://llvm.org/svn/llvm-project/llvm/branches/release_40@293665
91177308-0d34-0410-b5e6-
96231b3b80d8
Hans Wennborg [Tue, 31 Jan 2017 18:21:40 +0000 (18:21 +0000)]
Merging r292624:
------------------------------------------------------------------------
r292624 | petarj | 2017-01-20 09:53:30 -0800 (Fri, 20 Jan 2017) | 9 lines
[mips] Fix debug information for __thread variable
This patch fixes debug information for __thread variable on Mips
using .dtprelword and .dtpreldword directives.
Patch by Aleksandar Beserminji.
Differential Revision: http://reviews.llvm.org/D28770
------------------------------------------------------------------------
git-svn-id: https://llvm.org/svn/llvm-project/llvm/branches/release_40@293664
91177308-0d34-0410-b5e6-
96231b3b80d8
Hans Wennborg [Tue, 31 Jan 2017 17:23:10 +0000 (17:23 +0000)]
Merging r293417:
------------------------------------------------------------------------
r293417 | jhibbits | 2017-01-28 20:55:57 -0800 (Sat, 28 Jan 2017) | 16 lines
Add some Book-E instructions to the asm parser and printer.
Summary:
Adds the following instructions:
* mfpmr
* mtpmr
* icblc
* icblq
* icbtls
Fix the scheduling for mtspr on e5500, which uses CFX0, instead of
SFX0/SFX1 as on e500mc.
Addresses PR 31538.
Differential Revision: https://reviews.llvm.org/D29002
------------------------------------------------------------------------
git-svn-id: https://llvm.org/svn/llvm-project/llvm/branches/release_40@293651
91177308-0d34-0410-b5e6-
96231b3b80d8
Hans Wennborg [Tue, 31 Jan 2017 17:02:48 +0000 (17:02 +0000)]
Merging r293522:
------------------------------------------------------------------------
r293522 | bogner | 2017-01-30 10:29:46 -0800 (Mon, 30 Jan 2017) | 8 lines
SDAG: Update ChainNodesMatched during UpdateChains if a node is replaced
Previously, we would hit UB (or the ISD::DELETED_NODE assert) if we
happened to replace a node during UpdateChains, because it would be
left in the list we were iterating over. This nulls out the pointer
when that happens so that we can avoid the issue.
Fixes llvm.org/PR31710
------------------------------------------------------------------------
git-svn-id: https://llvm.org/svn/llvm-project/llvm/branches/release_40@293650
91177308-0d34-0410-b5e6-
96231b3b80d8
Hans Wennborg [Tue, 31 Jan 2017 00:39:51 +0000 (00:39 +0000)]
Merging r293021:
------------------------------------------------------------------------
r293021 | chapuni | 2017-01-24 21:26:23 -0800 (Tue, 24 Jan 2017) | 4 lines
Ignore llvm/test/tools/llvm-symbolizer/coff-exports.test on mingw.
FIXME: Demangler could behave along not host but target.
For example, assume host=mingw, target=msc.
------------------------------------------------------------------------
git-svn-id: https://llvm.org/svn/llvm-project/llvm/branches/release_40@293575
91177308-0d34-0410-b5e6-
96231b3b80d8
Hans Wennborg [Fri, 27 Jan 2017 22:55:50 +0000 (22:55 +0000)]
Merging r291918:
------------------------------------------------------------------------
r291918 | krasin | 2017-01-13 09:30:10 -0800 (Fri, 13 Jan 2017) | 13 lines
Fix UBSan bots by blacklisting bits/stl_tree.h.
Summary:
libstdc++ has some undefined behavior in bits/stl_tree.h that
has recently became excercised by some of the LLVM code.
Given that fixing libstdc++ will take years, adding the file
into a blacklist to fix bots seems like a necessity.
Reviewers: vitalybuka
Subscribers: llvm-commits, mgorny
Differential Revision: https://reviews.llvm.org/D28686
------------------------------------------------------------------------
git-svn-id: https://llvm.org/svn/llvm-project/llvm/branches/release_40@293342
91177308-0d34-0410-b5e6-
96231b3b80d8
Evandro Menezes [Fri, 27 Jan 2017 20:57:35 +0000 (20:57 +0000)]
[AArch64] Rename 'no-quad-ldst-pairs' to 'slow-paired-128'
In order to follow the pattern of the existing 'slow-misaligned-128store'
option, rename the option 'no-quad-ldst-pairs' to 'slow-paired-128'.
git-svn-id: https://llvm.org/svn/llvm-project/llvm/branches/release_40@293332
91177308-0d34-0410-b5e6-
96231b3b80d8
Matt Arsenault [Fri, 27 Jan 2017 20:21:31 +0000 (20:21 +0000)]
Merging r293310:
------------------------------------------------------------------------
r293310 | arsenm | 2017-01-27 09:42:26 -0800 (Fri, 27 Jan 2017) | 8 lines
AMDGPU: Enable FeatureFlatForGlobal on Volcanic Islands
Accomplishes what r292982 was supposed to, which ended up
only really making the necessary test changes.
This should be applied to the 4.0 branch.
Patch by Vedran Miletić <vedran@miletic.net>
------------------------------------------------------------------------
git-svn-id: https://llvm.org/svn/llvm-project/llvm/branches/release_40@293329
91177308-0d34-0410-b5e6-
96231b3b80d8
Matt Arsenault [Fri, 27 Jan 2017 19:26:48 +0000 (19:26 +0000)]
Merging r292982:
------------------------------------------------------------------------
r292982 | arsenm | 2017-01-24 14:02:15 -0800 (Tue, 24 Jan 2017) | 8 lines
Enable FeatureFlatForGlobal on Volcanic Islands
This switches to the workaround that HSA defaults to
for the mesa path.
This should be applied to the 4.0 branch.
Patch by Vedran Miletić <vedran@miletic.net>
------------------------------------------------------------------------
git-svn-id: https://llvm.org/svn/llvm-project/llvm/branches/release_40@293326
91177308-0d34-0410-b5e6-
96231b3b80d8
Matt Arsenault [Fri, 27 Jan 2017 18:39:19 +0000 (18:39 +0000)]
Merging r292473:
------------------------------------------------------------------------
r292473 | arsenm | 2017-01-18 22:35:27 -0800 (Wed, 18 Jan 2017) | 9 lines
AMDGPU: Disable some fneg combines unless nsz
For -(x + y) -> (-x) + (-y), if x == -y, this would
change the result from -0.0 to 0.0. Since the fma/fmad
combine is an extension of this problem it also
applies there.
fmul should be fine, and I don't think any of the unary
operators or conversions should be a problem either.
------------------------------------------------------------------------
git-svn-id: https://llvm.org/svn/llvm-project/llvm/branches/release_40@293319
91177308-0d34-0410-b5e6-
96231b3b80d8
Matt Arsenault [Fri, 27 Jan 2017 18:31:33 +0000 (18:31 +0000)]
Merging r292472:
------------------------------------------------------------------------
r292472 | arsenm | 2017-01-18 22:04:12 -0800 (Wed, 18 Jan 2017) | 5 lines
AMDGPU: Remove modifiers from v_div_scale_*
They seem to produce nonsense results when used.
This should be applied to the release branch.
------------------------------------------------------------------------
git-svn-id: https://llvm.org/svn/llvm-project/llvm/branches/release_40@293317
91177308-0d34-0410-b5e6-
96231b3b80d8
Hans Wennborg [Fri, 27 Jan 2017 17:13:59 +0000 (17:13 +0000)]
Merging r293259:
------------------------------------------------------------------------
r293259 | compnerd | 2017-01-26 19:41:53 -0800 (Thu, 26 Jan 2017) | 11 lines
ARM: fix vectorized division on WoA
The Windows on ARM target uses custom division for normal division as
the backend needs to insert division-by-zero checks. However, it is
designed to only handle non-vectorized division. ARM has custom
lowering for vectorized division as that can avoid loading registers
with the values and invoke a division routine for each one, preferring
to lower using NEON instructions. Fall back to the custom lowering for
the NEON instructions if we encounter a vectorized division.
Resolves PR31778!
------------------------------------------------------------------------
git-svn-id: https://llvm.org/svn/llvm-project/llvm/branches/release_40@293306
91177308-0d34-0410-b5e6-
96231b3b80d8
Hans Wennborg [Fri, 27 Jan 2017 16:37:00 +0000 (16:37 +0000)]
Merging r292712 and r292713:
------------------------------------------------------------------------
r292712 | ctopper | 2017-01-20 22:59:35 -0800 (Fri, 20 Jan 2017) | 1 line
[X86] Add test cases that show bad commuting being allowed to create a phsub operation.
------------------------------------------------------------------------
------------------------------------------------------------------------
r292713 | ctopper | 2017-01-20 22:59:38 -0800 (Fri, 20 Jan 2017) | 3 lines
[X86] Don't allow commuting to form phsub operations.
Fixes PR31714.
------------------------------------------------------------------------
git-svn-id: https://llvm.org/svn/llvm-project/llvm/branches/release_40@293299
91177308-0d34-0410-b5e6-
96231b3b80d8
Hans Wennborg [Fri, 27 Jan 2017 16:17:56 +0000 (16:17 +0000)]
Merging r292516:
------------------------------------------------------------------------
r292516 | rserge | 2017-01-19 12:24:23 -0800 (Thu, 19 Jan 2017) | 14 lines
[XRay][Arm] Repair XRay table emission on Arm32 and add tests to identify such problem earlier
Summary:
Emission of XRay table was occasionally disabled for Arm32, but this bug was not then detected because earlier (also by mistake) testing of XRay was occasionally disabled on 32-bit Arm targets. This patch should fix that problem and detect such problems in the future.
This patch is one of a series, see also
- https://reviews.llvm.org/D28623
Reviewers: rengolin, dberris
Reviewed By: dberris
Subscribers: llvm-commits, aemerson, rengolin, dberris, iid_iunknown
Differential Revision: https://reviews.llvm.org/D28624
------------------------------------------------------------------------
git-svn-id: https://llvm.org/svn/llvm-project/llvm/branches/release_40@293295
91177308-0d34-0410-b5e6-
96231b3b80d8
Mehdi Amini [Fri, 27 Jan 2017 16:16:33 +0000 (16:16 +0000)]
LLVM 4.0: cherry-pick r293293 - "Fix BasicAA incorrect assumption on GEP"
git-svn-id: https://llvm.org/svn/llvm-project/llvm/branches/release_40@293294
91177308-0d34-0410-b5e6-
96231b3b80d8
Mehdi Amini [Fri, 27 Jan 2017 16:06:47 +0000 (16:06 +0000)]
LLVM 4.0: cherry-pick r293291 - Avoid using unspecified ordering in MetadataLoader::MetadataLoaderImpl::parseOneMetadata.
git-svn-id: https://llvm.org/svn/llvm-project/llvm/branches/release_40@293292
91177308-0d34-0410-b5e6-
96231b3b80d8
Tom Stellard [Fri, 27 Jan 2017 00:45:06 +0000 (00:45 +0000)]
Merging r293000:
------------------------------------------------------------------------
r293000 | thomas.stellard | 2017-01-24 17:25:13 -0800 (Tue, 24 Jan 2017) | 15 lines
AMDGPU add support for spilling to a user sgpr pointed buffers
Summary:
This lets you select which sort of spilling you want, either s[0:1] or 64-bit loads from s[0:1].
Patch By: Dave Airlie
Reviewers: nhaehnle, arsenm, tstellarAMD
Reviewed By: arsenm
Subscribers: mareko, llvm-commits, kzhuravl, wdng, yaxunl, tony-tye
Differential Revision: https://reviews.llvm.org/D25428
------------------------------------------------------------------------
git-svn-id: https://llvm.org/svn/llvm-project/llvm/branches/release_40@293240
91177308-0d34-0410-b5e6-
96231b3b80d8
Hans Wennborg [Thu, 26 Jan 2017 00:26:36 +0000 (00:26 +0000)]
Merging r292651:
------------------------------------------------------------------------
r292651 | jvesely | 2017-01-20 13:24:26 -0800 (Fri, 20 Jan 2017) | 8 lines
AMDGPU/R600: Serialize vector trunc stores to private AS
Add DUMMY_CHAIN SDNode to denote stores of interest
Bugzilla: https://llvm.org/bugs/show_bug.cgi?id=28915
Bugzilla: https://llvm.org/bugs/show_bug.cgi?id=30411
Differential Revision: https://reviews.llvm.org/D27964
------------------------------------------------------------------------
git-svn-id: https://llvm.org/svn/llvm-project/llvm/branches/release_40@293118
91177308-0d34-0410-b5e6-
96231b3b80d8
Tim Northover [Wed, 25 Jan 2017 22:10:07 +0000 (22:10 +0000)]
Merging rr293088:
------------------------------------------------------------------------
r293088 | tnorthover | 2017-01-25 12:58:26 -0800 (Wed, 25 Jan 2017) | 5 lines
SDag: fix how initial loads are formed when splitting vector ops.
Later code expects the vector loads produced to be directly
concatenable, which means we shouldn't pad anything except the last load
produced with UNDEF.
------------------------------------------------------------------------
git-svn-id: https://llvm.org/svn/llvm-project/llvm/branches/release_40@293103
91177308-0d34-0410-b5e6-
96231b3b80d8
Hans Wennborg [Wed, 25 Jan 2017 17:14:48 +0000 (17:14 +0000)]
Merging r293025:
------------------------------------------------------------------------
r293025 | ahatanak | 2017-01-24 22:21:51 -0800 (Tue, 24 Jan 2017) | 29 lines
[SimplifyCFG] Do not sink and merge inline-asm instructions.
Conservatively disable sinking and merging inline-asm instructions as doing so
can potentially create arguments that cannot satisfy the inline-asm constraints.
For example, SimplifyCFG used to do the following transformation:
(before)
if.then:
%0 = call i32 asm "rorl $2, $0", "=&r,0,n"(i32 %r6, i32 8)
br label %if.end
if.else:
%1 = call i32 asm "rorl $2, $0", "=&r,0,n"(i32 %r6, i32 6)
br label %if.end
(after)
%.sink = select i1 %tobool, i32 6, i32 8
%0 = call i32 asm "rorl $2, $0", "=&r,0,n"(i32 %r6, i32 %.sink)
This would result in a crash in the backend since only immediate integer operands
are permitted for constraint "n".
rdar://problem/
30110806
Differential Revision: https://reviews.llvm.org/D29111
------------------------------------------------------------------------
git-svn-id: https://llvm.org/svn/llvm-project/llvm/branches/release_40@293074
91177308-0d34-0410-b5e6-
96231b3b80d8
Hans Wennborg [Wed, 25 Jan 2017 16:57:43 +0000 (16:57 +0000)]
Merging r292444:
------------------------------------------------------------------------
r292444 | mkuper | 2017-01-18 15:05:58 -0800 (Wed, 18 Jan 2017) | 7 lines
Revert r291670 because it introduces a crash.
r291670 doesn't crash on the original testcase from PR31589,
but it crashes on a slightly more complex one.
PR31589 has the new reproducer.
------------------------------------------------------------------------
git-svn-id: https://llvm.org/svn/llvm-project/llvm/branches/release_40@293070
91177308-0d34-0410-b5e6-
96231b3b80d8
Hans Wennborg [Tue, 24 Jan 2017 16:58:58 +0000 (16:58 +0000)]
Merging r291909:
------------------------------------------------------------------------
r291909 | compnerd | 2017-01-13 08:25:33 -0800 (Fri, 13 Jan 2017) | 9 lines
ARM: match GCC's behaviour for builtins
GCC changes the CC between the user-code and the builtins based on the
value of `-target` rather than `-mfloat-abi`. When a HF target is used,
the VFP variant of the AAPCS CC is used. Otherwise, the AAPCS variant
is used. In all cases, the AEABI functions use the AAPCS CC. Adjust
the calling convention based on the target.
Resolves PR30543!
------------------------------------------------------------------------
git-svn-id: https://llvm.org/svn/llvm-project/llvm/branches/release_40@292951
91177308-0d34-0410-b5e6-
96231b3b80d8
Hans Wennborg [Tue, 24 Jan 2017 00:26:12 +0000 (00:26 +0000)]
Merging r292467:
------------------------------------------------------------------------
r292467 | compnerd | 2017-01-18 18:58:46 -0800 (Wed, 18 Jan 2017) | 7 lines
llvm-cxxfilt: filter out invalid manglings
c++filt does not attempt to demangle symbols which do not match its
expected format. This means that the symbol must start with _Z or ___Z
(block invocation function extension). Any other symbols are returned
as is. Note that this is different from the behaviour of __cxa_demangle
which will demangle fragments.
------------------------------------------------------------------------
git-svn-id: https://llvm.org/svn/llvm-project/llvm/branches/release_40@292861
91177308-0d34-0410-b5e6-
96231b3b80d8
Hans Wennborg [Mon, 23 Jan 2017 21:33:34 +0000 (21:33 +0000)]
Merging r292758:
------------------------------------------------------------------------
r292758 | spatel | 2017-01-22 09:06:12 -0800 (Sun, 22 Jan 2017) | 4 lines
[x86] avoid crashing with illegal vector type (PR31672)
https://llvm.org/bugs/show_bug.cgi?id=31672
------------------------------------------------------------------------
git-svn-id: https://llvm.org/svn/llvm-project/llvm/branches/release_40@292832
91177308-0d34-0410-b5e6-
96231b3b80d8
Hans Wennborg [Mon, 23 Jan 2017 21:30:13 +0000 (21:30 +0000)]
Merging r292323:
------------------------------------------------------------------------
r292323 | pzheng | 2017-01-17 17:03:29 -0800 (Tue, 17 Jan 2017) | 9 lines
[test-release.sh] Add Polly to the list of projects
Reviewers: zinob, hans, grosser
Reviewed By: hans, grosser
Subscribers: llvm-commits
Differential Revision: https://reviews.llvm.org/D28712
------------------------------------------------------------------------
git-svn-id: https://llvm.org/svn/llvm-project/llvm/branches/release_40@292831
91177308-0d34-0410-b5e6-
96231b3b80d8
Matthias Braun [Mon, 23 Jan 2017 19:26:12 +0000 (19:26 +0000)]
Cherry pick r292625
git-svn-id: https://llvm.org/svn/llvm-project/llvm/branches/release_40@292820
91177308-0d34-0410-b5e6-
96231b3b80d8