Skip to content
  1. Aug 14, 2018
    • Stephen Kelly's avatar
      Remove vestiges of configure buildsystem · 1f656008
      Stephen Kelly authored
      Subscribers: mgorny, llvm-commits
      
      Differential Revision: https://reviews.llvm.org/D50528
      
      llvm-svn: 339729
      1f656008
    • Reid Kleckner's avatar
      Fix lit fatal errors about requiring a USE_Z3_SOLVER param · b8c29d53
      Reid Kleckner authored
      llvm-svn: 339728
      b8c29d53
    • Artem Dergachev's avatar
      [CFG] [analyzer] Find argument constructors in CXXTemporaryObjectExprs. · c531d549
      Artem Dergachev authored
      CXXTemporaryObjectExpr is a sub-class of CXXConstructExpr. If it has arguments
      that are structures passed by value, their respective constructors need to be
      handled by providing a ConstructionContext, like for regular function calls and
      for regular constructors.
      
      Differential Revision: https://reviews.llvm.org/D50487
      
      llvm-svn: 339727
      c531d549
    • Artem Dergachev's avatar
      [analyzer] Add a test forgotten in r339088. · bf33a2cd
      Artem Dergachev authored
      Differential Revision: https://reviews.llvm.org/D50363
      
      llvm-svn: 339726
      bf33a2cd
    • Alina Sbirlea's avatar
      Add proper headers in CFGUpdate.h and add CFGDiff.h in the list of delayed... · 24a74835
      Alina Sbirlea authored
      Add proper headers in CFGUpdate.h and add CFGDiff.h in the list of delayed headers for LLVM_intrinsic_gen.
      
      Summary:
      Fix module build after r339694.
      Add headers needed in CFGUpdate.h.
      Add CFGDiff.h in the list of delayed headers for LLVM_intrinsic_gen.
      Up for post-commit review.
      
      Subscribers: sanjoy, jlebar, llvm-commits
      
      Differential Revision: https://reviews.llvm.org/D50734
      
      llvm-svn: 339724
      24a74835
    • Vlad Tsyrklevich's avatar
      Reland "SafeStack: Delay thread stack clean-up"" · 05ee22e3
      Vlad Tsyrklevich authored
      This relands commit r339405 (reverted in commit r339408.) The original
      revert was due to tests failing on a darwin buildbot; however, after
      looking at the affected code more I realized that the Darwin safestack
      support has always been broken and disabled it in r339719. This relands
      the original commit.
      
      llvm-svn: 339723
      05ee22e3
    • Anna Thomas's avatar
      NFC: Clarify comment in loop vectorization legality · 6a1dd77f
      Anna Thomas authored
      Clarifying the comment about PSCEV and external IV users by referencing
      the bug in question.
      
      llvm-svn: 339722
      6a1dd77f
    • Craig Topper's avatar
      [InlineAsm] Update the min-legal-vector-width function attribute based on... · 2a87314e
      Craig Topper authored
      [InlineAsm] Update the min-legal-vector-width function attribute based on inputs and outputs to inline assembly
      
      Summary:
      Another piece of my ongoing to work for prefer-vector-width.
      
      min-legal-vector-width will eventually be used by the X86 backend to know whether it needs to make 512 bits type legal when prefer-vector-width=256. If the user used inline assembly that passed in/out a 512-bit register, we need to make sure 512 bits are considered legal. Otherwise we'll get an assert failure when we try to wire up the inline assembly to the rest of the code.
      
      This patch just checks the LLVM IR types to see if they are vectors and then updates the attribute based on their total width. I'm not sure if this is the best way to do this or if there's any subtlety I might have missed. So if anyone has other opinions on how to do this I'm open to suggestions.
      
      Reviewers: chandlerc, rsmith, rnk
      
      Reviewed By: rnk
      
      Subscribers: eraman, cfe-commits
      
      Differential Revision: https://reviews.llvm.org/D50678
      
      llvm-svn: 339721
      2a87314e
    • Vlad Tsyrklevich's avatar
      SafeStack: Disable Darwin support · 97e6819e
      Vlad Tsyrklevich authored
      Summary:
      Darwin support does not appear to be used as evidenced by the fact that
      the runtime has never supported non-trivial programs.
      
      Reviewers: pcc, kubamracek
      
      Reviewed By: pcc
      
      Subscribers: cfe-commits, kcc
      
      Differential Revision: https://reviews.llvm.org/D50724
      
      llvm-svn: 339720
      97e6819e
    • Vlad Tsyrklevich's avatar
      SafeStack: Disable Darwin support · a6446223
      Vlad Tsyrklevich authored
      Summary:
      Darwin support does not appear to be used as evidenced by the fact that
      the pthread interceptors have never worked and there is no support for
      other common threading mechanisms like GCD.
      
      Reviewers: pcc, eugenis, kubamracek
      
      Reviewed By: pcc, kubamracek
      
      Subscribers: kubamracek, mgorny, delcypher, llvm-commits, #sanitizers, kcc
      
      Differential Revision: https://reviews.llvm.org/D50718
      
      llvm-svn: 339719
      a6446223
    • Stefan Granitz's avatar
      Remove asseration from ConstString::GetConstCStringAndSetMangledCounterPart()... · 4aaa72f9
      Stefan Granitz authored
      Remove asseration from ConstString::GetConstCStringAndSetMangledCounterPart() to fix more tests first
      
      llvm-svn: 339716
      4aaa72f9
    • Raphael Isemann's avatar
      Stability improvements for CompletionTest · ffa7010b
      Raphael Isemann authored
      Summary:
      CompletionTest.DirCompletionAbsolute had a random failure on a CI node
      (in the failure, the completion count was 0, while we expected it to be 1),
      but there seems no good reason for it to fail. The sanitizers don't complain
      about the test when it's run, so I think we don't have some uninitialized
      memory that we access here.
      
      My best bet is that the unique directory selection randomly failed on the CI
      node because maybe the FS there doesn't actually guarantee the atomic fopen
      assumptions we make in the LLVM code (or some other funny race condition).
      In this case a different test run could get the same directory and clean its contents
      which would lead to 0 results.
      
      The other possible explanation is that someone changed the CI configuration
      on the node and changed the working dir to something very long, which would
      make our PATH_MAX test fail (which also leads to 0 results), but I think that case
      is unlikely.
      
      This patch is just a stab in the dark that (hopefully) fixes this random failure by
      giving each test a (more) unique working directory by appending the unique
      test name to the temp-dir prefix. Also adds one more ASSERT_NO_ERROR to
      one of our chdir calls just in case that is the reason for failing.
      
      The good thing is that this refactor gets rid of most of the static variables
      and files that we previously had as shared state between the different tests.
      
      Potentially fixes rdar://problem/43150260
      
      Reviewers: aprantl
      
      Reviewed By: aprantl
      
      Subscribers: jfb, lldb-commits
      
      Differential Revision: https://reviews.llvm.org/D50722
      
      llvm-svn: 339715
      ffa7010b
    • Adrian Prantl's avatar
      [DebugInfoMetadata] Added DIFlags interface in DIBasicType. · 55f42629
      Adrian Prantl authored
      Flags in DIBasicType will be used to pass attributes used in
      DW_TAG_base_type, such as DW_AT_endianity.
      
      Patch by Chirag Patel!
      
      Differential Revision: https://reviews.llvm.org/D49610
      
      llvm-svn: 339714
      55f42629
    • Sanjay Patel's avatar
      [InstCombine] fix typos in tests; NFC · b1546da0
      Sanjay Patel authored
      See D50036.
      
      llvm-svn: 339713
      b1546da0
    • Heejin Ahn's avatar
      [WebAssembly] SIMD encoding tests · c15a8784
      Heejin Ahn authored
      Modifies existing SIMD tests to also check that SIMD instructions are
      lowered to the expected bytes. This CL depends on D50597.
      
      Reviewers: aheejin
      
      Subscribers: sunfish, jgravelle-google, sbc100, llvm-commits
      
      Differential Revision: https://reviews.llvm.org/D50660
      
      Patch by Thomas Lively (tlively)
      
      llvm-svn: 339712
      c15a8784
    • Sanjay Patel's avatar
      [InstCombine] add tests for pow->sqrt; NFC · 73b7e9f6
      Sanjay Patel authored
      D50036 should fix the missed optimizations.
      
      llvm-svn: 339711
      73b7e9f6
    • Heejin Ahn's avatar
      [WebAssembly] Fix encoding of non-SIMD vector-typed instructions · c9c711a0
      Heejin Ahn authored
      Previously SIMD_I was the same as a normal instruction except for the
      addition of a HasSIM128 predicate. However, rL339186 changed the
      encoding of SIMD_I instructions to automatically contain the SIMD
      prefix byte. This broke the encoding of non-SIMD vector-typed
      instructions, which had instantiated SIMD_I. This CL corrects this
      error.
      
      Reviewers: aheejin
      
      Subscribers: sunfish, jgravelle-google, sbc100, llvm-commits
      
      Differential Revision: https://reviews.llvm.org/D50682
      
      Patch by Thomas Lively (tlively)
      
      llvm-svn: 339710
      c9c711a0
    • George Karpenkov's avatar
    • Zachary Turner's avatar
      [MS Demangler] Fix some minor formatting bugs. · 2bbb23ba
      Zachary Turner authored
      1) We print __restrict twice on member pointers.  This is fixed
         and relevant tests are re-enabled.
      
      2) Several tests were disabled because of printing slightly
         different output than undname.  These were confirmed to be
         bugs in undname, so we just re-enable the tests.
      
      3) The test for printing reference temporaries is re-enabled.  This
         is a clang mangling extension, so we have some flexibility with
         how we demangle it.  The output currently looks fine, so we just
         re-enable the test with no fixes.
      
      llvm-svn: 339708
      2bbb23ba
    • Heejin Ahn's avatar
      [WebAssembly] SIMD extract_lane · a0fd9c3e
      Heejin Ahn authored
      Implement instruction selection for all versions of the extract_lane
      instruction. Use explicit sext/zext to differentiate between
      extract_lane_s and extract_lane_u for applicable types, otherwise
      default to extract_lane_u.
      
      Reviewers: aheejin
      
      Subscribers: sunfish, jgravelle-google, sbc100, llvm-commits
      
      Differential Revision: https://reviews.llvm.org/D50597
      
      Patch by Thomas Lively (tlively)
      
      llvm-svn: 339707
      a0fd9c3e
    • Andrea Di Biagio's avatar
      [Tablegen][MCInstPredicate] Removed redundant template argument from class... · 9eaf5aa0
      Andrea Di Biagio authored
      [Tablegen][MCInstPredicate] Removed redundant template argument from class TIIPredicate, and implemented verification rules for TIIPredicates.
      
      This patch removes redundant template argument `TargetName` from TIIPredicate.
      Tablegen can always infer the target name from the context. So we don't need to
      force users of TIIPredicate to always specify it.
      
      This allows us to better modularize the tablegen class hierarchy for the
      so-called "function predicates". class FunctionPredicateBase has been added; it
      is currently used as a building block for TIIPredicates. However, I plan to
      reuse that class to model other function predicate classes too (i.e. not just
      TIIPredicates). For example, this can be a first step towards implementing
      proper support for dependency breaking instructions in tablegen.
      
      This patch also adds a verification step on TIIPredicates in tablegen.
      We cannot have multiple TIIPredicates with the same name. Otherwise, this will
      cause build errors later on, when tablegen'd .inc files are included by cpp
      files and then compiled.
      
      Differential Revision: https://reviews.llvm.org/D50708
      
      llvm-svn: 339706
      9eaf5aa0
    • Kostya Kortchinsky's avatar
      [scudo] Fix race condition in deallocation path when Quarantine is bypassed · 3afc797e
      Kostya Kortchinsky authored
      Summary:
      There is a race window in the deallocation path when the Quarantine is bypassed.
      Initially we would just erase the header of a chunk if we were not to use the
      Quarantine, as opposed to using a compare-exchange primitive, to make things
      faster.
      
      It turned out to be a poor decision, as 2 threads (or more) could simultaneously
      deallocate the same pointer, and if the checks were to done before the header
      got erased, this would result in the pointer being added twice (or more) to
      distinct thread caches, and eventually be reused.
      
      Winning the race is not trivial but can happen with enough control over the
      allocation primitives. The repro added attempts to trigger the bug, with a
      moderate success rate, but it should be enough to notice if the bug ever make
      its way back into the code.
      
      Since I am changing things in this file, there are 2 smaller changes tagging
      along, marking a variable `const`, and improving the Quarantine bypass test at
      runtime.
      
      Reviewers: alekseyshl, eugenis, kcc, vitalybuka
      
      Reviewed By: eugenis, vitalybuka
      
      Subscribers: delcypher, #sanitizers, llvm-commits
      
      Differential Revision: https://reviews.llvm.org/D50655
      
      llvm-svn: 339705
      3afc797e
    • Alexey Bataev's avatar
      [OPENMP] Fix processing of declare target construct. · 97b72212
      Alexey Bataev authored
      The attribute marked as inheritable since OpenMP 5.0 supports it +
      additional fixes to support new functionality.
      
      llvm-svn: 339704
      97b72212
    • Anna Thomas's avatar
      [LV] Teach about non header phis that have uses outside the loop · 60a1e4dd
      Anna Thomas authored
      Summary:
      This patch teaches the loop vectorizer to vectorize loops with non
      header phis that have have outside uses.  This is because the iteration
      dependence distance for these phis can be widened upto VF (similar to
      how we do for induction/reduction) if they do not have a cyclic
      dependence with header phis. When identifying reduction/induction/first
      order recurrence header phis, we already identify if there are any cyclic
      dependencies that prevents vectorization.
      
      The vectorizer is taught to extract the last element from the vectorized
      phi and update the scalar loop exit block phi to contain this extracted
      element from the vector loop.
      
      This patch can be extended to vectorize loops where instructions other
      than phis have outside uses.
      
      Reviewers: Ayal, mkuper, mssimpso, efriedma
      
      Subscribers: llvm-commits
      
      Differential Revision: https://reviews.llvm.org/D50579
      
      llvm-svn: 339703
      60a1e4dd
    • Louis Dionne's avatar
      [libc++] Fix incorrect definition of TEST_HAS_C11_FEATURES · 6513f375
      Louis Dionne authored
      Summary:
      The macro was not defined in C++11 mode when it should have been, at least
      according to how _LIBCPP_HAS_C11_FEATURES is defined.
      
      Reviewers: mclow.lists, EricWF, jfb, dexonsmith
      
      Subscribers: christof, dexonsmith, cfe-commits
      
      Differential Revision: https://reviews.llvm.org/D50719
      
      llvm-svn: 339702
      6513f375
    • Petr Hosek's avatar
      [CMake] Don't parse target triple except for arch · 39f08607
      Petr Hosek authored
      compiler-rt CMake build currently tries to parse the triple and then
      put it back together, but doing so inherently tricky, and doing so
      from CMake is just crazy and currently doesn't handle triples that
      have more than three components. Fortunatelly, the CMake really only
      needs the architecture part, which is typically the first component,
      to construct variants for other architectures. This means we can keep
      the rest of the triple as is and avoid the parsing altogether.
      
      Differential Revision: https://reviews.llvm.org/D50548
      
      llvm-svn: 339701
      39f08607
    • Bruno Cardoso Lopes's avatar
      Revert "[DebugInfo] Generate DWARF debug information for labels. (Fix leak problems)" · f446282a
      Bruno Cardoso Lopes authored
      This reverts commit cb8c5e417d55141f3f079a8a876e786f44308336 / r339676.
      
      This causing a test to fail in http://green.lab.llvm.org/green/job/clang-stage1-configure-RA/48406/
      
          LLVM :: DebugInfo/Generic/debug-label.ll
      
      llvm-svn: 339700
      f446282a
    • Alina Sbirlea's avatar
      [GraphDiff] Make InverseGraph a property of a GraphDiff. · abf94118
      Alina Sbirlea authored
      Summary:
      Treating a graph in reverse is a property of the GraphDiff and should instead be a template argument, just like IsPostDom is one for DomTrees.
      If it's just an argument to all methods, we could have mismatches between the constructor of the GraphDiff which may reverse the updates when filtering them, and the calls retrieving the filtered delete/insert updates.
      Also, since this will be used in IDF, where we're using a DomTree, this creates a cleaner interface for the GraphTraits to use the existing template argument of DomTreeBase.
      
      Separate patch from the one adding GraphDiff, so get a clear diff of what changed.
      
      Reviewers: timshen, kuhar
      
      Subscribers: sanjoy, llvm-commits, jlebar
      
      Differential Revision: https://reviews.llvm.org/D50687
      
      llvm-svn: 339699
      abf94118
    • Martin Storsjö's avatar
      [CMake] Fix the LIBCXX_STATICALLY_LINK_ABI_IN_SHARED_LIBRARY option · 3d2e5432
      Martin Storsjö authored
      This option should be available if LIBCXX_ENABLE_SHARED is enabled,
      not LIBCXX_ENABLE_STATIC.
      
      This fixes a typo from SVN r337814.
      
      Differential Revision: https://reviews.llvm.org/D50691
      
      llvm-svn: 339697
      3d2e5432
    • Simon Pilgrim's avatar
      [X86][SSE] Avoid duplicate shuffle input sources in combineX86ShufflesRecursively · 2ce3d6e1
      Simon Pilgrim authored
      rL339686 added the case where a faux shuffle might have repeated shuffle inputs coming from either side of the OR().
      
      This patch improves the insertion of the inputs into the source ops lists to account for this, as well as making it trivial to add support for shuffles with more than 2 inputs in the future.
      
      llvm-svn: 339696
      2ce3d6e1
    • Raphael Isemann's avatar
      Remove manual byte counting from Highlighter code. · 2d437f6b
      Raphael Isemann authored
      Summary:
      This removes the manual byte counting mechanism from the syntax highlighting
      code. This is no longer necessary as the Stream class now has built-in support for
      automatically counting the bytes that were written to it so far.
      
      The advantage of automatic byte counting via Stream is that it is less error-prone
      than the manual version and we need to write less boilerplate code.
      
      Reviewers: labath
      
      Reviewed By: labath
      
      Subscribers: labath, lldb-commits
      
      Differential Revision: https://reviews.llvm.org/D50676
      
      llvm-svn: 339695
      2d437f6b
    • Alina Sbirlea's avatar
      [DomTree] Cleanup Update and LegalizeUpdate API moved to Support header. · 148c4454
      Alina Sbirlea authored
      Summary:
      Clean-up following D50479.
      Make Update and LegalizeUpdate refer to the utilities in Support/CFGUpdate.
      
      Reviewers: kuhar
      
      Subscribers: sanjoy, jlebar, mgrang, llvm-commits
      
      Differential Revision: https://reviews.llvm.org/D50669
      
      llvm-svn: 339694
      148c4454
    • Kevin P. Neal's avatar
      · 2c0bc8b7
      Kevin P. Neal authored
      We have in place support for parsing #pragma FENV_ACCESS, but that 
      information is then discarded with a warning to the user that we don't 
      support it.
      
      This patch gets us one step closer by getting the info down into the 
      AST in most cases.
      
      Reviewed by:	rsmith
      Differential Revision:	https://reviews.llvm.org/D49865
      
      llvm-svn: 339693
      2c0bc8b7
    • David Bolvansky's avatar
      [NFC] Tests for select with binop fold - FP opcodes · ba74d1c4
      David Bolvansky authored
      llvm-svn: 339692
      ba74d1c4
    • Kevin P. Neal's avatar
      Revert test commit · da4c67f0
      Kevin P. Neal authored
      llvm-svn: 339691
      da4c67f0
    • Kevin P. Neal's avatar
      Test commit · 51f6e7ef
      Kevin P. Neal authored
      llvm-svn: 339690
      51f6e7ef
    • Alina Sbirlea's avatar
      Expose CFG Update struct. Define GraphTraits to get children given a snapshot CFG. · 4c44a447
      Alina Sbirlea authored
      Summary:
      Certain passes or analysis need to view a CFG snapshot rather than the actual CFG. This patch provides GraphTraits to offer such a view.
      
      The patch defines GraphTraits for BasicBlock* and Inverse<BasicBlock*> to provide CFG successors and predecessors based on a list of CFG updates.
      
      An Update is defined as a triple {InsertOrDeleteKind, BlockStartOfEdge, BlockEndOfEdge}.
      A GraphDiff is defined as a list of Updates that has been preprocessed to treat the CFG as a graph rather than a multi-graph. As such, there can only exist a single Update given two nodes. All duplicates will be filtered and Insert/Delete edges that cancel out will be ignored.
      The methods GraphDiff exposes are:
      - Determine if an existing child needs to be ignored, i.e. an Update exists in the correct direction to assume the removal of that edge.
      - Return a list of new children to be considered, i.e. an Update exists in the correct direction for each child in the list to assume the insertion of that edge.
      
      Reviewers: timshen, kuhar, chandlerc
      
      Subscribers: sanjoy, jlebar, llvm-commits
      
      Differential Revision: https://reviews.llvm.org/D50479
      
      llvm-svn: 339689
      4c44a447
    • Nirav Dave's avatar
      [DAG] Avoid redundant chain transversal in store merge cycle check. NFCI. · fbfe2ad9
      Nirav Dave authored
      Patch by Henric Karlsson.
      
      llvm-svn: 339688
      fbfe2ad9
    • Kirill Bobyrev's avatar
      NFC: Enforce good formatting across multiple clang-tools-extra files · 8e35f1e7
      Kirill Bobyrev authored
      This patch improves readability of multiple files in clang-tools-extra
      and enforces LLVM Coding Guidelines.
      
      Reviewed by: ioeric
      
      Differential Revision: https://reviews.llvm.org/D50707
      
      llvm-svn: 339687
      8e35f1e7
    • Simon Pilgrim's avatar
      [X86][SSE] Add shuffle combine support for OR(PSHUFB,PSHUFB) style patterns. · ed551382
      Simon Pilgrim authored
      If each element is zero from one (or both) inputs then we can combine these into a single shuffle mask.
      
      llvm-svn: 339686
      ed551382
Loading