platform/upstream/llvm.git
4 years ago[X86] Improve lowering of (v2i64 (setgt X, -1)) on pre-SSE2 targets. Enable v2i64...
Craig Topper [Tue, 7 Jan 2020 19:09:33 +0000 (11:09 -0800)]
[X86] Improve lowering of (v2i64 (setgt X, -1)) on pre-SSE2 targets. Enable v2i64 in foldVectorXorShiftIntoCmp.

Similar to D72302 but for the canonical form for the opposite case. I've changed foldVectorXorShiftIntoCmp to form a target independent setcc node instead of PCMPGT now and enabled its for v2i64 on pre-SSE4.2 targets. The setcc should eventually get lowered to PCMPGT or the new v2i64 sequence.

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

4 years ago[X86] Improve lowering of v2i64 sign bit tests on pre-sse4.2 targets
Craig Topper [Tue, 7 Jan 2020 19:08:45 +0000 (11:08 -0800)]
[X86] Improve lowering of v2i64 sign bit tests on pre-sse4.2 targets

Without sse4.2 a v2i64 setlt needs to expand into a pcmpgtd, pcmpeqd, 3 shuffles, and 2 logic ops. But if we're only interested in the sign bit of the i64 elements, we can just use one pcmpgtd and shuffle the odd elements to the even elements.

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

4 years ago[gn build] Port 1d94fb21118
LLVM GN Syncbot [Tue, 7 Jan 2020 19:13:41 +0000 (19:13 +0000)]
[gn build] Port 1d94fb21118

4 years ago[gicombiner] Add GIMatchTree and use it for the code generation
Daniel Sanders [Tue, 7 Jan 2020 18:27:53 +0000 (10:27 -0800)]
[gicombiner] Add GIMatchTree and use it for the code generation

Summary:
GIMatchTree's job is to build a decision tree by zipping all the
GIMatchDag's together.

Each DAG is added to the tree builder as a leaf and partitioners are used
to subdivide each node until there are no more partitioners to apply. At
this point, the code generator is responsible for testing any untested
predicates and following any unvisited traversals (there shouldn't be any
of the latter as the getVRegDef partitioner handles them all).

Note that the leaves don't always fit into partitions cleanly and the
partitions may overlap as a result. This is resolved by cloning the leaf
into every partition it belongs to. One example of this is a rule that can
match one of N opcodes. The leaf for this rule would end up in N partitions
when processed by the opcode partitioner. A similar example is the
getVRegDef partitioner where having rules (add $a, $b), and (add ($a, $b), $c)
will result in the former being in the partition for successfully
following the vreg-def and failing to do so as it doesn't care which
happens.

Depends on D69151

Fixed the issues with the windows bots which were caused by stdout/stderr
interleaving.

Reviewers: bogner, volkan

Reviewed By: volkan

Subscribers: lkail, mgorny, llvm-commits

Tags: #llvm

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

