[llvm-branch-commits] [llvm] [SelectionDAG][X86] Widen <2 x T> vector types for atomic load (PR #120598)
via llvm-branch-commits
llvm-branch-commits at lists.llvm.org
Tue Jan 21 09:53:28 PST 2025
================
@@ -5907,6 +5910,30 @@ SDValue DAGTypeLegalizer::WidenVecRes_INSERT_VECTOR_ELT(SDNode *N) {
N->getOperand(1), N->getOperand(2));
}
+SDValue DAGTypeLegalizer::WidenVecRes_ATOMIC_LOAD(AtomicSDNode *N) {
+ SmallVector<SDValue, 16> LdChain; // Chain for the series of load
+ SDValue Result = GenWidenVectorLoads(LdChain, N, /*IsAtomic=*/true);
----------------
jofrn wrote:
Within GenWidenVectorLoads, MemVTs should be empty and so we will generate a single atomic anyway. I've added a check `IsAtomic` to ensure we go down this path.
https://github.com/llvm/llvm-project/pull/120598
More information about the llvm-branch-commits
mailing list