This project is mirrored from https://github.com/llvm/llvm-project.git.
Pull mirroring failed .
Repository mirroring has been paused due to too many failed attempts. It can be resumed by a project maintainer or owner.
Last successful update .
Repository mirroring has been paused due to too many failed attempts. It can be resumed by a project maintainer or owner.
Last successful update .
- Apr 09, 2022
-
-
Siu Chi Chan authored
Fix backward compatibility issue due to D120662. Change-Id: I7cd0f704aabbaac7dcf59fd4b73b4f0e0cdfa69f Reviewed By: yaxunl, saiislam Differential Revision: https://reviews.llvm.org/D123387
-
Arthur Eubanks authored
And thread DSE's ephemeral values to EarliestEscapeInfo. This allows more precise analysis in DSEState::isReadClobber() via BatchAA. Followup to D123162. Reviewed By: nikic Differential Revision: https://reviews.llvm.org/D123342
-
Fangrui Song authored
`.symver foo, foo@ver` creates the MCSymbolELF `foo@ver` whose almost all attributes (including st_size) should inherit from `foo` (GNU as behavior). a041ef1b added st_size propagation which works for many cases but fails for the following one: ``` .set __GLIBC_2_12_sys_errlist, _sys_errlist_internal .type __GLIBC_2_12_sys_errlist,@object .size __GLIBC_2_12_sys_errlist, 1080 .symver __GLIBC_2_12_sys_errlist, sys_errlist@GLIBC_2.12 ... _sys_errlist_internal: .size _sys_errlist_internal, 1072 ``` `sys_errlist@GLIBC_2.12`'s st_size is 1072 (incorrect), which does not match `__GLIBC_2_12_sys_errlist`'s st_size: 1080. The problem is that `Base` is (the final) `_sys_errlist_internal` while we want to respect (the intermediate) `__GLIBC_2_12_sys_errlist`'s st_size. Fix this by following the MCSymbolRefExpr assignment chain and finding the closest non-null `getSize()`, which covers most needs. Notably MCBinaryExpr is not handled, but it is rare enough to matter. Reviewed By: peter.smith Differential Revision: https://reviews.llvm.org/D123283
-
Fangrui Song authored
-
Kevin Athey authored
one more follow up to: https://reviews.llvm.org/D122851 Differential Revision: https://reviews.llvm.org/D123404
-
Daniel Grumberg authored
Differential Revision: https://reviews.llvm.org/D123391
-
PeixinQiao authored
As Fortran 2018 3.18 states, the branch target statement can be `forall-construct-stmt`, but cannot be `forall-stmt`. `forall-stmt` is wrapped by `Statement` in `action-stmt` and `action-stmt` can be one branch target statement. Fix the semantic analysis and add two regression test cases in lowering. Reviewed By: Jean Perier Differential Revision: https://reviews.llvm.org/D123373
-
Fraser Cormack authored
Similar to D123217 but for the floating-point patterns. No change in generated output, while reducing the generated table size. Reviewed By: arcbbb Differential Revision: https://reviews.llvm.org/D123291
-
Vang Thao authored
Reviewed By: foad Differential Revision: https://reviews.llvm.org/D123348
-
Snehasish Kumar authored
The current implementation of memprof information in the indexed profile format stores the representation of each calling context fram inline. This patch uses an interned representation where the frame contents are stored in a separate on-disk hash table. The table is indexed via a hash of the contents of the frame. With this patch, the compressed size of a large memprof profile reduces by ~22%. Reviewed By: tejohnson Differential Revision: https://reviews.llvm.org/D123094
-
kristina authored
-
Craig Topper authored
SLLI is always compressible to C.SLLI as long as the source and dest register is the same. ANDI and SRLI are only compressible if the register is x8-x15. By using SLLI we have a better chance of generating shorter code. I had to exclude one exclusion for the BEXTI case so that it's pattern match could still fire. Reviewed By: luismarques Differential Revision: https://reviews.llvm.org/D123336
-
Simon Pilgrim authored
Based on Issue #37628
-
- Apr 08, 2022
-
-
Kevin Athey authored
Follow up to: https://reviews.llvm.org/D122851 Differential Revision: https://reviews.llvm.org/D123395
-
Nikita Popov authored
Rather than checking the rounded type store size, check the type size in bits. We don't want to forward a store of i1 to a load of i8 for example, even though they have the same type store size. The padding bits have unspecified contents. This is a partial fix for the issue reported at https://reviews.llvm.org/D115924#inline-1179482, the problem also needs to be addressed more generally in the constant folding code.
-
Florian Hahn authored
Update createEmptyBasicBlock to preserve the debug location of the previous terminator.
-
Florian Hahn authored
Adds a test case where currently no debug location is added to branches in the vector body.
-
Zaara Syeda authored
Loop Strength Reduce sometimes optimizes away all uses of an induction variable from a loop but leaves the IV increments. When the only remaining use of the IV is the PHI in the exit block, this patch will call rewriteLoopExitValues to replace the exit block PHI with the final value of the IV to skip the updates in each loop iteration. Differential Revision: https://reviews.llvm.org/D118808
-
Mark de Wever authored
Adds a `__get_container` member as suggested by @Quuxplusone in D110497. Includes s/_LIBCPP_INLINE_VISIBILITY/_LIBCPP_HIDE_FROM_ABI/. Reviewed By: Quuxplusone, #libc, ldionne Differential Revision: https://reviews.llvm.org/D110573
-
Mark de Wever authored
Before implementing P2216's format-string adjust the unit tests. After P2216 the format* functions require a compile-time string literal. This changes prepares the tests. Reviewed By: #libc, ldionne Differential Revision: https://reviews.llvm.org/D122534
-
Alexandre Ganea authored
Windows.
-
Joseph Huber authored
Summary: The changes made in D123177 added new targets to the `LIBOMPTARGET_TESTED_PLUGINS` variable which was linked against when building the `llvm-omp-target-info` tool. This caused linker errors on the export scripts. This patch removes that dependency, it still builds and runs as expected so I will assume it's correct.
-
Nikita Popov authored
Semantics here are a bit unclear, but the store-to-load forwarding case at least should be a miscompile.
-
Shraiysh Vaishay authored
This patch adds translation for allocate clause for parallel and single constructs. Also added tests for block constructs. This patch also adds tests for parallel construct which were not added earlier. Reviewed By: NimishMishra, peixin Differential Revision: https://reviews.llvm.org/D122483 Co-authored-by:
Sourabh Singh Tomar <SourabhSingh.Tomar@amd.com>
-
Aaron Ballman authored
The LANGOPT macro allows you to specify a default value for the langauge option. However, it's expected that these values be constant rather than depending on other language options (because the constructor setting the default values does not know the language mode at the time it's being constructed). Some of our language options were abusing this and passing in other language mode options which were then set correctly by other parts of frontend initialization. This removes the default values for the language options, and then ensures they're consistently set from the same place when setting language standard defaults.
-
Joseph Huber authored
Summary: The `-fopenmp-target-new-runtime` flag has not been used for awhile. It was present in a previous release so we shouldn't remove it for backwards compatibility, but we shouldn't have documentation or a help message for it.
-
Christudasan Devadasan authored
-
Nikita Popov authored
Don't try to directly use the with.overflow flag result in a cmov if we need to materialize constants between the instruction producing the overflow flag and the cmov. The current code is careful to check that there are no other instructions in between, but misses the constant materialization case (which may clobber eflags via xor or constant expression evaluation). Fixes https://github.com/llvm/llvm-project/issues/54369. Differential Revision: https://reviews.llvm.org/D122825
-
Carlos Alberto Enciso authored
The changes described by: https://reviews.llvm.org/D121801 https://reviews.llvm.org/D122226 Moved some llvm-pdbutil functionality to the debug PDB library. This patch addresses one outstanding issue concerning the global state (Filters) created in the PDB library. - Move 'Filters' inside the 'LinePrinter' class. - Omit 'Optional' and just pass 'PrintScope &HeaderScope' everywhere. Reviewed By: aganea Differential Revision: https://reviews.llvm.org/D122887
-
Benjamin Kramer authored
-
Jean Perier authored
The actual argument passed to STATUS may be a dummy OPTIONAL or a disassociated POINTER/unallocated ALLOCATABLE. Differential Revision: https://reviews.llvm.org/D123380
-
Nikita Popov authored
This test is currently looking for specific typed-pointer IR, so explicitly disable opaque pointers.
-
Nikita Popov authored
The output differs slightly with opaque pointers (no GEP constexpr), add -no-opaque-pointers for now.
-
Nikita Popov authored
This was skipping specific lifetime + bitcast patterns, but with opaque pointers the bitcast will not be present, and we did not perform this fold. Instead skip over lifetime.end and bitcasts generally, without trying to correlate them.
-
Nathan James authored
Fixes https://llvm.org/PR50157 Adds support for when the container being read from in a range-for is a member of a struct. Reviewed By: aaron.ballman Differential Revision: https://reviews.llvm.org/D101624
-
Vivek Khandelwal authored
This commit adds pooling_nchw_sum as a yaml op. Reviewed By: cathyzhyi, gysit Differential Revision: https://reviews.llvm.org/D123013
-
Jean Perier authored
isAbsent/isPresent helpers only give information about static presence of intrinsic arguments. Many intrinsic arguments optionality is dynamic (an absent dummy can legally be passed to these intrinsics). This requires a different handling (like `handleDynamicOptional`). Rename the helpers to avoid misleading coder/reader into thinking all optionality cases are covered by them. Differential Revision: https://reviews.llvm.org/D123378
-
Fraser Cormack authored
This patch aims to overcome an issue in these mappings where, when an ISD node was registered with BEGIN_REGISTER_VP_SDNODE but outwidth the scope of a pair of BEGIN_REGISTER_VP_INTRINSIC/END_REGISTER_VP_INTRINSIC macros, the switch cases fell apart. This in particular happened with VP_SETCC, where we'd end up with something along the lines of: case Intrinsic::vp_fcmp: break; case Intrinsic::vp_icmp: break; ResOpc = ISD::VP_SETCC; case Intrinsic::vp_store: ... To remedy this, we introduce a special-purpose mapping macro which can map any number of VP intrinsic opcodes to an ISD opcode. As a result, we no longer need to special-case the mapping from vp.icmp and vp.fcmp to VP_SETCC, as the new helper macro does it for us. Thanks to @craig.topper for noticing this and to @rogfer01 for the idea. Reviewed By: rogfer01 Differential Revision: https://reviews.llvm.org/D123324
-
LLVM GN Syncbot authored
-
David Green authored
Perfect shuffle costs are always encoded less than 4, and shouldn't really have a cost more than 3, so it makes no sense to check it when generating shuffles. The perfect shuffle is likely always better than a tbl too (although that may depend on whether it is in a loop).
-