4 years agoFix issues reported by -Wrange-loop-analysis when building with latest Clang (trunk...
Alexandre Ganea [Tue, 7 Jan 2020 18:58:17 +0000 (13:58 -0500)]
Fix issues reported by -Wrange-loop-analysis when building with latest Clang (trunk). NFC.

Fixes warning: loop variable 'E' of type 'const llvm::StringRef' creates a copy from type 'const llvm::StringRef' [-Wrange-loop-analysis]

4 years ago[OPENMP]Allow using of members in standalone declaration pragmas.
Alexey Bataev [Tue, 7 Jan 2020 18:39:18 +0000 (13:39 -0500)]
[OPENMP]Allow using of members in standalone declaration pragmas.

If standalone OpenMP declaration pragma, like declare mapper or declare
reduction, is declared in the class context, it may reference a member
(data or function) in its internal expressions/statements. So, the
parsing of such pragmas must be dalayed just like the parsing of the
member initializers/definitions before the completion of the class
declaration.

4 years ago[clangd] Heuristically resolve dependent call through smart pointer type
Nathan Ridge [Mon, 16 Dec 2019 01:42:25 +0000 (20:42 -0500)]
[clangd] Heuristically resolve dependent call through smart pointer type

Summary: Fixes https://github.com/clangd/clangd/issues/227

Reviewers: sammccall

Subscribers: ilya-biryukov, MaskRay, jkorous, arphaman, kadircet, usaxena95, cfe-commits

Tags: #clang

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

4 years ago[clangd] Assert that the testcases in LocateSymbol.All have no diagnostics
Nathan Ridge [Thu, 2 Jan 2020 06:08:05 +0000 (01:08 -0500)]
[clangd] Assert that the testcases in LocateSymbol.All have no diagnostics

Summary: Also fix some bugs in the testcases which this exposed.

Subscribers: ilya-biryukov, MaskRay, jkorous, arphaman, kadircet, usaxena95, cfe-commits

Tags: #clang

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

4 years ago[lldb] Initialize some bitfields in FuncUnwinders.cpp
Pavel Labath [Tue, 7 Jan 2020 17:01:59 +0000 (18:01 +0100)]
[lldb] Initialize some bitfields in FuncUnwinders.cpp

This got flagged by msan.

4 years ago[ARM] Regenerate bfi.ll test cases
Simon Pilgrim [Tue, 7 Jan 2020 16:50:55 +0000 (16:50 +0000)]
[ARM] Regenerate bfi.ll test cases

4 years ago[X86] Pull out repeated SrcVT.getVectorNumElements() call. NFCI.
Simon Pilgrim [Tue, 7 Jan 2020 15:52:15 +0000 (15:52 +0000)]
[X86] Pull out repeated SrcVT.getVectorNumElements() call. NFCI.

4 years ago[analyzer] Update help text to reflect sarif support
Gabor Horvath [Tue, 7 Jan 2020 16:37:49 +0000 (08:37 -0800)]
[analyzer] Update help text to reflect sarif support

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

4 years ago[LifetimeAnalysis] Do not forbid void deref type in gsl::Pointer/gsl::Owner annotations
Gabor Horvath [Thu, 2 Jan 2020 19:57:42 +0000 (11:57 -0800)]
[LifetimeAnalysis] Do not forbid void deref type in gsl::Pointer/gsl::Owner annotations

It turns out it is useful to be able to define the deref type as void.
In case we have a type erased owner, we want to express that the pointee
can be basically any type. It should not be unnatural to have a void
deref type as we already familiar with "pointers to void".

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

4 years ago[AIX][XCOFF]Implement mergeable const
diggerlin [Tue, 7 Jan 2020 16:20:51 +0000 (11:20 -0500)]
[AIX][XCOFF]Implement mergeable const

SUMMARY:
In this patch, we map mergeable const objects to the read-only section in the same manner as const objects that are not mergeable.

Reviewers: hubert.reinterpretcast,jasonliu
Subscribers: wuzish, nemanjai, hiraditya

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

4 years ago[HIP] Add option --gpu-max-threads-per-block=n
Yaxun (Sam) Liu [Mon, 9 Dec 2019 19:55:34 +0000 (14:55 -0500)]
[HIP] Add option --gpu-max-threads-per-block=n

Add this option to change the default launch bounds.

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

4 years ago[ARM][MVE] Renamed VPT Block tests and files to something more informative. NFC
Sjoerd Meijer [Tue, 7 Jan 2020 15:57:19 +0000 (15:57 +0000)]
[ARM][MVE] Renamed VPT Block tests and files to something more informative. NFC

4 years agoAMDGPU/GlobalISel: Fix readfirstlane pattern import
Matt Arsenault [Tue, 7 Jan 2020 16:01:16 +0000 (11:01 -0500)]
AMDGPU/GlobalISel: Fix readfirstlane pattern import

The imm folding optimization pattern failed to import. The instruction
pattern was already working, but failing to fail on SGPR inputs.

4 years agoRemove extraneous spaces
Med Ismail Bennani [Tue, 7 Jan 2020 15:43:56 +0000 (16:43 +0100)]
Remove extraneous spaces

Signed-off-by: Med Ismail Bennani <medismail.bennani@gmail.com>
4 years ago[InstCombine] try to pull 'not' of select into compare operands
Sanjay Patel [Tue, 7 Jan 2020 15:41:17 +0000 (10:41 -0500)]
[InstCombine] try to pull 'not' of select into compare operands

not (select ?, (cmp TPred, ?, ?), (cmp FPred, ?, ?) -->
     select ?, (cmp TPred', ?, ?), (cmp FPred', ?, ?)

If both sides of the select are cmps, we can remove an instruction.
The case where only side is a cmp is deferred to a possible
follow-on patch.

We have a more general 'isFreeToInvert' analysis, but I'm not seeing
a way to use that more widely without inducing infinite looping
(opposing transforms).
Here, we flip the compare predicates directly, so we should not have
any danger by creating extra intermediate 'not' ops.

Alive proofs:
https://rise4fun.com/Alive/jKa

Name: both select values are compares - invert predicates
  %tcmp = icmp sle i32 %x, %y
  %fcmp = icmp ugt i32 %z, %w
  %sel = select i1 %cond, i1 %tcmp, i1 %fcmp
  %not = xor i1 %sel, true
=>
  %tcmp_not = icmp sgt i32 %x, %y
  %fcmp_not = icmp ule i32 %z, %w
  %not = select i1 %cond, i1 %tcmp_not, i1 %fcmp_not

Name: false val is compare - invert/not
  %fcmp = icmp ugt i32 %z, %w
  %sel = select i1 %cond, i1 %tcmp, i1 %fcmp
  %not = xor i1 %sel, true
=>
  %tcmp_not = xor i1 %tcmp, -1
  %fcmp_not = icmp ule i32 %z, %w
  %not = select i1 %cond, i1 %tcmp_not, i1 %fcmp_not

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

4 years agoAMDGPU/GlobalISel: Fix import of s_abs_i32 pattern
Matt Arsenault [Tue, 7 Jan 2020 15:22:06 +0000 (10:22 -0500)]
AMDGPU/GlobalISel: Fix import of s_abs_i32 pattern

4 years agoAMDGPU/GlobalISel: Select llvm.amdgcn.wqm.vote
Matt Arsenault [Mon, 16 Sep 2019 04:53:31 +0000 (00:53 -0400)]
AMDGPU/GlobalISel: Select llvm.amdgcn.wqm.vote

4 years agoOpaquePtr: print byval types containing anonymous types correctly.
Tim Northover [Tue, 7 Jan 2020 10:03:31 +0000 (10:03 +0000)]
OpaquePtr: print byval types containing anonymous types correctly.

Attribute::getAsString doesn't have enough information to print anonymous
Module-level types correctly, so they come back as "%type 0xabcd". This results
in broken IR when printing as text.

Instead, print type-attributes (currently just byval) using the TypePrinting
infrastructure available in AsmWriter. This only applies to function argument
attributes.

4 years agollc: Change behavior of -mcpu with existing attribute
Matt Arsenault [Mon, 9 Dec 2019 11:37:14 +0000 (17:07 +0530)]
llc: Change behavior of -mcpu with existing attribute

Don't overwrite existing target-cpu attributes.

I've often found the replacement behavior annoying, and this is
inconsistent with how the fast math command line flags interact with
the function attributes.

Does not yet change target-features, since I think that should behave
as a concatenation.

4 years agoAMDGPU/GlobalISel: Partially fix llvm.amdgcn.kill pattern import
Matt Arsenault [Sun, 15 Sep 2019 16:50:17 +0000 (12:50 -0400)]
AMDGPU/GlobalISel: Partially fix llvm.amdgcn.kill pattern import

Tests deferred since the existing DAG test depends on some other
operations, but isn't far from working as-is.

4 years ago[docs] NFC: Fix typos in documents
Hans Wennborg [Tue, 7 Jan 2020 15:06:14 +0000 (16:06 +0100)]
[docs] NFC: Fix typos in documents

"the the" -> "the"
"an" -> "a"

Patch by Kazuaki Ishizaki <ishizaki@jp.ibm.com>!

Differential revision: https://reviews.llvm.org/D72091

4 years ago[TypePromotion] Use SetVectors instead of PtrSets
Sam Parker [Tue, 7 Jan 2020 14:50:26 +0000 (14:50 +0000)]
[TypePromotion] Use SetVectors instead of PtrSets

Remove the chance of non-deterministic insertion of zexts of the
sources by using a SetVector instead of SmallPtrSet. Do the same for
sinks for consistency and to negate the small issue from possibly
happening. The SafeWrap instructions are now also stored in a
SmallVector. The IRPromoter members of these structures have been
changed to references.

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

4 years ago[DAGCombiner] reduce shuffle of concat of same vector
Sanjay Patel [Tue, 7 Jan 2020 14:47:50 +0000 (09:47 -0500)]
[DAGCombiner] reduce shuffle of concat of same vector

This is possibly a small part towards solving PR42024:
https://bugs.llvm.org/show_bug.cgi?id=42024

The vectorizer is creating shuffles of concat like this:

%63 = shufflevector <4 x i64> %x, <4 x i64> undef, <8 x i32> <i32 0, i32 1, i32 2, i32 3, i32 0, i32 1, i32 2, i32 3>
%64 = shufflevector <8 x i64> %63, <8 x i64> undef, <8 x i32> <i32 0, i32 4, i32 1, i32 5, i32 2, i32 6, i32 3, i32 7>

That might be fixable in the vectorizers, but we're not allowed to fold that into a single shuffle in instcombine,
so we should have a backend backstop to convert that into the likely simpler form:

%64 = shufflevector <4 x i64> %x, <4 x i64> undef, <8 x i32> <i32 0, i32 0, i32 1, i32 1, i32 2, i32 2, i32 3, i32 3>

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

4 years ago[OPENMP]Do not diagnose references to non-integral types for ref in
Alexey Bataev [Tue, 7 Jan 2020 14:26:10 +0000 (09:26 -0500)]
[OPENMP]Do not diagnose references to non-integral types for ref in
declare simd.

According to the standard, a list-item that appears in a linear clause without the ref modifier must be of integral or pointer type, or must be a reference to an integral or pointer type. Added check that this restriction is applied only to non-ref items.

4 years ago[clangd] Introduce bulletlists
Kadir Cetinkaya [Thu, 12 Dec 2019 14:25:45 +0000 (15:25 +0100)]
[clangd] Introduce bulletlists

Reviewers: sammccall

Subscribers: ilya-biryukov, MaskRay, jkorous, arphaman, usaxena95, cfe-commits

Tags: #clang

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

4 years ago[ARM][MVE] VPT Blocks: findVCMPToFoldIntoVPS
Sjoerd Meijer [Tue, 7 Jan 2020 13:54:47 +0000 (13:54 +0000)]
[ARM][MVE] VPT Blocks: findVCMPToFoldIntoVPS

This is a recommit of D71330, but with a few things fixed and changed:

1) ReachingDefAnalysis: this was not running with optnone as it was checking
skipFunction(), which other analysis passes don't do. I guess this is a
copy-paste from a codegen pass.
2) VPTBlockPass: here I've added skipFunction(), because like most/all
optimisations, we don't want to run this with optnone.

