[clang] Do not report -Wasm-operand-widths for Aarch64 ilp32 operands (PR #73385)
via cfe-commits
cfe-commits at lists.llvm.org
Sat Nov 25 04:39:14 PST 2023
llvmbot wrote:
<!--LLVM PR SUMMARY COMMENT-->
@llvm/pr-subscribers-clang
@llvm/pr-subscribers-backend-aarch64
Author: None (joyhou-hw)
<details>
<summary>Changes</summary>
Since width of pointer type is 32 bits in ILP32 while memory instruction shall 'x' registers. msr/mrs likewise.
Now Wasm-operand-widths in ILP32 will warning below asm code with a WRONG massage.
```
void atomicAdd32(int *ptr, int lIncr)
{
int result = 0;
unsigned int tmp = 0;
__asm__ volatile(
"1: ldxr %w0, [%2] \n\t"
" add %w0, %w0, %w3 \n\t"
" stxr %w1, %w0, [%2] \n\t"
" cbnz %w1, 1b \n\t"
: "=&r"(result), "=&r"(tmp)
: "r"(ptr), "Ir"(lIncr)
:"memory","cc"
);
}
```
The [%2] shall be 'x' rregister for ldxr inst., not the %w2.
```
warning: value size does not match register size specified by the constraint and modifier [-Wasm-operand-widths]
: "r"(ptr), "Ir"(lIncr)
^
: note: use constraint modifier "w"
"1: ldxr %w0, [%2] \n\t"
^~
%w2
```
---
Full diff: https://github.com/llvm/llvm-project/pull/73385.diff
1 Files Affected:
- (modified) clang/lib/Basic/Targets/AArch64.cpp (+4)
``````````diff
diff --git a/clang/lib/Basic/Targets/AArch64.cpp b/clang/lib/Basic/Targets/AArch64.cpp
index c31f2e0bee54393..180c5f17d7835a4 100644
--- a/clang/lib/Basic/Targets/AArch64.cpp
+++ b/clang/lib/Basic/Targets/AArch64.cpp
@@ -1362,6 +1362,10 @@ bool AArch64TargetInfo::validateAsmConstraint(
bool AArch64TargetInfo::validateConstraintModifier(
StringRef Constraint, char Modifier, unsigned Size,
std::string &SuggestedModifier) const {
+ // Ignore in ILP32 since width of pointer type is 32 bits
+ // while memory instruction shall 'x' registers.
+ if (getTriple().getEnvironment() == llvm::Triple::GNUILP32)
+ return true;
// Strip off constraint modifiers.
while (Constraint[0] == '=' || Constraint[0] == '+' || Constraint[0] == '&')
Constraint = Constraint.substr(1);
``````````
</details>
https://github.com/llvm/llvm-project/pull/73385
More information about the cfe-commits
mailing list