Skip to content
  1. Mar 04, 2021
    • Petar Avramovic's avatar
      [GlobalISel] Combine zext(trunc x) to x · 4112299e
      Petar Avramovic authored
      Combine zext(trunc x) to x when truncated bits are known to be zero.
      
      Differential Revision: https://reviews.llvm.org/D96031
      4112299e
    • Petar Avramovic's avatar
      [GlobalISel] Start using vectors in GISelKnownBits · 4c8fb7dd
      Petar Avramovic authored
      For vectors we consider a bit as known if it is the same for all demanded
      vector elements (all elements by default). KnownBits BitWidth for vector
      type is size of vector element. Add support for G_BUILD_VECTOR.
      This allows combines of urem_pow2_to_mask in pre-legalizer combiner.
      
      Differential Revision: https://reviews.llvm.org/D96122
      4c8fb7dd
    • Nico Weber's avatar
      Revert "[Coverage] Emit gap region between statements if first statements... · fe5c2c3c
      Nico Weber authored
      Revert "[Coverage] Emit gap region between statements if first statements contains terminate statements."
      
      This reverts commit 2d7374a0.
      Breaks ContinuousSyncMode/basic.c in check-profile on macOS.
      fe5c2c3c
    • Sanjay Patel's avatar
      [Analysis][LoopVectorize] rename "Unsafe" variables/methods; NFC · b3a33553
      Sanjay Patel authored
      We are tracking an FP instruction that does *not* have FMF (reassoc)
      properties, so calling that "Unsafe" seems opposite of the common
      reading.
      
      I also removed one getter method by rolling the null check into
      the access. Further simplification seems possible.
      
      The motivation is to clean up the interactions between FMF and
      function-level attributes in these classes and their callers.
      b3a33553
    • Jann Horn's avatar
      [CodeGenPrepare] Eliminate llvm.expect before removing empty blocks · 91c9dee3
      Jann Horn authored
      CodeGenPrepare currently first removes empty blocks, then in a loop
      performs other optimizations. One of those optimizations is the removal
      of call instructions that invoke @llvm.assume, which can create new
      empty blocks.
      
      This means that when a branch only contains a call to __builtin_assume(),
      the empty branch will survive into MIR, and will then only be
      half-removed by MIR-level optimizations (e.g. removing the branch but
      leaving the condition intact).
      
      Fix it by eliminating @llvm.expect builtin calls before removing empty
      blocks.
      
      Reviewed By: bkramer
      
      Differential Revision: https://reviews.llvm.org/D97848
      91c9dee3
    • Pavel Labath's avatar
      [lldb] Apply gdb-remote timeout to platform connections as well · bf3ac994
      Pavel Labath authored
      We have a plugin.process.gdb-remote.packet-timeout setting, which can be
      used to control how long the lldb client is willing to wait before
      declaring the server side dead. Our test suite makes use of this
      feature, and sets the setting value fairly high, as the low default
      value can cause flaky tests, particularly on slower bots.
      
      After fixing TestPlatformConnect (one of the few tests exercising the
      remote platform capabilities of lldb) in 4b284b9c, it immediately
      started being flaky on the arm bots. It turns out this is because the
      packet-timeout setting is not being applied to platform connections.
      
      This patch makes the platform connections also respect the value of this
      setting. It also adds a test which checks that the timeout value is
      being honored.
      
      Differential Revision: https://reviews.llvm.org/D97769
      bf3ac994
    • Nicolas Vasilache's avatar
    • Arnamoy Bhattacharyya's avatar
      [flang][driver] Add options for -fdefault* and -flarge-sizes · ab971c29
      Arnamoy Bhattacharyya authored
      Add support for the following Fortran dialect options:
        - -default*
        - -flarge-sizes
      
      It also adds two test cases:
        # For checking whether `flang-new` is passing options correctly to `flang-new -fc1`.
        # For checking if `fdefault-` arguments are processed properly.
      
      Also moves the Dialect related option parsing to a dedicated function
      and adds a member `defaultKinds()` to `CompilerInvocation`
      
      Depends on: D96032
      
      Differential Revision: https://reviews.llvm.org/D96344
      ab971c29
    • Ayke van Laethem's avatar
      [AVR] Fix lifeness issues in the AVR backend · a1155ae6
      Ayke van Laethem authored
      This patch is a large number of small changes that should hopefully not
      affect the generated machine code but are still important to get right
      so that the machine verifier won't complain about them.
      
      The llvm/test/CodeGen/AVR/pseudo/*.mir changes are also necessary
      because without the liveins the used registers are considered undefined
      by the machine verifier and it will complain about them.
      
      Differential Revision: https://reviews.llvm.org/D97172
      a1155ae6
    • Thomas Preud'homme's avatar
      Add __builtin_isnan(__fp16) testcase · 52bfe660
      Thomas Preud'homme authored
      Reviewed By: rjmccall
      
      Differential Revision: https://reviews.llvm.org/D97777
      52bfe660
    • Nicolas Vasilache's avatar
      [mlir] NFC - Add runner util functions to only print MemRef metadata. · 4f4f3f1e
      Nicolas Vasilache authored
      These are useful to debug execution, without having to print the whole
      content of a memref.
      4f4f3f1e
    • Nicolas Vasilache's avatar
    • martinboehme's avatar
      [clang-tidy][NFC] Update docs for bugprone-use-after-move · 3ea0e119
      martinboehme authored
      - Create a separate section on silencing erroneous warnings and add more material to it
      - Add note that the check is flow-sensitive but not path-sensitive
      3ea0e119
    • Thomas Preud'homme's avatar
      Revert "Add __builtin_isnan(__fp16) testcase" · 6d6e7132
      Thomas Preud'homme authored
      This reverts commit e77b5c40 because it
      fails without 1b6eb56a.
      6d6e7132
    • Simon Pilgrim's avatar
      [DAG] TargetLowering::BuildUDIV - use APInt as const ref. NFCI. · 7d3d9fe8
      Simon Pilgrim authored
      Fixes clang-tidy warning.
      7d3d9fe8
    • Simon Pilgrim's avatar
      [X86] X86TargetLowering::isSafeMemOpType - break if-else chain. NFCI. · 7cbc5df4
      Simon Pilgrim authored
      All if-else blocks return - fixes clang-tidy warning.
      7cbc5df4
    • Christian Sigg's avatar
      [mlir] Initialize CUDA context lazily. · f69d5a7f
      Christian Sigg authored
      So we can remove the ignore-warning pragma again.
      
      Reviewed By: herhut
      
      Differential Revision: https://reviews.llvm.org/D97864
      f69d5a7f
    • Thomas Preud'homme's avatar
      Revert "Stop traping on sNaN in __builtin_isinf" · b7aeece4
      Thomas Preud'homme authored
      This reverts commit 1b6eb56a because the
      invert logic for isfinite is incorrect.
      b7aeece4
    • Stephen Tozer's avatar
    • gbtozers's avatar
      [DebugInfo] Add new instruction and DIExpression operator for variadic debug values · d07f106f
      gbtozers authored
      This patch adds a new instruction that can represent variadic debug values,
      DBG_VALUE_VAR. This patch alone covers the addition of the instruction and a set
      of basic code changes in MachineInstr and a few adjacent areas, but does not
      correctly handle variadic debug values outside of these areas, nor does it
      generate them at any point.
      
      The new instruction is similar to the existing DBG_VALUE instruction, with the
      following differences: the operands are in a different order, any number of
      values may be used in the instruction following the Variable and Expression
      operands (these are referred to in code as “debug operands”) and are indexed
      from 0 so that getDebugOperand(X) == getOperand(X+2), and the Expression in a
      DBG_VALUE_VAR must use the DW_OP_LLVM_arg operator to pass arguments into the
      expression.
      
      The new DW_OP_LLVM_arg operator is only valid in expressions appearing in a
      DBG_VALUE_VAR; it takes a single argument and pushes the debug operand at the
      index given by the argument onto the Expression stack. For example the
      sub-expression `DW_OP_LLVM_arg, 0` has the meaning “Push the debug operand at
      index 0 onto the expression stack.”
      
      Differential Revision: https://reviews.llvm.org/D82363
      d07f106f
    • James Henderson's avatar
      [llvm-objcopy][llvm-strip][test] Improve testing · 1562e455
      James Henderson authored
      This patch adds a number of new test cases that cover various
      llvm-objcopy and llvm-strip features that had missing test coverage of
      various descriptions:
      * --add-section - checked the shdr properties, not just the content.
      * Dedicated test case for --add-symbol when there are many sections.
      * Show that --change-start accepts negative values without overflow.
        This was previously present but got lost between review versions.
      * --dump-section - show that multiple sections can be dumped
        simultaneously to different files, and that an error is reported when
        a section cannot be found.
      * --globalize-symbol(s) - show that symbols that are not mentioned are
        not globalized, if they would otherwise be, and that missing symbols
        from the list do not cause problems.
      * --keep-global-symbol - show that the --regex option can be used in
        conjunction with this option.
      * --keep-symbol - show that the --regex option can be used in
        conjunction with this option.
      * --localize-symbol(s) - show that symbols that are not mentioned are
        not localized, if they would otherwise be, and that missing symbols
        from the list do not cause problems.
      * --prefix-alloc-sections - show the behaviour of an empty string
        argument and multiple arguments.
      * --prefix-symbols - show the behaviour of an empty string argument and
        multiple arguments. Also show the option applies to undefined symbols.
      * --redefine-symbol - show that symbols with no name can be renamed,
        that it is not an error if a symbol is not specified, and that the
        option doesn't chain (i.e. --redefine-sym a=b --redefine-sym b=c does
        not redefine a as c).
      * --rename-section - show that all section flags are preserved if none
        are specified. Also show that the option does not chain.
      * --set-section-alignment - show that only specified sections have
        their alignments changed.
      * --set-section-flags - show which section flags are preserved when this
        option is used. Also show that unspecified sections are not affected.
      * --preserve-dates - show that -p is an alias of --preserve-dates.
      * --strip-symbol - show that --regex works with this option for
        llvm-objcopy as well as llvm-strip.
      * --strip-unneeded-symbol(s) - show more clearly that needed symbols are
        not stripped even if requested by this option.
      * --allow-broken-links - show the sh_link of a symbol table is set to 0
        when its string table has been removed when this option is specified.
      * --weaken-symbol(s) - show that symbols that are not mentioned are not
        weakened, if they would otherwise be, and that missing symbols from
        the list do not cause problems.
      * --wildcard - show the wildcard behaviour for several options that were
        previously unchecked.
      
      Reviewed by: alexshap
      
      Differential Revision: https://reviews.llvm.org/D97666
      1562e455
    • Hans Wennborg's avatar
      Revert "[darwin] switch blocking mutex from osspinlock to os_unfair_lock" · 840a16d3
      Hans Wennborg authored
      > OSSpinLock is deprecated, so we are switching to `os_unfair_lock`. However, `os_unfair_lock` isn't available on older OSs, so we keep `OSSpinLock` as fallback.
      >
      > Also change runtime assumption check to static since they only ever check constant values.
      >
      > rdar://69588111
      >
      > Reviewed By: delcypher, yln
      >
      > Differential Revision: https://reviews.llvm.org/D97509
      
      This reverts commit 71ef5433.
      840a16d3
    • LLVM GN Syncbot's avatar
      [gn build] Port d791695c · 635db351
      LLVM GN Syncbot authored
      635db351
    • Oliver Stannard's avatar
      [objdump][ARM] Use correct offset when printing ARM/Thumb branch targets · aac056c5
      Oliver Stannard authored
      llvm-objdump only uses one MCInstrAnalysis object, so if ARM and Thumb
      code is mixed in one object, or if an object is disassembled without
      explicitly setting the triple to match the ISA used, then branch and
      call targets will be printed incorrectly.
      
      This could be fixed by creating two MCInstrAnalysis objects in
      llvm-objdump, like we currently do for SubtargetInfo. However, I don't
      think there's any reason we need two separate sub-classes of
      MCInstrAnalysis, so instead these can be merged into one, and the ISA
      determined by checking the opcode of the instruction.
      
      Differential revision: https://reviews.llvm.org/D97766
      aac056c5
    • Andrew Savonichev's avatar
      [MCA] Add support for in-order CPUs · d791695c
      Andrew Savonichev authored
      This patch adds a pipeline to support in-order CPUs such as ARM
      Cortex-A55.
      
      In-order pipeline implements a simplified version of Dispatch,
      Scheduler and Execute stages as a single stage. Entry and Retire
      stages are common for both in-order and out-of-order pipelines.
      
      Differential Revision: https://reviews.llvm.org/D94928
      d791695c
    • Simon Pilgrim's avatar
      [X86] canonicalizeShuffleWithBinOps - handle general unaryshuffle(binop(x,c))... · 1584e55a
      Simon Pilgrim authored
      [X86] canonicalizeShuffleWithBinOps - handle general unaryshuffle(binop(x,c)) patterns not just xor(x,-1)
      
      Generalize the shuffle(not(x)) -> not(shuffle(x)) fold to handle any binop with 0/-1.
      
      Hopefully we can further generalize to help push target unary/binary shuffles through binops similar to what we do in DAGCombiner::visitVECTOR_SHUFFLE
      1584e55a
    • Fraser Cormack's avatar
      [NFC] Fix typos in CallingConvLower.h · c907681b
      Fraser Cormack authored
      c907681b
    • James Henderson's avatar
      [llvm-objcopy][llvm-strip] Improve --discard-all documentation and help · f2e85c31
      James Henderson authored
      The help text and documentation for the --discard-all option failed to
      mention that the option also causes the removal of debug sections. This
      change fixes both for both llvm-objcopy and llvm-strip.
      
      Reviewed by: MaskRay
      
      Differential Revision: https://reviews.llvm.org/D97662
      f2e85c31
    • James Henderson's avatar
      [llvm-objcopy/strip] Fix off-by-one error in SYMTAB_SHNDX need check · 8bb74d16
      James Henderson authored
      The check for whether an extended symbol index table was required
      dropped the first SHN_LORESERVE sections from the sections array before
      checking whether the remaining sections had symbols. Unfortunately, the
      null section header is not present in this list, so the check was
      skipping the first section that might be important. If that section
      contained a symbol, and no subsequent ones did, the .symtab_shndx
      section would not be emitted, leading to a corrupt object.
      
      Also consolidate and expand test coverage in the area to cover this bug
      and other aspects of the SYMTAB_SHNDX section.
      
      Reviewed by: alexshap, MaskRay
      
      Differential Revision: https://reviews.llvm.org/D97661
      8bb74d16
    • David Spickett's avatar
      [libcxx] Move Linaro AArch64 buildbots to buildkite · 6e5342a6
      David Spickett authored
      Reviewed By: #libc, ldionne
      
      Differential Revision: https://reviews.llvm.org/D96267
      6e5342a6
    • Kadir Cetinkaya's avatar
      [clangd] Introduce client state invalidation · 1d7b3281
      Kadir Cetinkaya authored
      Clangd can invalidate client state of features like semantic higlighting
      without client explicitly triggering, for example after a preamble build
      caused by an onSave notification on a different file.
      
      This patch introduces a mechanism to let client know of such actions,
      and also calls the workspace/semanticTokens/refresh request to
      demonstrate the situation after each preamble build.
      
      Fixes https://github.com/clangd/clangd/issues/699.
      
      Differential Revision: https://reviews.llvm.org/D97548
      1d7b3281
    • David Green's avatar
      [ARM] Remove new ARMSelectionDAGTest unittest. · 098aea95
      David Green authored
      This removes the unit test from a968e7b8 as it reportedly causes
      some link problems. It can be reinstated once the issues are understood
      and sorted out.
      098aea95
    • Michael Kruse's avatar
      [Polly][Codegen] Emit access group metadata. · b85c98b4
      Michael Kruse authored
      Emit llvm.loop.parallel_accesses metadata instead of
      llvm.mem.parallel_loop_access. The latter is deprecated because it
      assumes that LoopIDs are persistent, which they are not.
      We also emit parallel access metadata for all surrounding parallel
      loops, not just the innermost parallel.
      b85c98b4
    • Alex Zinenko's avatar
      [mlir] ODS: change OpBuilderDAG to OpBuilder · 32c49c7d
      Alex Zinenko authored
      We no longer have the non-DAG version.
      
      Reviewed By: rriddle
      
      Differential Revision: https://reviews.llvm.org/D97856
      32c49c7d
    • Max Kazantsev's avatar
      [X86][CodeGenPrepare] Try to reuse IV's incremented value instead of adding the offset, part 2 · 9d5af555
      Max Kazantsev authored
      This patch enables the case where we do not completely eliminate offset.
      Supposedly in this case we reduce live range overlap that never harms, but
      since there are doubts this is true, this goes as a separate change.
      
      Differential Revision: https://reviews.llvm.org/D96399
      Reviewed By: reames
      9d5af555
    • James Henderson's avatar
      [llvm-objcopy][test] Improve many-sections object and test case · 49c91a64
      James Henderson authored
      Additionally do some test tidy-ups and improve coverage of symbol
      section indexes where the logical section index >= SHN_LORESERVE.
      
      The symbol and section names in the many-section input object were
      mostly shared. This patch changes them to be distinct, enabling
      different operations such as --add-symbol, to be more targeted, when
      using the object. It also makes the test less confusing and removes some
      oddness in the symbol table order, presumably caused by the duplicate
      names.
      
      The input object was built from assembly that was of the form:
      .section s1
      sym1:
      .section s2
      sym2:
      ...
      with a total of 65536 such occurrences. llvm-objcopy was then used to
      remove the empty .text section automatically generated by MC, and
      incidentally to move .strtab to the end of the object. This ensured that
      the section/symbol indexes matched their name (i.e. section index 1 was
      s1, section index 2 was s2 etc, and sym1 was in s1, sym2 in s2 etc).
      
      Reviewed by: MaskRay
      
      Differential Revision: https://reviews.llvm.org/D97660
      49c91a64
    • Fraser Cormack's avatar
      [RISCV] Fix crash when inserting large fixed-length subvectors · 8e7ceffd
      Fraser Cormack authored
      This patch addresses a compiler crash resulting from passing a
      fixed-length type to one that expects scalable vector types. An
      assertion was added to prevent this regressing in the future.
      
      Reviewed By: craig.topper
      
      Differential Revision: https://reviews.llvm.org/D97868
      8e7ceffd
    • Fraser Cormack's avatar
      [RISCV] Preserve fixed-length VL on insert_vector_elt in more cases · d8e1d2eb
      Fraser Cormack authored
      This patch fixes up one case where the fixed-length-vector VL was
      dropped (falling back to VLMAX) when inserting vector elements, as the
      code would lower via ISD::INSERT_VECTOR_ELT (at index 0) which loses the
      fixed-length vector information.
      
      To this end, a custom node, VMV_S_XF_VL, was introduced to carry the VL
      operand through to the final instruction. This node wraps the RVV
      vmv.s.x and vmv.s.f instructions, which were being selected by
      insert_vector_elt anyway.
      
      There should be no observable difference in scalable-vector codegen.
      
      There is still one outstanding drop from fixed-length VL to VLMAX, when
      an i64 element is inserted into a vector on RV32; the splat (which is
      custom legalized) has no notion of the original fixed-length vector
      type.
      
      Reviewed By: craig.topper
      
      Differential Revision: https://reviews.llvm.org/D97842
      d8e1d2eb
    • Martin Storsjö's avatar
      1bdb6366
    • Petr Hosek's avatar
      Revert "[XRay][x86_64] Fix CFI directives in assembly trampolines" · 46a3f4ae
      Petr Hosek authored
      This reverts commit 9ee61cf3 since
      it's failing to compile on Darwin.
      46a3f4ae
Loading