This fixes the issues with the initial/previous commit: the VPTBlockPass was
running with optnone, but ReachingDefAnalysis wasn't, and so VPTBlockPass was
crashing querying ReachingDefAnalysis.

I've added test case mve-vpt-block-optnone.mir to check that we don't run
VPTBlock with optnone.

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

4 years ago[X86] Standardize shuffle match/lowering function names. NFC.
Simon Pilgrim [Tue, 7 Jan 2020 13:41:38 +0000 (13:41 +0000)]
[X86] Standardize shuffle match/lowering function names. NFC.

We mainly use lowerShuffle*/matchShuffle* - replace the (few) lowerVectorShuffle*/matchVectorShuffle* cases to be consistent.

4 years agoFix "pointer is null" static analyzer warning. NFCI.
Simon Pilgrim [Tue, 7 Jan 2020 13:37:48 +0000 (13:37 +0000)]
Fix "pointer is null" static analyzer warning. NFCI.

4 years ago[ARM] Improve codegen of volatile load/store of i64
Victor Campos [Thu, 2 Jan 2020 11:00:14 +0000 (11:00 +0000)]
[ARM] Improve codegen of volatile load/store of i64

Summary:
Instead of generating two i32 instructions for each load or store of a volatile
i64 value (two LDRs or STRs), now emit LDRD/STRD.

These improvements cover architectures implementing ARMv5TE or Thumb-2.

Reviewers: dmgreen, efriedma, john.brawn, nickdesaulniers

Reviewed By: efriedma, nickdesaulniers

Subscribers: nickdesaulniers, vvereschaka, kristof.beyls, hiraditya, llvm-commits

Tags: #llvm

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

4 years agoFix "use of uninitialized variable" static analyzer warning. NFCI.
Simon Pilgrim [Tue, 7 Jan 2020 12:05:40 +0000 (12:05 +0000)]
Fix "use of uninitialized variable" static analyzer warning. NFCI.

4 years ago[lldb][NFC] Use static_cast instead of reinterpret_cast where possible
Raphael Isemann [Tue, 7 Jan 2020 11:13:03 +0000 (12:13 +0100)]
[lldb][NFC] Use static_cast instead of reinterpret_cast where possible

Summary: There are a few places in LLDB where we do a `reinterpret_cast` for conversions that we could also do with `static_cast`. This patch moves all this code to `static_cast`.

Reviewers: shafik, JDevlieghere, labath

Reviewed By: labath

Subscribers: arphaman, usaxena95, lldb-commits

Tags: #lldb

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

4 years ago[SystemZ] Extend fp-strict-alias test case
Ulrich Weigand [Tue, 7 Jan 2020 11:43:33 +0000 (12:43 +0100)]
[SystemZ] Extend fp-strict-alias test case

Explicitly add test for fpexcept.maytrap intrinsics.

4 years ago[gn build] Port c69ae835d0e
LLVM GN Syncbot [Tue, 7 Jan 2020 11:41:46 +0000 (11:41 +0000)]
[gn build] Port c69ae835d0e

4 years ago[clangd] Add path mappings functionality
Sam McCall [Tue, 7 Jan 2020 10:28:05 +0000 (11:28 +0100)]
[clangd] Add path mappings functionality

Summary: Add path mappings to clangd which translate file URIs on inbound and outbound LSP messages. This mapping allows clangd to run in a remote environment (e.g. docker), where the source files and dependencies may be at different locations than the host. See http://lists.llvm.org/pipermail/clangd-dev/2019-January/000231.htm for more.

Patch by William Wagner!

Reviewers: sammccall, ilya-biryukov

Reviewed By: sammccall

Subscribers: usaxena95, ormris, mgorny, MaskRay, jkorous, arphaman, kadircet, cfe-commits

