platform/upstream/llvm.git
4 years ago[llvm-symbolizer]Fix printing of malformed address values not passed via stdin
Xuanda Yang [Wed, 8 Jan 2020 10:37:41 +0000 (18:37 +0800)]
[llvm-symbolizer]Fix printing of malformed address values not passed via stdin

Summary:
relates https://bugs.llvm.org/show_bug.cgi?id=44443

Adding missing newline when printing bad input values.

Fix testcase

Reviewers: jhenderson

Reviewed By: jhenderson

Subscribers: rupprecht, llvm-commits

Tags: #llvm

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

4 years agoRevert "[InstCombine] fold zext of masked bit set/clear"
Kadir Cetinkaya [Wed, 8 Jan 2020 10:21:21 +0000 (11:21 +0100)]
Revert "[InstCombine] fold zext of masked bit set/clear"

This reverts commit a041c4ec6f7aa659b235cb67e9231a05e0a33b7d.

This looks like a non-trivial change and there has been no code
reviews (at least there were no phabricator revisions attached to the
commit description). It is also causing a regression in one of our
downstream integration tests, we haven't been able to come up with a
minimal reproducer yet.

4 years agoAArch64: add missing Apple CPU names and use them by default.
Tim Northover [Fri, 15 Nov 2019 12:39:56 +0000 (12:39 +0000)]
AArch64: add missing Apple CPU names and use them by default.

Apple's CPUs are called A7-A13 in official communication, occasionally with
weird suffixes which we probably don't need to care about. This adds each one
and describes its features. It also switches the default CPU to the canonical
name for Cyclone, but leaves legacy support in so that existing bitcode still
compiles.

4 years ago[lldb][NFC] Remove redundant ClangASTContext constructor that takes ArchSpec
Raphael Isemann [Wed, 8 Jan 2020 08:02:55 +0000 (09:02 +0100)]
[lldb][NFC] Remove redundant ClangASTContext constructor that takes ArchSpec

ArchSpec has a superset of the information of llvm::Triple but the ClangASTContext
just uses the Triple part of it. This deletes the ArchSpec constructor and all
the code creating ArchSpecs and instead just uses the llvm::Triple constructor
for ClangASTContext.

4 years ago[libcxx][test] Fix span tests.
Stephan T. Lavavej [Wed, 8 Jan 2020 07:33:52 +0000 (23:33 -0800)]
[libcxx][test] Fix span tests.

span.cons/container.pass.cpp
N4842 22.7.3.2 [span.cons]/13 constrains span's range constructor
for ranges::contiguous_range (among other criteria).

24.4.5 [range.refinements]/2 says that contiguous_range requires data(),
and (via contiguous_range, random_access_range, bidirectional_range,
forward_range, input_range, range) it also requires begin() and end()
(see 24.4.2 [range.range]/1).

Therefore, IsAContainer needs to provide begin() and end().

