Skip to content
  1. Sep 19, 2018
    • Martin Storsjö's avatar
      [benchmark] Cherrypick fix for MinGW/ARM from upstream · 023dfa57
      Martin Storsjö authored
      This fixes building for Windows on ARM, with MinGW headers.
      (Building for Windows on ARM with Windows SDK still is unsupported
      by the benchmark library.)
      
      Differential Revision: https://reviews.llvm.org/D52262
      
      llvm-svn: 342549
      023dfa57
    • Roman Lebedev's avatar
      [InstCombine] foldICmpWithLowBitMaskedVal(): handle uncanonical ((-1 << y) >> y) mask · f50023d3
      Roman Lebedev authored
      Summary:
      The last low-bit-mask-pattern-producing-pattern i can think of.
      
      https://rise4fun.com/Alive/UGzE <- non-canonical
      But we can not canonicalize it because of extra uses.
      
      https://bugs.llvm.org/show_bug.cgi?id=38123
      
      Reviewers: spatel, craig.topper, RKSimon
      
      Reviewed By: spatel
      
      Subscribers: llvm-commits
      
      Differential Revision: https://reviews.llvm.org/D52148
      
      llvm-svn: 342548
      f50023d3
    • Roman Lebedev's avatar
      [InstCombine] foldICmpWithLowBitMaskedVal(): handle uncanonical ((1 << y)+(-1)) mask · ca2bdb03
      Roman Lebedev authored
      Summary:
      Same as to D52146.
      `((1 << y)+(-1))` is simply non-canoniacal version of `~(-1 << y)`: https://rise4fun.com/Alive/0vl
      We can not canonicalize it due to the extra uses. But we can handle it here.
      
      Reviewers: spatel, craig.topper, RKSimon
      
      Reviewed By: spatel
      
      Subscribers: llvm-commits
      
      Differential Revision: https://reviews.llvm.org/D52147
      
      llvm-svn: 342547
      ca2bdb03
    • Roman Lebedev's avatar
      [InstCombine] foldICmpWithLowBitMaskedVal(): handle ~(-1 << y) mask · 183a465d
      Roman Lebedev authored
      Summary:
      Two folds are happening here:
      1. https://rise4fun.com/Alive/oaFX
      2. And then `foldICmpWithHighBitMask()` (D52001): https://rise4fun.com/Alive/wsP4
      
      This change doesn't just add the handling for eq/ne predicates,
      it actually builds upon the previous `foldICmpWithLowBitMaskedVal()` work,
      so **all** the 16 fold variants* are immediately supported.
      
      I'm indeed only testing these two predicates.
      I do not feel like re-proving all 16 folds*, because they were already proven
      for the general case of constant with all-ones in low bits. So as long as
      the mask produces all-ones in low bits, i'm pretty sure the fold is valid.
      
      But required, i can re-prove, let me know.
      
      * eq/ne are commutative - 4 folds; ult/ule/ugt/uge - are not commutative (the commuted variant is InstSimplified), 4 folds; slt/sle/sgt/sge are not commutative - 4 folds. 12 folds in total.
      
      https://bugs.llvm.org/show_bug.cgi?id=38123
      https://bugs.llvm.org/show_bug.cgi?id=38708
      
      Reviewers: spatel, craig.topper, RKSimon
      
      Reviewed By: spatel
      
      Subscribers: llvm-commits
      
      Differential Revision: https://reviews.llvm.org/D52146
      
      llvm-svn: 342546
      183a465d
    • Oliver Stannard's avatar
      [ARM] Fix unwind information for floating point registers · 0b835be7
      Oliver Stannard authored
      Fixes the unwind information generated for floating-point registers.
      Previously, all padding registers were assumed to be four bytes wide. Now, the
      width of the register is used to specify the amount of padding.
      
      Patch by Jackson Woodruff!
      
      Differential revision: https://reviews.llvm.org/D51494
      
      llvm-svn: 342545
      0b835be7
    • Fedor Sergeev's avatar
      [New PM] Introducing PassInstrumentation framework · 875c938f
      Fedor Sergeev authored
      Summary:
      Pass Execution Instrumentation interface enables customizable instrumentation
      of pass execution, as per "RFC: Pass Execution Instrumentation interface"
      posted 06/07/2018 on llvm-dev@
      
      The intent is to provide a common machinery to implement all
      the pass-execution-debugging features like print-before/after,
      opt-bisect, time-passes etc.
      
      Here we get a basic implementation consisting of:
      * PassInstrumentationCallbacks class that handles registration of callbacks
        and access to them.
      
      * PassInstrumentation class that handles instrumentation-point interfaces
        that call into PassInstrumentationCallbacks.
      
      * Callbacks accept StringRef which is just a name of the Pass right now.
        There were some ideas to pass an opaque wrapper for the pointer to pass instance,
        however it appears that pointer does not actually identify the instance
        (adaptors and managers might have the same address with the pass they govern).
        Hence it was decided to go simple for now and then later decide on what the proper
        mental model of identifying a "pass in a phase of pipeline" is.
      
      * Callbacks accept llvm::Any serving as a wrapper for const IRUnit*, to remove direct dependencies
        on different IRUnits (e.g. Analyses).
      
      * PassInstrumentationAnalysis analysis is explicitly requested from PassManager through
        usual AnalysisManager::getResult. All pass managers were updated to run that
        to get PassInstrumentation object for instrumentation calls.
      
      * Using tuples/index_sequence getAnalysisResult helper to extract generic AnalysisManager's extra
        args out of a generic PassManager's extra args. This is the only way I was able to explicitly
        run getResult for PassInstrumentationAnalysis out of a generic code like PassManager::run or
        RepeatedPass::run.
        TODO: Upon lengthy discussions we agreed to accept this as an initial implementation
        and then get rid of getAnalysisResult by improving RepeatedPass implementation.
      
      * PassBuilder takes PassInstrumentationCallbacks object to pass it further into
        PassInstrumentationAnalysis. Callbacks registration should be performed directly
        through PassInstrumentationCallbacks.
      
      * new-pm tests updated to account for PassInstrumentationAnalysis being run
      
      * Added PassInstrumentation tests to PassBuilderCallbacks unit tests.
        Other unit tests updated with registration of the now-required PassInstrumentationAnalysis.
      
      Reviewers: chandlerc, philip.pfaffe
      Differential Revision: https://reviews.llvm.org/D47858
      
      llvm-svn: 342544
      875c938f
    • Simon Pilgrim's avatar
      [TableGen] CodeGenDAGPatterns::GenerateVariants - use BitVector::set() where possible. NFCI. · 6d706779
      Simon Pilgrim authored
      In these cases we are always setting to true.
      
      llvm-svn: 342543
      6d706779
    • Benjamin Kramer's avatar
      [InstCombine] Don't transform sin/cos -> tanl if for half types · e5e1ea79
      Benjamin Kramer authored
      This is still unsafe for long double, we will transform things into tanl
      even if tanl is for another type. But that's for someone else to fix.
      
      llvm-svn: 342542
      e5e1ea79
    • Calixte Denizet's avatar
      Verify commit access in fixing typo · 7413a438
      Calixte Denizet authored
      llvm-svn: 342538
      7413a438
    • Simon Pilgrim's avatar
      [TableGen] CodeGenDAGPatterns::GenerateVariants - use BitVector::push_back() · 429df29e
      Simon Pilgrim authored
      As mentioned on D52236, this saves 10secs in debug builds of x86 -gen-dag-isel
      
      llvm-svn: 342536
      429df29e
    • Simon Pilgrim's avatar
      [ADT][BitVector] Add push_back() · 07a5fcd8
      Simon Pilgrim authored
      Add a higher performance alternative to calling resize() every time which performs a lot of clearing to zero - when we're adding a single bit most of the time this will be completely unnecessary.
      
      Differential Revision: https://reviews.llvm.org/D52236
      
      llvm-svn: 342535
      07a5fcd8
    • Alex Bradbury's avatar
      [RISCV] Codegen for i8, i16, and i32 atomicrmw with RV32A · 21aea51e
      Alex Bradbury authored
      Introduce a new RISCVExpandPseudoInsts pass to expand atomic 
      pseudo-instructions after register allocation. This is necessary in order to 
      ensure that register spills aren't introduced between LL and SC, thus breaking 
      the forward progress guarantee for the operation. AArch64 does something 
      similar for CmpXchg (though only at O0), and Mips is moving towards this 
      approach (see D31287). See also [this mailing list 
      post](http://lists.llvm.org/pipermail/llvm-dev/2016-May/099490.html) from 
      James Knight, which summarises the issues with lowering to ll/sc in IR or 
      pre-RA.
      
      See the [accompanying RFC 
      thread](http://lists.llvm.org/pipermail/llvm-dev/2018-June/123993.html) for an 
      overview of the lowering strategy.
      
      Differential Revision: https://reviews.llvm.org/D47882
      
      llvm-svn: 342534
      21aea51e
    • Hans Wennborg's avatar
      [COFF] Emit @feat.00 on 64-bit and set the CFG bit when emitting guardcf tables · 4195eb10
      Hans Wennborg authored
      The 0x800 bit in @feat.00 needs to be set in order to make LLD pick up
      the .gfid$y table. I believe this is fine to set even if we don't emit
      the instrumentation.
      
      We haven't emitted @feat.00 on 64-bit before. I see that MSVC does emit
      it, but I'm not entirely sure what the default value should be. I went
      with zero since that seems as safe as not emitting the symbol in the
      first place.
      
      Differential Revision: https://reviews.llvm.org/D52235
      
      llvm-svn: 342532
      4195eb10
    • Simon Pilgrim's avatar
      [X86][SSE] Update extractelement test in preparation for D52140 · e2b16389
      Simon Pilgrim authored
      SimplifyDemandedVectorEltsForTargetNode will remove most of this test unless get rid of the undefs - still testing for align 1 which was the point of the test
      
      Removed out of date comment as well
      
      llvm-svn: 342531
      e2b16389
    • Carlos Alberto Enciso's avatar
      [DebugInfo][Dexter] Speculated BB presents illegal variable value to debugger. · ba4e437c
      Carlos Alberto Enciso authored
      When SimplifyCFG changes the PHI node into a select instruction, the debug information becomes ambiguous. It causes the debugger to display wrong variable value. 
      
      Differential Revision: https://reviews.llvm.org/D51976
      
      llvm-svn: 342527
      ba4e437c
    • Jonas Devlieghere's avatar
      [DWARF Verifier] Add helper function to dump DIEs. [NFC] · f1f3e737
      Jonas Devlieghere authored
      It's pretty common for the verifier to dump the relevant DIE when it
      finds an issue. This tends to be relatively verbose and error prone
      because we have to pass the DIDumpOptions to the DIE's dump method. This
      patch adds a helper function to the verifier to make this easier.
      
      llvm-svn: 342526
      f1f3e737
    • Thomas Lively's avatar
      [WebAssembly][NFC] Remove extra space in WebAssemblyInstrSIMD.td · ad7e9e9f
      Thomas Lively authored
      llvm-svn: 342522
      ad7e9e9f
    • Matthias Braun's avatar
      AArch64MacroFusion: Factor out some opcode handling code; NFC · 934be5fe
      Matthias Braun authored
      llvm-svn: 342521
      934be5fe
    • Matthias Braun's avatar
      ScheduleDAG: Cleanup dumping code; NFC · 726e12cf
      Matthias Braun authored
      - Instead of having both `SUnit::dump(ScheduleDAG*)` and
        `ScheduleDAG::dumpNode(ScheduleDAG*)`, just keep the latter around.
      - Add `ScheduleDAG::dump()` and avoid code duplication in several
        places. Implement it for different ScheduleDAG variants.
      - Add `ScheduleDAG::dumpNodeName()` in favor of the `SUnit::print()`
        functions. They were only ever used for debug dumping and putting the
        function into ScheduleDAG is consistent with the `dumpNode()` change.
      
      llvm-svn: 342520
      726e12cf
    • Dean Michael Berris's avatar
      [XRay][compiler-rt] FDRLogWriter Abstraction · b64f71b0
      Dean Michael Berris authored
      Summary:
      This change introduces an `FDRLogWriter` type which is responsible for
      serialising metadata and function records to character buffers. This is
      the first step in a refactoring of the implementation of the FDR runtime
      to allow for more granular testing of the individual components of the
      implementation.
      
      The main contribution of this change is a means of hiding the details of
      how specific records are written to a buffer, and for managing the
      extents of these buffers. We make use of C++ features (templates and
      some metaprogramming) to reduce repetition in the act of writing out
      specific kinds of records to the buffer.
      
      In this process, we make a number of changes across both LLVM and
      compiler-rt to allow us to use the `Trace` abstraction defined in the
      LLVM project in the testing of the runtime implementation. This gives us
      a closer end-to-end test which version-locks the runtime implementation
      with the loading implementation in LLVM.
      
      We also allow using gmock in compiler-rt unit tests, by adding the
      requisite definitions in the `AddCompilerRT.cmake` module.
      
      Finally, we've gone ahead and updated the FDR logging implementation to
      use the FDRLogWriter for the lowest-level record-writing details.
      
      Following patches will isolate the state machine transitions which
      manage the set-up and tear-down of the buffers we're using in multiple
      threads.
      
      Reviewers: mboerger, eizan
      
      Subscribers: mgorny, jfb, llvm-commits
      
      Differential Revision: https://reviews.llvm.org/D52220
      
      llvm-svn: 342518
      b64f71b0
  2. Sep 18, 2018
Loading