Tags: #clang

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

4 years ago[RISCV][Docs] Add RISC-V asm template argument modifiers
Luís Marques [Tue, 7 Jan 2020 11:06:44 +0000 (11:06 +0000)]
[RISCV][Docs] Add RISC-V asm template argument modifiers

Adds the RISC-V asm template argument modifiers currently supported by LLVM.
Additional ones supported by GCC will be added to the documentation when we
start supporting them.

4 years agoFix Wdocumentation warnings. NFCI.
Simon Pilgrim [Tue, 7 Jan 2020 10:52:08 +0000 (10:52 +0000)]
Fix Wdocumentation warnings. NFCI.

4 years agoFix "use of uninitialized variable" static analyzer warnings. NFCI.
Simon Pilgrim [Mon, 6 Jan 2020 18:24:53 +0000 (18:24 +0000)]
Fix "use of uninitialized variable" static analyzer warnings. NFCI.

4 years agoFix "use of uninitialized variable" static analyzer warnings. NFCI.
Simon Pilgrim [Mon, 6 Jan 2020 16:53:18 +0000 (16:53 +0000)]
Fix "use of uninitialized variable" static analyzer warnings. NFCI.

4 years ago[DebugInfo] Fix infinite loop caused by reading past debug_line end
James Henderson [Tue, 7 Jan 2020 10:21:20 +0000 (10:21 +0000)]
[DebugInfo] Fix infinite loop caused by reading past debug_line end

If the claimed unit length of a debug line program is such that the line
table would finish past the end of the .debug_line section, an infinite
loop occurs because the data extractor will continue to "read" zeroes
without changing the offset. This previously didn't hit an error because
the line table program handles a series of zeroes as a bad extended
opcode.

This patch fixes the inifinite loop and adds a warning if the program
doesn't fit in the available data.

Reviewed by: JDevlieghere

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

4 years ago[LLD][ELF][AArch64] Do not use thunk for undefined weak symbol.
Peter Smith [Mon, 6 Jan 2020 14:16:05 +0000 (14:16 +0000)]
[LLD][ELF][AArch64] Do not use thunk for undefined weak symbol.

In AArch64 a branch to an undefined weak symbol that does not have a PLT
entry should resolve to the next instruction. The thunk generation code
can prevent this from happening as a range extension thunk can be generated
if the branch is sufficiently far away from 0, the value of an undefined
weak symbol.

The fix is taken from the Arm implementation of needsThunk(), we prevent a
thunk from being generated to an undefined weak symbol.

fixes pr44451

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

4 years ago[lldb][NFC] Take a llvm::Triple in ClangASTContext constructor
Raphael Isemann [Tue, 7 Jan 2020 09:37:57 +0000 (10:37 +0100)]
[lldb][NFC] Take a llvm::Triple in ClangASTContext constructor

This constructor is supposed to take a string representing an llvm::Triple.
We might as well take a llvm::Triple here which saves us all the string
conversions in the call sites and we make this more type safe.

4 years ago[NFC] Use isX86() instead of getArch()
Jim Lin [Tue, 7 Jan 2020 09:32:39 +0000 (17:32 +0800)]
[NFC] Use isX86() instead of getArch()

Summary: This is a clean up for https://reviews.llvm.org/D72247.

Reviewers: MaskRay, craig.topper, jhenderson

Reviewed By: MaskRay

Subscribers: hiraditya, rupprecht, cfe-commits, llvm-commits

Tags: #clang, #llvm

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

4 years ago[SystemZ] Fix python failure in test case
Ulrich Weigand [Tue, 7 Jan 2020 09:24:26 +0000 (10:24 +0100)]
[SystemZ] Fix python failure in test case

With recent Python the Large/spill-02.py test failed with an error:
TypeError: can't multiply sequence by non-int of type 'float'

4 years ago[APFloat] Fix out of scope usage of a pointer to local variable
Ehud Katz [Tue, 7 Jan 2020 09:24:11 +0000 (11:24 +0200)]
[APFloat] Fix out of scope usage of a pointer to local variable

4 years agoFix compiler extension example cmake integration
serge-sans-paille [Tue, 7 Jan 2020 08:27:08 +0000 (09:27 +0100)]
Fix compiler extension example cmake integration

- Do not add it to the Export file
- Update install target

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

4 years ago[lldb] Fix LLDB build after API change to printInst (D72172)
Raphael Isemann [Tue, 7 Jan 2020 07:30:45 +0000 (08:30 +0100)]
[lldb] Fix LLDB build after API change to printInst (D72172)

It seems in D72172 we always pass a 0 as the new default argument so let's
do the same in LLDB to get the build bot running.

4 years ago[APFloat] Fix fusedMultiplyAdd when `this` equals to `Addend`
Ehud Katz [Tue, 7 Jan 2020 06:45:18 +0000 (08:45 +0200)]
[APFloat] Fix fusedMultiplyAdd when `this` equals to `Addend`

Up until now, the arguments to `fusedMultiplyAdd` are passed by
reference. We must save the `Addend` value on the beginning of the
function, before we modify `this`, as they may be the same reference.

To fix this, we now pass the `addend` parameter of `multiplySignificand`
by value (instead of by-ref), and have a default value of zero.

Fix PR44051.

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

4 years ago[libc] Move implementations of strcat and strcpy to the string directory.
Siva Chandra Reddy [Mon, 6 Jan 2020 18:38:45 +0000 (10:38 -0800)]
[libc] Move implementations of strcat and strcpy to the string directory.

Summary:
Now that tests live in separate top-level directory, keeping the
implementations of individual functions in a directory of their own is
not meaningful. Hence, this change moves them into the higher level
string directory.

NFC intended.

Reviewers: MaskRay

Subscribers: mgorny, tschuett, libc-commits

Tags: #libc-project

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

4 years ago[OpenMP] NFC: Fix trivial typos in comments
Kazuaki Ishizaki [Tue, 7 Jan 2020 06:03:31 +0000 (14:03 +0800)]
[OpenMP] NFC: Fix trivial typos in comments

Reviewers: jdoerfert, Jim

Reviewed By: Jim

Subscribers: Jim, mgorny, guansong, jfb, openmp-commits

Tags: #openmp

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

