Skip to content
New issue

Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.

By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.

Already on GitHub? Sign in to your account

[AArch64] Incorrect register used for inline assembly input #58384

Open
Amanieu opened this issue Oct 15, 2022 · 3 comments
Open

[AArch64] Incorrect register used for inline assembly input #58384

Amanieu opened this issue Oct 15, 2022 · 3 comments

Comments

@Amanieu
Copy link
Contributor

Amanieu commented Oct 15, 2022

define void @foo() {
  %1 = call i32 asm sideeffect "", "={x0},0"(i32 435)
  ret void
}

With llc -march=aarch64 -O0, this generates the following assembly.

foo:                                    // @foo
	.cfi_startproc
// %bb.0:
	mov	w8, #435
	mrs	x0, NZCV
	//APP
	//NO_APP
	ret

Using ={x0},{x0} instead of ={x0},0 seems to avoid this issue,

This IR is generated by rustc's inline assembly for an inout("x8") operand, so perhaps this is rustc's fault?
Actually I can reproduce this bug in Clang as well, so it's definitely not an issue that is unique to rustc.

void foo() {
    register int x asm("x8") = 435;
    asm volatile("" : "+&r" (x));
}
@nikic
Copy link
Contributor

nikic commented Oct 15, 2022

Causes an assertion failure:

X0 = COPY W8
unimplemented reg-to-reg copy

@llvmbot
Copy link
Member

llvmbot commented Oct 15, 2022

@llvm/issue-subscribers-backend-aarch64

Amanieu added a commit to Amanieu/rust that referenced this issue Nov 2, 2022
Upstream issue: llvm/llvm-project#58384

LLVM gets confused if we assign a 32-bit value to a 64-bit register, so
pass the 32-bit register name to LLVM in that case.
@Amanieu
Copy link
Contributor Author

Amanieu commented Nov 3, 2022

I worked around this in rustc (rust-lang/rust#103897) by renaming the register to wN instead of xN if the type is 32-bit or smaller. Perhaps this should be solved in the frontend in Clang?

matthiaskrgr added a commit to matthiaskrgr/rust that referenced this issue Nov 4, 2022
asm: Work around LLVM bug on AArch64

Upstream issue: llvm/llvm-project#58384

LLVM gets confused if we assign a 32-bit value to a 64-bit register, so pass the 32-bit register name to LLVM in that case.
Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment
Projects
None yet
Development

No branches or pull requests

4 participants