[llvm] [ARM] Use correct ABI for atomic functions (PR #128891)
Matt Arsenault via llvm-commits
llvm-commits at lists.llvm.org
Wed Feb 26 22:54:55 PST 2025
================
@@ -1999,6 +1999,19 @@ bool AtomicExpandImpl::expandAtomicOpToLibcall(
Value *IntValue =
Builder.CreateBitOrPointerCast(ValueOperand, SizedIntTy);
Args.push_back(IntValue);
+
+ // Set the zeroext/signext attributes on the parameter if needed to match
+ // the target's ABI.
+ if (TLI->shouldExtendTypeInLibCall(
+ TLI->getMemValueType(DL, SizedIntTy))) {
+ // The only atomic operations affected by signedness are min/max, and
+ // we don't have __atomic_ libcalls for them, so IsSigned is always
+ // false.
+ if (TLI->shouldSignExtendTypeInLibCall(SizedIntTy, false /*IsSigned*/))
+ Attr = Attr.addParamAttribute(Ctx, Args.size() - 1, Attribute::SExt);
+ else
+ Attr = Attr.addParamAttribute(Ctx, Args.size() - 1, Attribute::ZExt);
----------------
arsenm wrote:
```suggestion
Attribute::AttrKind ExtAttr = TLI->shouldSignExtendTypeInLibCall(SizedIntTy, /*IsSigned=*/false) ? Attribute::SExt : Attribute::ZExt;
Attr = Attr.addParamAttribute(Ctx, Args.size() - 1, AttrKind);
```
https://github.com/llvm/llvm-project/pull/128891
More information about the llvm-commits
mailing list