4 years ago[libc] Add __attribute__((always_inline)) to x86_64 syscall functions.
Siva Chandra Reddy [Thu, 2 Jan 2020 19:09:18 +0000 (11:09 -0800)]
[libc] Add __attribute__((always_inline)) to x86_64 syscall functions.

Summary:
Some syscalls like SYS_clone do not tolerate a return instruction after
the syscall instruction. Marking the syscall functions with the
`always_inline` attribute accommodates such syscalls as inlining
eliminates the return instruction.

Reviewers: abrachet, phosek

Subscribers: MaskRay, tschuett, libc-commits

Tags: #libc-project

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

4 years agoLet PassBuilder Expose PassInstrumentationCallbacks
Juneyoung Lee [Tue, 7 Jan 2020 05:04:32 +0000 (14:04 +0900)]
Let PassBuilder Expose PassInstrumentationCallbacks

Summary:
This is an effort to allowing external libraries register their own pass instrumentation during their llvmGetPassPluginInfo() calls.

By exposing this through the added getPIC(), now a pass writer can do something like this:

```
extern "C" ::llvm::PassPluginLibraryInfo LLVM_ATTRIBUTE_WEAK
llvmGetPassPluginInfo() {
  return {
    ..,
    [](llvm::PassBuilder &PB) {
      PB.getPIC()->registerAfterPassCallback(move(f));
    }
  };
}
```

Reviewers: chandlerc, philip.pfaffe, fedor.sergeev

Reviewed By: fedor.sergeev

Subscribers: llvm-commits

Tags: #llvm

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

4 years ago[MC] Add parameter `Address` to MCInstrPrinter::printInstruction
Fangrui Song [Fri, 3 Jan 2020 20:02:46 +0000 (12:02 -0800)]
[MC] Add parameter `Address` to MCInstrPrinter::printInstruction

Follow-up of D72172.

Reviewed By: jhenderson, rnk

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

4 years ago[MC] Add parameter `Address` to MCInstPrinter::printInst
Fangrui Song [Fri, 3 Jan 2020 18:55:30 +0000 (10:55 -0800)]
[MC] Add parameter `Address` to MCInstPrinter::printInst

printInst prints a branch/call instruction as `b offset` (there are many
variants on various targets) instead of `b address`.

It is a convention to use address instead of offset in most external
symbolizers/disassemblers. This difference makes `llvm-objdump -d`
output unsatisfactory.

Add `uint64_t Address` to printInst(), so that it can pass the argument to
printInstruction(). `raw_ostream &OS` is moved to the last to be
consistent with other print* methods.

The next step is to pass `Address` to printInstruction() (generated by
tablegen from the instruction set description). We can gradually migrate
targets to print addresses instead of offsets.

In any case, downstream projects which don't know `Address` can pass 0 as
the argument.

Reviewed By: jhenderson

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

4 years agoAMDGPU/GlobalISel: Fix unused variable warning in release
Matt Arsenault [Tue, 7 Jan 2020 03:31:33 +0000 (22:31 -0500)]
AMDGPU/GlobalISel: Fix unused variable warning in release

4 years ago[mlir][Linalg] Add a linalg.reshape op
Nicolas Vasilache [Tue, 7 Jan 2020 03:14:14 +0000 (22:14 -0500)]
[mlir][Linalg] Add a linalg.reshape op

Summary:
This diff adds a new operation to linalg to allow reshaping of an
existing view into a new view in the same buffer at the same offset.

More specifically:
The `linalg.reshape` op produces a new view whose sizes are a reassociation
of the original `view`. Depending on whether or not the reassociated
MemRefType is contiguous, the resulting memref may require explicit alloc
and copies.

A reassociation is defined as a continous grouping of dimensions and is
represented with a affine map array attribute. In the future, non-continous
groupings may be allowed (i.e. permutations, reindexings etc).

For now, it is assumed that either:
  1. a reassociation produces and consumes contiguous MemRefType or,
  2. the reshape op will be folded into its consumers (by changing the shape
     of the computations).
All other cases are undefined behavior and a reshape op may not lower to
LLVM if it cannot be proven statically that it does not require alloc+copy.

A reshape may either collapse or expand dimensions, depending on the
relationship between source and target memref ranks. The verification rule
is that the reassociation maps are applied to the memref with the larger
rank to obtain the memref with the smaller rank. In the case of a dimension
expansion, the reassociation maps can be interpreted as inverse maps.

Examples:

```mlir
   // Dimension collapse (i, j) -> i' and k -> k'
   %1 = linalg.reshape %0 [(i, j, k) -> (i, j),
                           (i, j, k) -> (k)] :
     memref<?x?x?xf32, stride_spec> into memref<?x?xf32, stride_spec_2>
```

```mlir
   // Dimension expansion i -> (i', j') and (k) -> (k')
   %1 = linalg.reshape %0 [(i, j, k) -> (i, j),
                           (i, j, k) -> (k)] :
     memref<?x?xf32, stride_spec> into memref<?x?x?xf32, stride_spec_2>
```

The relevant invalid and roundtripping tests are added.

Reviewers: AlexEichenberger, ftynse, rriddle, asaadaldien, yangjunpro

Subscribers: kiszk, merge_guards_bot, mehdi_amini, jpienaar, burmako, shauheen, antiagainst, arpith-jacob, mgester, lucyrfox, llvm-commits

Tags: #llvm

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

4 years ago[NFC][Test] Add a test to verify the DAGCombine of fma
QingShan Zhang [Tue, 7 Jan 2020 03:13:39 +0000 (03:13 +0000)]
[NFC][Test] Add a test to verify the DAGCombine of fma

4 years agoAMDGPU: Add run line to int_to_fp tests
Matt Arsenault [Tue, 7 Jan 2020 02:01:16 +0000 (21:01 -0500)]
AMDGPU: Add run line to int_to_fp tests

This wasn't catching a regression on targets with legal i16 triggered
in a future commit.

4 years agoAMDGPU: Select llvm.amdgcn.interp.p2.f16 directly
Matt Arsenault [Mon, 21 Oct 2019 20:39:17 +0000 (13:39 -0700)]
AMDGPU: Select llvm.amdgcn.interp.p2.f16 directly

This will enable automatic GlobalISel support in a future commit.

4 years agoAlways deduce the lengths of contained parameter packs when deducing a
Richard Smith [Tue, 7 Jan 2020 01:16:29 +0000 (17:16 -0800)]
Always deduce the lengths of contained parameter packs when deducing a
pack expansion.

