From 807534e33b7d7deb4473a53c5764d5843f5e5e26 Mon Sep 17 00:00:00 2001 From: Artyom Pavlov Date: Fri, 27 Dec 2024 15:23:58 +0300 Subject: [PATCH] Use const operand in the ARM branch --- src/backends/linux_raw.rs | 4 +++- 1 file changed, 3 insertions(+), 1 deletion(-) diff --git a/src/backends/linux_raw.rs b/src/backends/linux_raw.rs index 25db23ad..df8bf082 100644 --- a/src/backends/linux_raw.rs +++ b/src/backends/linux_raw.rs @@ -13,6 +13,7 @@ unsafe fn getrandom_syscall(buf: *mut u8, buflen: usize, flags: u32) -> isize { // Based on `rustix` and `linux-raw-sys` code. cfg_if! { if #[cfg(target_arch = "arm")] { + const __NR_getrandom: u32 = 384; // In thumb-mode, r7 is the frame pointer and is not permitted to be used in // an inline asm operand, so we have to use a different register and copy it // into r7 inside the inline asm. @@ -21,9 +22,10 @@ unsafe fn getrandom_syscall(buf: *mut u8, buflen: usize, flags: u32) -> isize { // bother with it. core::arch::asm!( "mov {tmp}, r7", - "mov r7, #384", // __NR_getrandom = 384 + "mov r7, {nr}", "svc 0", "mov r7, {tmp}", + nr = const __NR_getrandom, tmp = out(reg) _, inlateout("r0") buf => r0, in("r1") buflen,