(Detected by MSVC's concept-constrained implementation.)

span.cons/stdarray.pass.cpp
This test uses std::array, so it must include <array>.
<span> isn't guaranteed to drag in <array>.

(Detected by MSVC's implementation which uses a forward declaration to
avoid dragging in <array>, for increased compiler throughput.)

span.objectrep/as_bytes.pass.cpp
span.objectrep/as_writable_bytes.pass.cpp
Testing `sp.extent == std::dynamic_extent` triggers MSVC warning
C4127 "conditional expression is constant". Using `if constexpr` is a
simple way to avoid this without disrupting anyone else (as span
requires C++20 mode).

span.tuple/get.pass.cpp
22.7.3.2 [span.cons]/4.3: "Preconditions: If extent is not equal to
dynamic_extent, then count is equal to extent."

These lines were triggering undefined behavior (detected by assertions
in MSVC's implementation).

I changed the count arguments in the first two chunks, followed by
changing the span extents, in order to preserve the test's coverage
and follow the existing pattern.

span.cons/span.pass.cpp
22.7.3.2 [span.cons]/18.1 constrains span's converting constructor with
"Extent == dynamic_extent || Extent == OtherExtent is true".

This means that converting from dynamic extent to static extent is
not allowed. (Other constructors tested elsewhere, like
span(It first, size_type count), can be used to write such code.)

As this is the test for the converting constructor, I have:

* Removed the "dynamic -> static" case from checkCV(), which is
comprehensive.

* Changed the initialization of std::span<T, 0> s1{}; in
testConstexprSpan() and testRuntimeSpan(), because s1 is used below.

* Removed ASSERT_NOEXCEPT(std::span<T, 0>{s0}); from those functions,
as they are otherwise comprehensive.

* Deleted testConversionSpan() entirely. Note that this could never
compile (it had a bool return type, but forgot to say `return`). And it
couldn't have provided useful coverage, as the /18.2 constraint
"OtherElementType(*)[] is convertible to ElementType(*)[]"
permits only cv-qualifications, which are already tested by checkCV().

4 years ago[clangd] Add xref for macros to FileIndex.
Utkarsh Saxena [Thu, 12 Dec 2019 11:12:17 +0000 (12:12 +0100)]
[clangd] Add xref for macros to FileIndex.

Summary:
Adds macro references to the dynamic index.
Tests added.
Also exposed a new API to convert path to URI in URI.h

Reviewers: hokein

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

Tags: #clang

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

4 years ago[libc] Add a convenience CMake rule to add testsuites.
Siva Chandra Reddy [Tue, 7 Jan 2020 19:09:40 +0000 (11:09 -0800)]
[libc] Add a convenience CMake rule to add testsuites.

Summary:
This rule helps avoid repeated setting of check-libc's dependency on the
various testsuites.

Reviewers: abrachet

Subscribers: mgorny, MaskRay, tschuett, libc-commits

Tags: #libc-project

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

4 years ago[NFC][Test] Add the option -enable-no-signed-zeros-fp-math for test
QingShan Zhang [Wed, 8 Jan 2020 06:48:51 +0000 (06:48 +0000)]
[NFC][Test] Add the option -enable-no-signed-zeros-fp-math for test
fma-combine.ll

4 years ago[lldb/CMake] Only auto-enable Python when SWIG is found
Jonas Devlieghere [Wed, 8 Jan 2020 05:53:33 +0000 (21:53 -0800)]
[lldb/CMake] Only auto-enable Python when SWIG is found

As correctly pointed out by Martin on the mailing list, Python should
only be auto-enabled if SWIG is found as well. This moves the logic of
finding SWIG into FindPythonInterpAndLibs to make that possible.

To make diagnosing easier I've included a status message to convey why
Python support is disabled.

4 years ago[lldb/Test] Try to appease the Windows bot
Jonas Devlieghere [Wed, 8 Jan 2020 05:36:19 +0000 (21:36 -0800)]
[lldb/Test] Try to appease the Windows bot

In TestConvenienceVariables I changed %t from a file to a directory.
This tripped up mkdir which can't deal with an existing file at the
given location. In order to solve this issue on the bots I added an
`rm -rf %t` statement, but now the Windows bot complains that "This
function is not supported on this system".

If you never ran the test suite wit this temporary workaround, the test
might fail. If this happens please remove what %t expands to in the lit
output and rerun the test.

4 years ago[X86] Adding fp128 support for strict fcmp
Wang, Pengfei [Thu, 26 Dec 2019 14:16:46 +0000 (22:16 +0800)]
[X86] Adding fp128 support for strict fcmp

Summary: Adding fp128 support for strict fcmp

Reviewers: craig.topper, LiuChen3, andrew.w.kaylor, RKSimon, uweigand

Subscribers: hiraditya, llvm-commits, LuoYuanke

Tags: #llvm

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

4 years ago[RISCV] Fix evalutePCRelLo for symbols at the end of a fragment
James Clarke [Wed, 8 Jan 2020 04:32:04 +0000 (04:32 +0000)]
[RISCV] Fix evalutePCRelLo for symbols at the end of a fragment

Summary:
This is analogous to D58943, which correctly finds the corresponding
fixup. However, when linker relaxations are disabled and we evaluate the
fixup, we need to also ensure we use an offset of 0 rather than the size
of the previous fragment.

Reviewers: asb, efriedma, lenary

Reviewed By: efriedma

Subscribers: hiraditya, rbar, johnrusso, simoncook, sabuasal, niosHD, kito-cheng, shiva0217, MaskRay, zzheng, edward-jones, rogfer01, MartinMosbeck, brucehoult, the_o, rkruppe, PkmX, jocewei, psnobl, benna, Jim, s.egerton, pzheng, sameer.abuasal, apazos, luismarques, llvm-commits

Tags: #llvm

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

4 years ago[mlir][spirv] Add lowering for std.fpext, std.fptrunc, std.sitofp.
Denis Khalikov [Wed, 8 Jan 2020 03:11:59 +0000 (22:11 -0500)]
[mlir][spirv] Add lowering for std.fpext, std.fptrunc, std.sitofp.

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

4 years agoRevert "[mlir][spirv] Add lowering for std.fpext, std.fptrunc, std.sitofp."
Lei Zhang [Wed, 8 Jan 2020 03:11:17 +0000 (22:11 -0500)]
Revert "[mlir][spirv] Add lowering for std.fpext, std.fptrunc, std.sitofp."

This reverts commit 7e7f849a6d94f77f1a29630419acb7226051f4b6 because
it recorded the wrong commit author.

4 years agoAMDGPU: Annotate EXTRACT_SUBREGs with source register classes
Matt Arsenault [Wed, 8 Jan 2020 02:11:56 +0000 (21:11 -0500)]
AMDGPU: Annotate EXTRACT_SUBREGs with source register classes

This partially fixes GlobalISel import of the patterns, but removes a
lot of entriess from the end of the skipped pattern log.

4 years ago[mlir][spirv] Add lowering for std cmp ops.
Denis Khalikov [Wed, 8 Jan 2020 02:47:49 +0000 (21:47 -0500)]
[mlir][spirv] Add lowering for std cmp ops.

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

4 years ago[mlir][spirv] Add lowering for standard bit ops
Denis Khalikov [Wed, 8 Jan 2020 02:40:42 +0000 (21:40 -0500)]
[mlir][spirv] Add lowering for standard bit ops

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

4 years ago[docs] Fix duplicate explicit target name: developer policy
Jim Lin [Wed, 8 Jan 2020 02:43:45 +0000 (10:43 +0800)]
[docs] Fix duplicate explicit target name: developer policy

4 years ago[mlir][spirv] Add lowering for std.fpext, std.fptrunc, std.sitofp.
Lei Zhang [Wed, 8 Jan 2020 02:28:26 +0000 (21:28 -0500)]
[mlir][spirv] Add lowering for std.fpext, std.fptrunc, std.sitofp.

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

4 years ago[SCEV] get more accurate range for AddExpr with wrap flag.
czhengsz [Wed, 8 Jan 2020 01:52:37 +0000 (20:52 -0500)]
[SCEV] get more accurate range for AddExpr with wrap flag.

Reviewed By: nikic

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

4 years ago[docs] Improve HowTo commit changes from git
Jim Lin [Wed, 8 Jan 2020 01:48:01 +0000 (09:48 +0800)]
[docs] Improve HowTo commit changes from git

Summary: As a novice here I tried to `git push` my changes for a while before figuring out the correct workflow which is described on other pages. This small change doesn't reduce redundancy between those pages, but at least readers can follow the links now.

Reviewers: Kokan, Jim

Reviewed By: Kokan, Jim

Subscribers: riccibruno, kiszk, llvm-commits

Tags: #llvm

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

4 years ago[libcxx] fix incorrect attribute property
Kazuaki Ishizaki [Wed, 8 Jan 2020 01:35:12 +0000 (09:35 +0800)]
[libcxx] fix incorrect attribute property

Summary:
`__has_attribute(fallthough)` -> `__has_attribute(fallthrough)`
This is a follow-up of https://reviews.llvm.org/D72287

Reviewers: EricWF, mclow.lists, Jim

Reviewed By: Jim

Subscribers: christof, ldionne, libcxx-commits

Tags: #libc

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

4 years agoXFAIL load_extension.ll for all targets currently - it's failing on
Eric Christopher [Wed, 8 Jan 2020 01:00:23 +0000 (17:00 -0800)]
XFAIL load_extension.ll for all targets currently - it's failing on
additional platforms than just darwin.

4 years agoRevert "Re-land "[lldb/Lua] Add string conversion operator for SBTarget.""
Jonas Devlieghere [Wed, 8 Jan 2020 00:45:43 +0000 (16:45 -0800)]
Revert "Re-land "[lldb/Lua] Add string conversion operator for SBTarget.""

This was returning a pointer to a stack-allocated memory location. This
works for Python where we return a PythonString which must own the
underlying string.

4 years agoRewrite comment about what watchpoints Aarch64 supports.
Jason Molenda [Wed, 8 Jan 2020 00:12:49 +0000 (16:12 -0800)]
Rewrite comment about what watchpoints Aarch64 supports.

4 years ago[GVN/FP] Considate logic for reasoning about equality vs equivalance for floats
Philip Reames [Wed, 8 Jan 2020 00:03:51 +0000 (16:03 -0800)]
[GVN/FP] Considate logic for reasoning about equality vs equivalance for floats

Factor out common logic into some reasonable commented helper functions. In the process, ensure that the in-block vs cross-block cases are handled the same. They previously weren't.

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

4 years agoFix warnings as errors that occur on sanitizer-x86_64-linux
Daniel Sanders [Wed, 8 Jan 2020 00:02:06 +0000 (16:02 -0800)]
Fix warnings as errors that occur on sanitizer-x86_64-linux

4 years ago[PowerPC] Default ppc64 linux-gnu/freebsd to -fno-PIC
Fangrui Song [Tue, 7 Jan 2020 22:21:39 +0000 (14:21 -0800)]
[PowerPC] Default ppc64 linux-gnu/freebsd to -fno-PIC

According to D53384, the default was switched from -fno-PIC to -fPIC to
work around a -fsanitize=leak bug on big-endian.

This gratuitous difference between little-endian and big-endian is
undesired, and not acceptable on powerpc64-unknown-freebsd.  If
-fsanitize=leak still has the problem, we should consider defaulting to
-fPIC/-fPIE only when -fsanitize=leak is specified (see SanitizerArgs::requiresPIE())

powerpc64-ibm-aix is unaffected: it still defaults to -fPIC.
powerpc64-linux-musl is unaffected (-fPIE since D39588): it still defaults to -fPIE.

Reviewed By: #powerpc, jhibbits

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

4 years ago[AArch64][GlobalISel] Fold a chain of two G_PTR_ADDs of constant offsets.
Amara Emerson [Tue, 7 Jan 2020 18:52:26 +0000 (10:52 -0800)]
[AArch64][GlobalISel] Fold a chain of two G_PTR_ADDs of constant offsets.

E.g.
%addr1 = G_PTR_ADD %base, G_CONSTANT 20
%addr2 = G_PTR_ADD %addr1, G_CONSTANT 8
  -->
%addr2 = G_PTR_ADD %base, G_CONSTANT 28

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

4 years ago[X86] Add SSE4.1 command lines to vec-strict-inttofp-128.ll to cover the v2i64->v2f32...
Craig Topper [Tue, 7 Jan 2020 21:50:59 +0000 (13:50 -0800)]
[X86] Add SSE4.1 command lines to vec-strict-inttofp-128.ll to cover the v2i64->v2f32 strict_uitofp codegen. NFC

4 years agoRevert "Allow output constraints on "asm goto""
Bill Wendling [Tue, 7 Jan 2020 21:43:04 +0000 (13:43 -0800)]
Revert "Allow output constraints on "asm goto""

This reverts commit 52366088a8e42c2f1e96e8430b84b8b65ec3f7bc.

I accidentally pushed this before supporting changes.

4 years agoRe-land "[lldb/Lua] Add string conversion operator for SBTarget."
Jonas Devlieghere [Tue, 7 Jan 2020 21:23:52 +0000 (13:23 -0800)]
Re-land "[lldb/Lua] Add string conversion operator for SBTarget."

Extend the SBTarget class with a string conversion operator and reuse
the same code between Python and Lua. This should happen for all the SB
classes, but I'm doing just this one as an example and for use in a test
case.

4 years agoAllow output constraints on "asm goto"
Bill Wendling [Tue, 7 Jan 2020 20:53:44 +0000 (12:53 -0800)]
Allow output constraints on "asm goto"

Summary:
Remove the restrictions that preventing "asm goto" from returning non-void
values. The values returned by "asm goto" are only valid on the "fallthrough"
path.

Reviewers: jyknight, nickdesaulniers, hfinkel

Reviewed By: jyknight, nickdesaulniers

Subscribers: rsmith, hiraditya, llvm-commits, cfe-commits, craig.topper, rnk

Tags: #clang, #llvm

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

4 years agoAMDGPU/GlobalISel: Fix scalar G_SELECT for arbitrary pointers
Matt Arsenault [Tue, 7 Jan 2020 21:24:42 +0000 (16:24 -0500)]
AMDGPU/GlobalISel: Fix scalar G_SELECT for arbitrary pointers

4e85ca9562a588eba491e44bcbf73cb2f419780f missed updating the legal
condition type set for pointers with any unrecognized address space.

4 years agoAMDGPU/GlobalISel: Add some missing G_SELECT testcases
Matt Arsenault [Tue, 7 Jan 2020 21:04:43 +0000 (16:04 -0500)]
AMDGPU/GlobalISel: Add some missing G_SELECT testcases

4 years agoAMDGPU/GlobalISel: Fix missing test for s16 icmp
Matt Arsenault [Tue, 7 Jan 2020 20:31:03 +0000 (15:31 -0500)]
AMDGPU/GlobalISel: Fix missing test for s16 icmp

4 years agoAMDGPU: Apply i16 add->sub pattern with zext to i32
Matt Arsenault [Tue, 7 Jan 2020 18:32:03 +0000 (13:32 -0500)]
AMDGPU: Apply i16 add->sub pattern with zext to i32

This was only applying the deeper nested zext pattern, and missing the
special case code size fold.

4 years ago[clang-tidy] modernize-use-using uses AST and now supports struct defintions and...
Mitchell Balan [Tue, 7 Jan 2020 18:49:55 +0000 (13:49 -0500)]
[clang-tidy] modernize-use-using uses AST and now supports struct defintions and multiple types in a typedef

Summary:
It now handles `typedef`s that include comma-separated multiple types, and handles embedded struct definitions, which previously could not be automatically converted.

For example, with this patch `modernize-use-using` now can convert:

typedef struct { int a; } R_t, *R_p;

to:

using R_t = struct { int a; };
using R_p = R_t*;

`-ast-dump` showed that the `CXXRecordDecl` definitions and multiple `TypedefDecl`s come consecutively in the tree, so `check()` stores information between calls to determine when it is receiving a second or additional `TypedefDecl` within a single `typedef`, or when the current `TypedefDecl` refers to an embedded `CXXRecordDecl` like a `struct`.

Reviewers: alexfh, aaron.ballman

Patch by: poelmanc

Subscribers: riccibruno, sammccall, cfe-commits, aaron.ballman

Tags: clang-tools-extra, clang

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

4 years ago[libc++] Add additional benchmark functions to libcxx/benchmarks/string.bench
Eric Fiselier [Tue, 7 Jan 2020 21:31:06 +0000 (16:31 -0500)]
[libc++] Add additional benchmark functions to libcxx/benchmarks/string.bench

This change adds the following benchmarks:

- StringAssignStr
Assign a const basic::string& value

- StringAssignAsciiz
Assign a const char* asciiz value

StringAssignAsciizMix
Assign mixed long/short const char* asciiz values

- StringResizeDefaultInit
Resize default init benchmark

Patch by Martijn Vels (mvels@google.com)
Reviewed as D72343

4 years ago[X86] Enable v2i64->v2f32 uint_to_fp code in ReplaceNodeResults on SSE4.1 target
Craig Topper [Tue, 7 Jan 2020 21:25:29 +0000 (13:25 -0800)]
[X86] Enable v2i64->v2f32 uint_to_fp code in ReplaceNodeResults on SSE4.1 target

Now that we generate decent code for (v2i64 (setlt zero, X)) on pre-sse4.2 targets I think we can use this now.

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

4 years ago[lldb/Test] Remove old binary created by TestConvenienceVariables
Jonas Devlieghere [Tue, 7 Jan 2020 21:21:47 +0000 (13:21 -0800)]
[lldb/Test] Remove old binary created by TestConvenienceVariables

On a dirty build directory the new mkdir fails because the file already
exists and is not a directory.

4 years ago[lldb/Test] Make TestConvenienceVariables more strict
Jonas Devlieghere [Tue, 7 Jan 2020 21:05:39 +0000 (13:05 -0800)]
[lldb/Test] Make TestConvenienceVariables more strict

This test was passing even when the output of lldb.target was empty.
I've made the test more strict by checking explicitly for the target
name and by using CHECK-NEXT lines.

4 years ago[gicombiner] Correct 64f1bb5cd2c to account for MSVC's %p format
Daniel Sanders [Sat, 4 Jan 2020 00:51:28 +0000 (16:51 -0800)]
[gicombiner] Correct 64f1bb5cd2c to account for MSVC's %p format

4 years agoRemove extraneous semicolon.
Bill Wendling [Tue, 7 Jan 2020 20:48:17 +0000 (12:48 -0800)]
Remove extraneous semicolon.

4 years ago[x86] add tests for extract-of-concat; NFC
Sanjay Patel [Tue, 7 Jan 2020 20:48:21 +0000 (15:48 -0500)]
[x86] add tests for extract-of-concat; NFC

4 years agoRevert "[lldb/Lua] Add string conversion operator for SBTarget."
Jonas Devlieghere [Tue, 7 Jan 2020 20:46:01 +0000 (12:46 -0800)]
Revert "[lldb/Lua] Add string conversion operator for SBTarget."

This reverts commit 640d0ba8760051afc002c672121c6989517fc94e.

4 years ago[cmake] Use source-groups in Polly.
Christopher Tetreault [Tue, 7 Jan 2020 20:15:07 +0000 (14:15 -0600)]
[cmake] Use source-groups in Polly.

Configure CMake to setup source-groups for Polly. Source groups
describe how source files should be organized in IDEs. By default, all
headers are dumped into one folder under PollyCore and all source files
into another. On disk, these files are organized into folders, but this
isn't reflected in the IDE. This change uses CMake source groups to have
the IDE reflect the on disk layout. This will make it easier to visualize
the project structure for users of Visual Studio and XCode

Patch by Christopher Tetreault <ctetreau@quicinc.com>

Reviewed By: Meinersbur, grosser

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

4 years agoAMDGPU: Add baseline test for missing pattern
Matt Arsenault [Tue, 7 Jan 2020 18:18:51 +0000 (13:18 -0500)]
AMDGPU: Add baseline test for missing pattern

The optimization to turn an add into a sub isn't triggering when the
pattern to use the zeroed high bits is used.

4 years agoAMDGPU: Remove VOP3Mods0Clamp0OMod
Matt Arsenault [Tue, 7 Jan 2020 17:02:11 +0000 (12:02 -0500)]
AMDGPU: Remove VOP3Mods0Clamp0OMod

Now that overridable default operands work, there's no reason to use
complex patterns to just produce 0s.

4 years agoAMDGPU: Fix misleading, misplaced end block comments
Matt Arsenault [Tue, 7 Jan 2020 18:12:12 +0000 (13:12 -0500)]
AMDGPU: Fix misleading, misplaced end block comments

4 years agoAMDGPU: Use ImmLeaf
Matt Arsenault [Tue, 7 Jan 2020 17:32:08 +0000 (12:32 -0500)]
AMDGPU: Use ImmLeaf

4 years agoAMDGPU: Fix not using v_cvt_f16_[iu]16
Matt Arsenault [Mon, 30 Sep 2019 17:39:33 +0000 (13:39 -0400)]
AMDGPU: Fix not using v_cvt_f16_[iu]16

We weren't treating i16->f16 casts as legal on targets with these
instructions, and always using a pair of casts through i32.

4 years ago[lldb/Lua] Add string conversion operator for SBTarget.
Jonas Devlieghere [Tue, 7 Jan 2020 19:11:38 +0000 (11:11 -0800)]
[lldb/Lua] Add string conversion operator for SBTarget.

Extend the SBTarget class with a string conversion operator and reuse
the same code between Python and Lua. This should happen for all the SB
classes, but I'm doing just this one as an example and for use in a test
case.

4 years ago[cmake] Use relative cmake binary dir for processing pass plugins.
Michael Kruse [Tue, 7 Jan 2020 17:41:14 +0000 (11:41 -0600)]
[cmake] Use relative cmake binary dir for processing pass plugins.

https://reviews.llvm.org/D61446 introduced a new function to process
pass plugins that used CMAKE_BINARY_DIR. This is problematic when LLVM
is a subproject. Instead use LLVM_BINARY_DIR to get the right relative
directory for cmake.

Patch by Alan Baker <alanbaker@google.com>

Reviewed By: Meinersbur

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

4 years ago[PowerPC][Triple] Use elfv2 on freebsd>=13 and linux-musl
Fangrui Song [Tue, 7 Jan 2020 17:54:10 +0000 (09:54 -0800)]
[PowerPC][Triple] Use elfv2 on freebsd>=13 and linux-musl

Summary:
Every powerpc64le platform uses elfv2.

For powerpc64, the environments "elfv1" and "elfv2" were added for
FreeBSD ELFv1->ELFv2 migration in D61950.  FreeBSD developers have
decided to use OS versions to select ABI, and no one is relying on the
environments.

Also use elfv2 on powerpc64-linux-musl.

Users can always use -mabi=elfv1 and -mabi=elfv2 to override the default
ABI.

Reviewed By: adalava

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

4 years ago[test] Move ppc64 tests from test/Preprocessor/init.c to init-ppc64.c
Fangrui Song [Tue, 7 Jan 2020 18:41:13 +0000 (10:41 -0800)]
[test] Move ppc64 tests from test/Preprocessor/init.c to init-ppc64.c

4 years ago[OPENMP]Reduce calls for the mangled names.
Alexey Bataev [Tue, 7 Jan 2020 19:11:45 +0000 (14:11 -0500)]
[OPENMP]Reduce calls for the mangled names.

Use canonical decls instead of mangled names in the set of already
emitted decls. This allows to reduce the number of function calls for
getting declarations mangled names and speedup the compilation.

4 years ago[MachineOutliner][AArch64] Save + restore LR in noreturn functions
Jessica Paquette [Tue, 7 Jan 2020 19:12:32 +0000 (11:12 -0800)]
[MachineOutliner][AArch64] Save + restore LR in noreturn functions

Conservatively always save + restore LR in noreturn functions.

These functions do not end in a RET, and so they aren't guaranteed to have an
instruction which uses LR in any way. So, as a result, you can end up in
unfortunate situations where you can't backtrace out of these functions in a
debugger.

Remove the old noreturn test, and add a new one which is more descriptive.

Remove the restriction that we can't outline from noreturn functions as well
since we now do the right thing.

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.