Previously, if all parameter / argument pairs for a pack expansion
deduction were non-deduced contexts, we would not deduce the arity of
the pack, and could end up deducing a different arity (leading to
failures during substitution) or defaulting to an arity of 0 (leading to
bad diagnostics about passing the wrong number of arguments to a
variadic function). Instead, we now always deduce the arity for all
involved packs any time we deduce a pack expansion.

This will result in less substitution happening in some cases, which
could avoid non-SFINAEable errors, and should generally improve the
quality of diagnostics when passing initializer lists to variadic
functions.

4 years agoAMDGPU: Use default operands for clamp/omod
Matt Arsenault [Sat, 7 Sep 2019 22:42:27 +0000 (18:42 -0400)]
AMDGPU: Use default operands for clamp/omod

We have a lot of complex pattern variants that just set the source
modifiers that are really handled, and then set the output modifiers
to 0. We're unlikely to ever match output modifiers from the use
instruction side, and we already match clamp/omod in a separate pass.

4 years ago[WebAssembly] Fix landingpad-only case in Emscripten EH
Heejin Ahn [Tue, 7 Jan 2020 00:15:53 +0000 (16:15 -0800)]
[WebAssembly] Fix landingpad-only case in Emscripten EH

Summary:
Previously we didn't set `Changed` to true when there are only landing
pads but not invokes. This fixes it and we set `Changed` to true
whenever we have landing pads. (There can't be invokes without landing
pads, so that case is covered too)

The test case for this has to be a separate file because this pass is a
`ModulePass` and `Changed` is computed based on the whole module.

Reviewers: tlively

Subscribers: dschuff, sbc100, jgravelle-google, hiraditya, sunfish, llvm-commits

Tags: #llvm

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

4 years agoAMDGPU/GlobalISel: Legalize G_READCYCLECOUNTER
Matt Arsenault [Sat, 4 Jan 2020 17:50:18 +0000 (12:50 -0500)]
AMDGPU/GlobalISel: Legalize G_READCYCLECOUNTER

4 years ago[CodeGen][ObjC] Push the properties of a protocol before pushing the
Akira Hatanaka [Sat, 4 Jan 2020 16:32:49 +0000 (08:32 -0800)]
[CodeGen][ObjC] Push the properties of a protocol before pushing the
properties of the protocol it inherits

This fixes a bug where the type string for a @dynamic property of an
@implementation didn't have 'D' in it when the protocol it conforms to
redeclares the property declared in the base protocol.

rdar://problem/45503561

4 years ago[msan] Fix underflow in qsort interceptor.
Evgenii Stepanov [Tue, 7 Jan 2020 00:12:52 +0000 (16:12 -0800)]
[msan] Fix underflow in qsort interceptor.

4 years ago[NFC] Fixes -Wrange-loop-analysis warnings
Mark de Wever [Mon, 6 Jan 2020 23:49:41 +0000 (00:49 +0100)]
[NFC] Fixes -Wrange-loop-analysis warnings

This avoids new warnings due to D68912 adds -Wrange-loop-analysis to -Wall.

4 years agoAdd Triple::isX86()
Fangrui Song [Mon, 6 Jan 2020 18:16:28 +0000 (10:16 -0800)]
Add Triple::isX86()

Reviewed By: craig.topper, skan

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

4 years agoUse FileCheck instead of grep
Akira Hatanaka [Mon, 6 Jan 2020 23:45:27 +0000 (15:45 -0800)]
Use FileCheck instead of grep

4 years agoAMDGPU/GlobalISel: Select G_UADDE/G_USUBE
Matt Arsenault [Wed, 25 Dec 2019 14:06:05 +0000 (09:06 -0500)]
AMDGPU/GlobalISel: Select G_UADDE/G_USUBE

4 years agoAMDGPU/GlobalISel: Replace handling of boolean values
Matt Arsenault [Sat, 2 Nov 2019 16:30:59 +0000 (09:30 -0700)]
AMDGPU/GlobalISel: Replace handling of boolean values

This solves selection failures with generated selection patterns,
which would fail due to inferring the SGPR reg bank for virtual
registers with a set register class instead of VCC bank. Use
instruction selection would constrain the virtual register to a
specific class, so when the def was selected later the bank no longer
was set to VCC.

Remove the SCC reg bank. SCC isn't directly addressable, so it
requires copying from SCC to an allocatable 32-bit register during
selection, so these might as well be treated as 32-bit SGPR values.

Now any scalar boolean value that will produce an outupt in SCC should
be widened during RegBankSelect to s32. Any s1 value should be a
vector boolean during selection. This makes the vcc register bank
unambiguous with a normal SGPR during selection.

Summary of how this should now work:

- G_TRUNC is always a no-op, and never should use a vcc bank result.

- SALU boolean operations should be promoted to s32 in RegBankSelect
  apply mapping

- An s1 value means vcc bank at selection. The exception is for
  legalization artifacts that use s1, which are never VCC. All other
  contexts should infer the VCC register classes for s1 typed
  registers. The LLT for the register is now needed to infer the
  correct register class. Extensions with vcc sources should be
  legalized to a select of constants during RegBankSelect.

- Copy from non-vcc to vcc ensures high bits of the input value are
  cleared during selection.

- SALU boolean inputs should ensure the inputs are 0/1. This includes
  select, conditional branches, and carry-ins.

There are a few somewhat dirty details. One is that G_TRUNC/G_*EXT
selection ignores the usual register-bank from register class
functions, and can't handle truncates with VCC result banks. I think
this is OK, since the artifacts are specially treated anyway. This
does require some care to avoid producing cases with vcc. There will
also be no 100% reliable way to verify this rule is followed in
selection in case of register classes, and violations manifests
themselves as invalid copy instructions much later.

Standard phi handling also only considers the bank of the result
register, and doesn't insert copies to make the source banks
match. This doesn't work for vcc, so we have to manually correct phi
inputs in this case. We should add a verifier check to make sure there
are no phis with mixed vcc and non-vcc register bank inputs.

There's also some duplication with the LegalizerHelper, and some code
which should live in the helper. I don't see a good way to share
special knowledge about what types to use for intermediate operations
depending on the bank for example. Using the helper to replace
extensions with selects also seems somewhat awkward to me.

