Skip to content
  1. Jun 11, 2019
    • Jordan Rupprecht's avatar
      [docs] Add "GNU binutils Replacements" section to command guide · 4c3722ae
      Jordan Rupprecht authored
      Summary:
      This splits out a section in the command guide for llvm tools that can be used as replacements for GNU tools. For pages that didn't exist, I added stub pages that can be individually filled in by followup patches.
      
      Tested by running `ninja docs-llvm-html` and inspecting locally.
      
      Reviewers: jhenderson, MaskRay, grimar, alexshap
      
      Reviewed By: jhenderson, MaskRay, grimar
      
      Subscribers: smeenai, arphaman, llvm-commits
      
      Tags: #llvm
      
      Differential Revision: https://reviews.llvm.org/D63014
      
      llvm-svn: 363100
      4c3722ae
    • Marshall Clow's avatar
      Mark CTAD fail tests for set/multiset as XFAIL for older compilers that give... · 903d3db5
      Marshall Clow authored
      Mark CTAD fail tests for set/multiset as XFAIL for older compilers that give different error messages
      
      llvm-svn: 363099
      903d3db5
    • Antonio Afonso's avatar
      Add support to read aux vector values · 943faef1
      Antonio Afonso authored
      Summary:
      This is the second patch to improve module loading in a series that started here (where I explain the motivation and solution): https://reviews.llvm.org/D62499
      
      I need to read the aux vector to know where the r_debug map with the loaded libraries are.
      The AuxVector class was made generic so it could be reused between the POSIX-DYLD plugin and NativeProcess*. The class itself ended up in the ProcessUtility plugin.
      
      Reviewers: clayborg, xiaobai, labath, JDevlieghere
      
      Reviewed By: clayborg, labath, JDevlieghere
      
      Subscribers: emaste, JDevlieghere, mgorny, lldb-commits
      
      Tags: #lldb
      
      Differential Revision: https://reviews.llvm.org/D62500
      
      llvm-svn: 363098
      943faef1
    • Marshall Clow's avatar
    • Amara Emerson's avatar
      [GlobalISel] Add a G_JUMP_TABLE opcode. · d133c159
      Amara Emerson authored
      This opcode generates a pointer to the address of the jump table
      specified by the source operand, which is a jump table index.
      
      It will be used in conjunction with an upcoming G_BRJT opcode to support
      jump table codegen with GlobalISel.
      
      Differential Revision: https://reviews.llvm.org/D63111
      
      llvm-svn: 363096
      d133c159
    • Kostya Kortchinsky's avatar
      [scudo][standalone] Unmap memory in tests · 624a24e1
      Kostya Kortchinsky authored
      Summary:
      The more tests are added, the more we are limited by the size of the
      address space on 32-bit. Implement `unmapTestOnly` all around (like it
      is in sanitzer_common) to be able to free up some memory.
      This is not intended to be a proper "destructor" for an allocator, but
      allows us to not fail due to having no memory left.
      
      Reviewers: morehouse, vitalybuka, eugenis, hctim
      
      Reviewed By: morehouse
      
      Subscribers: delcypher, jfb, #sanitizers, llvm-commits
      
      Tags: #llvm, #sanitizers
      
      Differential Revision: https://reviews.llvm.org/D63146
      
      llvm-svn: 363095
      624a24e1
    • Alina Sbirlea's avatar
      [MemorySSA] When applying updates, clean unnecessary Phis. · cb4ed8a7
      Alina Sbirlea authored
      Summary: After applying a set of insert updates, there may be trivial Phis left over. Clean them up.
      
      Reviewers: george.burgess.iv
      
      Subscribers: jlebar, Prazek, llvm-commits
      
      Tags: #llvm
      
      Differential Revision: https://reviews.llvm.org/D63033
      
      llvm-svn: 363094
      cb4ed8a7
    • Cameron McInally's avatar
      [NFC][CodeGen] Add unary FNeg tests to X86/combine-fcopysign.ll... · e04c4b6a
      Cameron McInally authored
      [NFC][CodeGen] Add unary FNeg tests to X86/combine-fcopysign.ll X86/dag-fmf-cse.ll X86/fast-isel-fneg.ll X86/fdiv.ll
      
      llvm-svn: 363093
      e04c4b6a
    • Eric Fiselier's avatar
      Check in test that demonstrates ABI break for std::function. · 5d6626c7
      Eric Fiselier authored
      Our C++03 and C++11 implementations of function are not ABI
      compatible. I've added a "test" that demonstrates this.
      
      llvm-svn: 363092
      5d6626c7
    • Alina Sbirlea's avatar
      Only passes that preserve MemorySSA must mark it as preserved. · 3cef1f7d
      Alina Sbirlea authored
      Summary:
      The method `getLoopPassPreservedAnalyses` should not mark MemorySSA as
      preserved, because it's being called in a lot of passes that do not
      preserve MemorySSA.
      Instead, mark the MemorySSA analysis as preserved by each pass that does
      preserve it.
      These changes only affect the new pass mananger.
      
      Reviewers: chandlerc
      
      Subscribers: mehdi_amini, jlebar, Prazek, george.burgess.iv, llvm-commits
      
      Tags: #llvm
      
      Differential Revision: https://reviews.llvm.org/D62536
      
      llvm-svn: 363091
      3cef1f7d
    • Louis Dionne's avatar
      [libc++] Implement deduction guides for <set> · e20865c3
      Louis Dionne authored
      This is part of C++17's P0433.
      
      Thanks to Arthur O'Dwyer for the patch.
      
      Differential Revision: https://reviews.llvm.org/D58582
      
      llvm-svn: 363090
      e20865c3
    • Amy Huang's avatar
      Deduplicate S_CONSTANTs in LLD. · 9970817c
      Amy Huang authored
      Summary: Deduplicate S_CONSTANTS when linking, if they have the same value.
      
      Reviewers: rnk
      
      Subscribers: hiraditya, llvm-commits
      
      Tags: #llvm
      
      Differential Revision: https://reviews.llvm.org/D63151
      
      llvm-svn: 363089
      9970817c
    • Richard Smith's avatar
      Remove redundant check for whether a DeclRefExpr that names a capture · 36bd1c90
      Richard Smith authored
      constitutes an odr-use.
      
      We now track this accurately on the DeclRefExpr.
      
      llvm-svn: 363088
      36bd1c90
    • Richard Smith's avatar
      For DR712: store on a MemberExpr whether it constitutes an odr-use. · 1bbad593
      Richard Smith authored
      llvm-svn: 363087
      1bbad593
    • Richard Smith's avatar
      For DR712: store on a DeclRefExpr whether it constitutes an odr-use. · 715f7a1b
      Richard Smith authored
      Begin restructuring to support the forms of non-odr-use reference
      permitted by DR712.
      
      llvm-svn: 363086
      715f7a1b
    • Jinsong Ji's avatar
      [PowerPC] Enable MachinePipeliner for P9 with -ppc-enable-pipeliner · ef2d6d99
      Jinsong Ji authored
      Implement necessary target hooks to enable MachinePipeliner for P9 only.
      The pass is off by default, can be enabled with -ppc-enable-pipeliner for P9.
      
      Differential Revision: https://reviews.llvm.org/D62164
      
      llvm-svn: 363085
      ef2d6d99
    • Cameron McInally's avatar
      [NFC][CodeGen] Add unary fneg tests to X86/fma-fneg-combine.ll · 10c08555
      Cameron McInally authored
      llvm-svn: 363084
      10c08555
    • Jonas Devlieghere's avatar
      [Path] Set FD to -1 in moved-from TempFile · a6fe345a
      Jonas Devlieghere authored
      When moving a temp file, explicitly set the file descriptor to -1 so we
      can never accidentally close the moved-from TempFile.
      
      Differential revision: https://reviews.llvm.org/D63087
      
      llvm-svn: 363083
      a6fe345a
    • Cameron McInally's avatar
      [InstCombine] Handle -(X-Y) --> (Y-X) for unary fneg when NSZ · 08200d6d
      Cameron McInally authored
      Differential Revision: https://reviews.llvm.org/D62612
      
      llvm-svn: 363082
      08200d6d
    • James Henderson's avatar
      [docs][llvm-nm] Add darwin as --format option · 5058ae09
      James Henderson authored
      llvm-svn: 363081
      5058ae09
    • Cameron McInally's avatar
      796de113
    • Sander de Smalen's avatar
      Fix docs build issue introduced by r363035 · 9d51fa55
      Sander de Smalen authored
      Replacing '.. code-block:: llvm' by '::' is a quick fix to the
      build warning/error: Could not lex literal_block as "llvm".
      
      llvm-svn: 363079
      9d51fa55
    • Nico Weber's avatar
      lld-link: Reject more than one resource .obj file · af6bc65d
      Nico Weber authored
      Users are exepcted to pass all .res files to the linker, which then
      merges all the resource in all .res files into a tree structure and then
      converts the final tree structure to a .obj file with .rsrc$01 and
      .rsrc$02 sections and then links that.
      
      If the user instead passes several .obj files containing such resources,
      the correct thing to do would be to have custom code to merge the trees
      in the resource sections instead of doing normal section merging -- but
      link.exe rejects if multiple resource obj files are passed in with
      LNK4078, so let lld-link do that too instead of silently writing broken
      .rsrc sections in that case.
      
      The only real way to run into this is if users manually convert .res
      files to .obj files by running cvtres and then handing the resulting
      .obj files to lld-link instead, which in practice likely never happens.
      
      (lld-link is slightly stricter than link.exe now: If link.exe is passed
      one .obj file created by cvtres, and a .res file, for some reason it
      just emits a warning instead of an error and outputs strange looking
      data. lld-link now errors out on mixed input like this.)
      
      One way users could accidentally run into this is the following
      scenario: If a .res file is passed to lib.exe, then lib.exe calls
      cvtres.exe on the .res file before putting it in the output .lib.
      (llvm-lib currently doesn't do this.)
      link.exe's /wholearchive seems to only add obj files referenced from the
      static library index, but lld-link current really adds all files in the
      archive. So if lld-link /wholearchive is used with .lib files produced
      by lib.exe and .res files were among the files handed to lib.exe, we
      previously silently produced invalid output, but now we error out.
      
      link.exe's /wholearchive semantics on the other hand mean that it
      wouldn't load the resource object files from the .lib file at all.
      Since this scenario is probably still an unlikely corner case,
      the difference in behavior here seems fine -- and lld-link might have to
      change to use link.exe's /wholearchive semantics in the future anyways.
      
      Vaguely related to PR42180.
      
      Differential Revision: https://reviews.llvm.org/D63109
      
      llvm-svn: 363078
      af6bc65d
    • Simon Pilgrim's avatar
      [X86] Regenerate CmpISel test for future patch · f3708318
      Simon Pilgrim authored
      llvm-svn: 363077
      f3708318
    • Yaxun Liu's avatar
      Revert r344630 Disable code object version 3 for HIP toolchain. · 1362ffbc
      Yaxun Liu authored
      Remove the workaround so that by default code object v3 is enabled.
      
      llvm-svn: 363076
      1362ffbc
    • Louis Dionne's avatar
      [libcxx] Make std::tuple<> trivially constructible · 405570dc
      Louis Dionne authored
      Summary:
      This is not mandated by the Standard, but it's nonetheless a nice
      property to have, especially since it's so easy to implement. It
      also shrinks our bug list!
      
      PR41714
      
      Reviewers: mclow.lists, EricWF
      
      Subscribers: christof, jkorous, dexonsmith, libcxx-commits
      
      Tags: #libc
      
      Differential Revision: https://reviews.llvm.org/D62618
      
      llvm-svn: 363075
      405570dc
    • Erich Keane's avatar
      Fix for r42230, MSVC test failure in DependencyDirectivesSourceMinimizerTest.cpp · d65ef673
      Erich Keane authored
      r362459 introduced DependencyDirectivesSourceMinimizerTest.cpp, which
      hits an MSVC bug:
      developercommunity.visualstudio.com/content/problem/67300/stringifying-raw-string-literal.html
      
      This only happens when the parameter to a macro is stringified in the
      macro.  This patch removes the string from the assert so that the
      warning no longer happens.
      
      llvm-svn: 363074
      d65ef673
    • James Henderson's avatar
      224410b7
    • Louis Dionne's avatar
      [libcxx] Slightly improved policy for handling experimental features · 776acf22
      Louis Dionne authored
      Summary:
      Following the discussion on the libcxx-dev mailing list
      (http://lists.llvm.org/pipermail/libcxx-dev/2019-May/000358.html),
      this implements the new policy for handling experimental features and
      their deprecation. We basically add a deprecation warning for
      std::experimental::filesystem, and we remove a bunch of <experimental/*>
      headers that were now empty.
      
      Reviewers: mclow.lists, EricWF
      
      Subscribers: mgorny, christof, jkorous, dexonsmith, arphaman, libcxx-commits, jfb
      
      Tags: #libc
      
      Differential Revision: https://reviews.llvm.org/D62428
      
      llvm-svn: 363072
      776acf22
    • Max Moroz's avatar
      Add FuzzedDataProvider helper class / single header library. · 10ed6818
      Max Moroz authored
      Summary:
      This class is useful for writing fuzz target that have multiple inputs.
      
      Current CL imports the existing `FuzzedDataProvider` from Chromium
      without any modifications. Feel free to review it thoroughly, if you're
      interested, but I'd prefer changing the class in a follow up CL.
      
      The CL also introduces an exhaustive test for the library, as the behavior
      of `FuzzedDataProvider` must not change over time.
      
      In follow up CLs I'm planning on changing some implementation details
      (I can share a doc with some comments to be addressed). After that, we
      will document how `FuzzedDataProvider` should be used.
      
      I have tested this on Linux, Windows and Mac platforms.
      
      Reviewers: morehouse, metzman, kcc
      
      Reviewed By: morehouse
      
      Subscribers: metzman, thakis, rnk, mgorny, ormris, delcypher, #sanitizers, llvm-commits
      
      Tags: #llvm, #sanitizers
      
      Differential Revision: https://reviews.llvm.org/D62733
      
      llvm-svn: 363071
      10ed6818
    • Hubert Tong's avatar
      [NFC][PowerPC] Header-dependent test requires "native" · 11db920f
      Hubert Tong authored
      Two recently added tests mention complications for cross-compile, but
      they do not actually enforce native compilation. This patch makes them
      require native compilation to avoid the complications they mention.
      
      llvm-svn: 363070
      11db920f
    • Hubert Tong's avatar
      Reapply r362994 & co "[analyzer][tests] Add normalize_plist to replace diff_plist" · 61c848d2
      Hubert Tong authored
      Following r363007, which reverted r362998, r362996, and r362994,
      reapply with adjustments for the CRLF differences encountered with
      Windows. Namely, the `-b` option of `diff` is employed, and the `grep`
      patterns have `$` replaced with `[[:space:]]*$`.
      
      llvm-svn: 363069
      61c848d2
    • Nikolai Kosjar's avatar
      [clang-tidy] Fix invalid read on destruction · be8d03a5
      Nikolai Kosjar authored
      ...in case the clang tidy plugin is linked into the clang binary.
      
      Valgrind's memcheck reports:
      
      8949== Invalid read ==8866== Invalid read of size 4
      8866== at 0x164D248B: fetch_sub (atomic_base.h:524)
      8866== by 0x164D248B: llvm::ThreadSafeRefCountedBase<clang::ast_matchers::internal::DynMatcherInterface>::Release() const (IntrusiveRefCntPtr.h:98)
      8866== by 0x164CE16C: llvm::IntrusiveRefCntPtrInfo<clang::ast_matchers::internal::DynMatcherInterface>::release(clang::ast_matchers::internal::DynMatcherInterface*) (IntrusiveRefCntPtr.h:127)
      8866== by 0x164C8D5C: llvm::IntrusiveRefCntPtr<clang::ast_matchers::internal::DynMatcherInterface>::release() (IntrusiveRefCntPtr.h:190)
      8866== by 0x164C3B87: llvm::IntrusiveRefCntPtr<clang::ast_matchers::internal::DynMatcherInterface>::~IntrusiveRefCntPtr() (IntrusiveRefCntPtr.h:157)
      8866== by 0x164BB4F1: clang::ast_matchers::internal::DynTypedMatcher::~DynTypedMatcher() (ASTMatchersInternal.h:341)
      8866== by 0x164BB529: clang::ast_matchers::internal::Matcher<clang::QualType>::~Matcher() (ASTMatchersInternal.h:496)
      8866== by 0xD7AE614: __cxa_finalize (cxa_finalize.c:83)
      8866== by 0x164B3082: ??? (in /d2/llvm/8/qtc/builds/DebugShared/lib/libclangTidyModernizeModule.so.8)
      8866== by 0x4010B72: _dl_fini (dl-fini.c:138)
      8866== by 0xD7AE040: __run_exit_handlers (exit.c:108)
      8866== by 0xD7AE139: exit (exit.c:139)
      8866== by 0xD78CB9D: (below main) (libc-start.c:344)
      8866== Address 0x19dd9bc8 is 8 bytes inside a block of size 16 free'd
      8866== at 0x4C3123B: operator delete(void*) (in /usr/lib/valgrind/vgpreload_memcheck-amd64-linux.so)
      8866== by 0x1469BB99: clang::ast_matchers::internal::(anonymous namespace)::TrueMatcherImpl::~TrueMatcherImpl() (ASTMatchersInternal.cpp:126)
      8866== by 0x1469BBC5: llvm::object_deleter<clang::ast_matchers::internal::(anonymous namespace)::TrueMatcherImpl>::call(void*) (ManagedStatic.h:30)
      8866== by 0x9ABFF26: llvm::ManagedStaticBase::destroy() const (ManagedStatic.cpp:72)
      8866== by 0x9ABFF94: llvm::llvm_shutdown() (ManagedStatic.cpp:84)
      8866== by 0x9A65232: llvm::InitLLVM::~InitLLVM() (InitLLVM.cpp:52)
      8866== by 0x14B0C8: main (driver.cpp:323)
      8866== Block was alloc'd at
      8866== at 0x4C3017F: operator new(unsigned long) (in /usr/lib/valgrind/vgpreload_memcheck-amd64-linux.so)
      8866== by 0x1469BB36: llvm::object_creator<clang::ast_matchers::internal::(anonymous namespace)::TrueMatcherImpl>::call() (ManagedStatic.h:24)
      8866== by 0x9ABFD99: llvm::ManagedStaticBase::RegisterManagedStatic(void* (*)(), void (*)(void*)) const (ManagedStatic.cpp:42)
      8866== by 0x1469B5DF: llvm::ManagedStatic<clang::ast_matchers::internal::(anonymous namespace)::TrueMatcherImpl, llvm::object_creator<clang::ast_matchers::internal::(anonymous namespace)::TrueMatcherImpl>, llvm::object_deleter<clang::ast_matchers::internal::(anonymous namespace)::TrueMatcherImpl> >::operator*() (ManagedStatic.h:67)
      8866== by 0x14698F9D: clang::ast_matchers::internal::DynTypedMatcher::trueMatcher(clang::ast_type_traits::ASTNodeKind) (ASTMatchersInternal.cpp:195)
      8866== by 0x164C9D3B: _ZNK5clang12ast_matchers8internal11TrueMatchercvNS1_7MatcherIT_EEINS_8QualTypeEEEv (ASTMatchersInternal.h:1247)
      8866== by 0x16501458: __static_initialization_and_destruction_0(int, int) (LoopConvertCheck.cpp:48)
      8866== by 0x16501976: _GLOBAL__sub_I_LoopConvertCheck.cpp (LoopConvertCheck.cpp:920)
      8866== by 0x4010732: call_init (dl-init.c:72)
      8866== by 0x4010732: _dl_init (dl-init.c:119)
      8866== by 0x40010C9: ??? (in /lib/x86_64-linux-gnu/ld-2.27.so)
      
      Differential Revision: https://reviews.llvm.org/D63129
      
      llvm-svn: 363068
      be8d03a5
    • Nikolai Kosjar's avatar
      [libclang] Allow skipping warnings from all included files · 8edd8da4
      Nikolai Kosjar authored
      Depending on the included files and the used warning flags, e.g. -
      Weverything, a huge number of warnings can be reported for included
      files. As processing that many diagnostics comes with a performance
      impact and not all clients are interested in those diagnostics, add a
      flag to skip them.
      
      Differential Revision: https://reviews.llvm.org/D48116
      
      llvm-svn: 363067
      8edd8da4
    • James Henderson's avatar
      [llvm-dwarfdump] Simplify --ignore-case help text and documentation · 94879632
      James Henderson authored
      There was a typo in the --ignore-case help text that was copied into the
      llvm-dwarfdump command-guide. Additionally, this patch simplifies the
      wording, since it was unnecessarily verbose: the switch applies for
      searching in general and doesn't need explicitly stating different
      search modes (which might go out-of-date as options are added or
      removed).
      
      Reviwed by: JDevlieghere
      
      Differential Revision: https://reviews.llvm.org/D63133
      
      llvm-svn: 363066
      94879632
    • James Henderson's avatar
      [docs][llvm-nm] Fix documentation regarding llvm-nm reading stdin · be7f5c71
      James Henderson authored
      llvm-nm reads a.out NOT stdin when no input file is specified. This
      patch fixes the doc accordingly, and rephrases the surrounding sentence
      slightly.
      
      Reviewed by: grimar
      
      Differential Revision: https://reviews.llvm.org/D63135
      
      llvm-svn: 363065
      be7f5c71
    • Fangrui Song's avatar
      [ELF][RISCV] Add R_RISCV_PC_INDIRECT to isRelExpr() · 47d77365
      Fangrui Song authored
      So that R_RISCV_PCREL_LO12_[IS] are considered as link-time constants in
      -pie mode, otherwise there are bogus errors:
      
          ld.lld: error: can't create dynamic relocation R_RISCV_PCREL_LO12_I against symbol: .L0  in readonly segment; recompile object files with -fPIC or pass '-Wl,-z,notext' to allow text relocations in the output
      
      Reviewed By: ruiu
      
      Differential Revision: https://reviews.llvm.org/D63123
      
      llvm-svn: 363064
      47d77365
    • Ilya Biryukov's avatar
      [ARM] Fix a typo in the test from r363039 · b37ccc5f
      Ilya Biryukov authored
      llvm-svn: 363063
      b37ccc5f
    • Gabor Marton's avatar
      [ASTImporter] Fix unhandled cases in ASTImporterLookupTable · dd2b76e1
      Gabor Marton authored
      Summary:
      In most cases the FriendDecl contains the declaration of the befriended
      class as a child node, so it is discovered during the recursive
      visitation. However, there are cases when the befriended class is not a
      child, thus it must be fetched explicitly from the FriendDecl, and only
      then can we add it to the lookup table.
      (Note, this does affect only CTU and does not affect LLDB, because we
      cannot and do not use the ASTImporterLookupTable in LLDB.)
      
      Reviewers: a_sidorin, a.sidorin, shafik
      
      Subscribers: rnkovacs, dkrupp, Szelethus, gamesh411, cfe-commits
      
      Tags: #clang
      
      Differential Revision: https://reviews.llvm.org/D62064
      
      llvm-svn: 363062
      dd2b76e1
    • Rui Ueyama's avatar
      Revert r362867: [ELF][PPC] Simplify {read,write}FromHalf16 · 963d73ff
      Rui Ueyama authored
      This reverts commit r362867 since it seems to have broken
      ppc64le-lld-multistage-test bot.
      
      llvm-svn: 363060
      963d73ff
Loading