[llvm-branch-commits] [llvm] [AtomicExpand] Add bitcasts when expanding load atomic vector (PR #148900)
via llvm-branch-commits
llvm-branch-commits at lists.llvm.org
Mon Oct 20 14:47:36 PDT 2025
================
@@ -1211,6 +1211,11 @@ def : Pat<(v4i32 (scalar_to_vector (i32 (atomic_load_32 addr:$src)))),
def : Pat<(v2i64 (scalar_to_vector (i64 (atomic_load_64 addr:$src)))),
(MOV64toPQIrm addr:$src)>; // load atomic <2 x i32,float>
+def : Pat<(v2i64 (atomic_load_128_v2i64 addr:$src)),
+ (VMOVAPDrm addr:$src)>; // load atomic <2 x i64>
+def : Pat<(v4i32 (atomic_load_128_v4i32 addr:$src)),
+ (VMOVAPDrm addr:$src)>; // load atomic <4 x i32>
----------------
jofrn wrote:
It is required for the SSE/AVX extensions, like in `atomic_vec2_ptr_align` with `-mcpu=x86-64-v2`. If the extensions are enabled, then this pattern has to be handled in this test.
https://github.com/llvm/llvm-project/pull/148900
More information about the llvm-branch-commits
mailing list