Another issue is there are some contexts calling
getRegBankFromRegClass that apparently don't have the LLT type for the
register, but I haven't yet run into a real issue from this.

This also introduces new unnecessary instructions in most cases, since
we don't yet try to optimize out the zext when the source is known to
come from a compare.

4 years agoTableGen/GlobalISel: Handle default operands that are used
Matt Arsenault [Tue, 22 Oct 2019 04:39:42 +0000 (21:39 -0700)]
TableGen/GlobalISel: Handle default operands that are used

Copy the logic from the existing handling in the DAG matcher emittter.

This will enable some AMDGPU pattern cleanups without breaking
GlobalISel tests, and eventually handle importing more patterns.

The test is a bit annoying since the sections seem to randomly sort
themselves if anything else is added in the future.

4 years agoGlobalISel: Implement lower for G_INTRINSIC_ROUND
Matt Arsenault [Tue, 24 Dec 2019 19:49:31 +0000 (14:49 -0500)]
GlobalISel: Implement lower for G_INTRINSIC_ROUND

Mostly copied from AMDGPU lowering implementation, except used
G_SITOFP instead of directly creating a select on -1.0, 0.0.

4 years agoChange the patterns to include the prefix '= ' so we don't pass errantly.
Jason Molenda [Mon, 6 Jan 2020 23:18:22 +0000 (15:18 -0800)]
Change the patterns to include the prefix '= ' so we don't pass errantly.
Looking at a sometimes-passing test case on a platform
where random values were being returned - sometimes
the expected digit ('1' or '2') would be included in the
random returned value.  Add a prefix to reduce the likelihood of
this a bit.

4 years ago[X86] Move an enum definition into a header to simplify future patches [NFC]
Philip Reames [Mon, 6 Jan 2020 23:13:45 +0000 (15:13 -0800)]
[X86] Move an enum definition into a header to simplify future patches [NFC]

4 years ago[msan] Check qsort input.
Evgenii Stepanov [Fri, 20 Dec 2019 20:07:04 +0000 (12:07 -0800)]
[msan] Check qsort input.

Summary:
Qsort interceptor suppresses all checks by unpoisoning the data in the
wrapper of a comparator function, and then unpoisoning the output array
as well.

This change adds an explicit run of the comparator on all elements of
the input array to catch any sanitizer bugs.

Reviewers: vitalybuka

Subscribers: #sanitizers, llvm-commits

Tags: #sanitizers, #llvm

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

4 years ago[NSArray] Remove a very old and deprecated formatter.
Davide Italiano [Mon, 6 Jan 2020 22:58:01 +0000 (14:58 -0800)]
[NSArray] Remove a very old and deprecated formatter.

Checked with the Foundation folks.

4 years ago[CMake] Pass symlink dependency to add_llvm_install_targets explicitly
Petr Hosek [Sat, 28 Dec 2019 00:25:43 +0000 (16:25 -0800)]
[CMake] Pass symlink dependency to add_llvm_install_targets explicitly

The install-${name}-stripped targets don't strip when ${name} is being
symlinked, e.g. llvm-ar or llvm-objcopy. The problem is that
llvm_install_symlink passes install-${dest} as a dependency of
install-${name}, e.g. install-llvm-ar becomes a dependency of both
install-llvm-ranlib and install-llvm-ranlib-stripped. What this means is
that when installing a distribution that contains both llvm-ar and
llvm-ranlib is that first the stripped version of llvm-ar is installed
(by the install-llvm-ar-stripped target) and then it's overwritten by an
unstripped version of llvm-ar bnecause install-llvm-ranlib-stripped has
install-llvm-ranlib as a dependency as mentioned earlier. To avoid this
issue, rather than passing the install-${dest} as dependency, we
introduce a new argument to add_llvm_install_targets for symlink target
which expands it into an appropriate dependency, i.e. install-${dest}
for install-${name} target and install-${dest}-stripped for
install-${name}-stripped.

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

4 years agoDon't rely on 'l'(ell) modifiers to indicate a label reference
Bill Wendling [Tue, 24 Dec 2019 00:57:41 +0000 (16:57 -0800)]
Don't rely on 'l'(ell) modifiers to indicate a label reference

Summary:
It's not necessary to use an 'l'(ell) modifier when referencing a label.
Treat block addresses and MBB references as if the modifier is used
anyway. This prevents us from generating references to ficticious
labels.

Reviewers: jyknight, nickdesaulniers, hfinkel

Subscribers: hiraditya, llvm-commits

Tags: #llvm

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

4 years ago[FileCheck] Remove FileCheck prefix in API
Thomas Preud'homme [Wed, 11 Dec 2019 23:48:01 +0000 (23:48 +0000)]
[FileCheck] Remove FileCheck prefix in API

Summary:
When FileCheck was made a library, types in the public API were renamed
to add a FileCheck prefix, such as Pattern to FileCheckPattern. Many
types were moved into a private interface and thus don't need this
prefix anymore. This commit removes those unneeded prefixes.

Reviewers: jhenderson, jdenny, probinson, grimar, arichardson, rnk

Reviewed By: jhenderson

Subscribers: hiraditya, llvm-commits

Tags: #llvm

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

4 years ago[PowerPC][NFC] Rename record instructions to use _rec suffix instead of o
Jinsong Ji [Mon, 6 Jan 2020 19:05:12 +0000 (19:05 +0000)]
[PowerPC][NFC] Rename record instructions to use _rec suffix instead of o

We use o suffix to indicate record form instuctions,
(as it is similar to dot '.' in mne?)

This was fine before, as we did not support XO-form.
However, with https://reviews.llvm.org/D66902,
we now have XO-form support.

It becomes confusing now to still use 'o' for record form,
and it is weird to have something like 'Oo' .

This patch rename all 'o' instructions to use '_rec' instead.
Also rename `isDot` to `isRecordForm`.

Reviewed By: #powerpc, hfinkel, nemanjai, steven.zhang, lkail

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

4 years ago[Diagnostic] make Wmisleading-indendation not warn about labels
Tyker [Mon, 6 Jan 2020 21:04:55 +0000 (22:04 +0100)]
[Diagnostic] make Wmisleading-indendation not warn about labels

Reviewers: aaron.ballman, xbolva00

Reviewed By: aaron.ballman

Subscribers: nickdesaulniers, nathanchance

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

4 years agoGlobalISel: Fix unsupported legalize action
Matt Arsenault [Mon, 9 Sep 2019 20:55:49 +0000 (16:55 -0400)]
GlobalISel: Fix unsupported legalize action

This would complain about invalid legalizer rules otherwise.

Mark some operations as unsupported for AMDGPU. This currently seems
to produce the same legalize error as when no rules are defined, but
eventually this should produce a proper user facing error.

4 years agoGlobalISel: Correct result type for G_FCMP in lowerFPTOUI
Matt Arsenault [Sat, 4 Jan 2020 22:06:47 +0000 (17:06 -0500)]
GlobalISel: Correct result type for G_FCMP in lowerFPTOUI

Using the final result type doesn't make any sense. Use the natural
default boolean type for the select condition.

4 years agoGlobalISel: Start adding computeNumSignBits to GISelKnownBits
Matt Arsenault [Sat, 4 Jan 2020 19:13:06 +0000 (14:13 -0500)]
GlobalISel: Start adding computeNumSignBits to GISelKnownBits

4 years agoAMDGPU: Fix legalizing f16 fpow
Matt Arsenault [Sat, 4 Jan 2020 20:48:46 +0000 (15:48 -0500)]
AMDGPU: Fix legalizing f16 fpow

The existing test only covered one case for r600. The use of
mul_legacy also looks suspicious to me, but leave it for now. The
patterns are also not making use of source modifiers.

4 years agoAMDGPU: Use ImmLeaf
Matt Arsenault [Mon, 6 Jan 2020 20:39:05 +0000 (15:39 -0500)]
AMDGPU: Use ImmLeaf

This solves one GlobalISel importer error, but the pattern still fails
for another reason.

4 years agoAMDGPU: Use ImmLeaf for inline immediate predicates
Matt Arsenault [Mon, 6 Jan 2020 19:39:13 +0000 (14:39 -0500)]
AMDGPU: Use ImmLeaf for inline immediate predicates

4 years agollc/MIR: Fix setFunctionAttributes for MIR functions
Matt Arsenault [Fri, 6 Dec 2019 18:36:34 +0000 (00:06 +0530)]
llc/MIR: Fix setFunctionAttributes for MIR functions

A random set of attributes are implemented by llc/opt forcing the
string attributes on the IR functions before processing anything. This
would not happen for MIR functions, which have not yet been created at
this point.

Use a callback in the MIR parser, purely to avoid dealing with the
ugliness that the command line flags are in a .inc file, and would
require allowing access to these flags from multiple places (either
from the MIR parser directly, or a new utility pass to implement these
flags). It would probably be better to cleanup the flag handling into
a separate library.

This is in preparation for treating more command line flags with a
corresponding function attribute in a more uniform way. The fast math
flags in particular have a messy system where the command line flag
sets the behavior from a function attribute if present, and otherwise
the command line flag. This means if any other pass tries to inspect
the function attributes directly, it will be inconsistent with the
intended behavior. This is also inconsistent with the current behavior
of -mcpu and -mattr, which overwrites any pre-existing function
attributes. I would like to move this to consistenly have the command
line flags not overwrite any pre-existing attributes, and to always
ensure the command line flags are consistent with the function
attributes.

4 years ago[X86] Improve v4i32->v4f64 uint_to_fp for AVX1/AVX2 targets.
Craig Topper [Mon, 6 Jan 2020 22:06:20 +0000 (14:06 -0800)]
[X86] Improve v4i32->v4f64 uint_to_fp for AVX1/AVX2 targets.

Use zext+or+fsub to do the conversion. Similar to D71971.

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

4 years ago[lldb/Docs] Describe optional dependencies on build page.
Jonas Devlieghere [Mon, 6 Jan 2020 21:57:55 +0000 (13:57 -0800)]
[lldb/Docs] Describe optional dependencies on build page.

List the different CMake flags controlling the optional dependencies as
per the discussion on the mailing list:

http://lists.llvm.org/pipermail/lldb-dev/2020-January/015867.html

4 years ago[LegalizeTypes] Add widening support for STRICT_FSETCC/FSETCCS
Craig Topper [Mon, 6 Jan 2020 21:37:47 +0000 (13:37 -0800)]
[LegalizeTypes] Add widening support for STRICT_FSETCC/FSETCCS

This patch adds widening which really just scalarizes because we don't have a strategy for the extra elements we would need to pad with.

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

4 years ago[X86] Rename vec-strict-*-cmp.ll to vec-strict-cmp-*.ll to match other strict files...
Craig Topper [Mon, 6 Jan 2020 21:34:45 +0000 (13:34 -0800)]
[X86] Rename vec-strict-*-cmp.ll to vec-strict-cmp-*.ll to match other strict files wich have the size at the end. NFC

4 years ago[OPENMP50]Support lastprivate conditional updates in inc/dec unary ops.
Alexey Bataev [Mon, 6 Jan 2020 21:14:34 +0000 (16:14 -0500)]
[OPENMP50]Support lastprivate conditional updates in inc/dec unary ops.

Added support for checking of updates of variables used in unary
pre(pos) inc/dec expressions.

4 years ago [NFC] Test commit, revert whitespace change
stevewan [Mon, 6 Jan 2020 21:28:13 +0000 (16:28 -0500)]
 [NFC] Test commit, revert whitespace change

As per the Developer Policy, upon obtaining commit access.

4 years ago[NFC] Test commit, whitespace change
stevewan [Mon, 6 Jan 2020 21:24:27 +0000 (16:24 -0500)]
[NFC] Test commit, whitespace change

As per the Developer Policy, upon obtaining commit access.

4 years ago[x86] add tests for concat self + shuffle; NFC
Sanjay Patel [Mon, 6 Jan 2020 20:24:30 +0000 (15:24 -0500)]
[x86] add tests for concat self + shuffle; NFC

4 years ago[OpenMP] Fix incorrect property of __has_attribute() macro
Kelvin Li [Mon, 6 Jan 2020 20:00:10 +0000 (15:00 -0500)]
[OpenMP] Fix incorrect property of __has_attribute() macro

__has_attribute(fallthough) -> __has_attribute(fallthrough)

Submitted by: kiszk (Kazuaki Ishizaki <ishizaki@jp.ibm.com>)

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