From 36244e6d15018d0c150b73b309b1f67cef1aa2cd Mon Sep 17 00:00:00 2001 From: DianQK Date: Sun, 17 Dec 2023 20:23:53 +0800 Subject: [PATCH] Change `division_function` to use the `naked` function Solve the issue of not recognizing builtin functions under LTO. --- rp2040-hal/src/sio.rs | 39 +++++++++++++++++++++------------------ 1 file changed, 21 insertions(+), 18 deletions(-) diff --git a/rp2040-hal/src/sio.rs b/rp2040-hal/src/sio.rs index ead75c858..c5df6ea43 100644 --- a/rp2040-hal/src/sio.rs +++ b/rp2040-hal/src/sio.rs @@ -278,29 +278,32 @@ core::arch::global_asm!( macro_rules! division_function { ( - $name:ident $($intrinsic:ident)* ( $argty:ty ) { + $name:ident $intrinsic:ident $intrinsic_alias:ident ( $argty:ty ) { $($begin:literal),+ } ) => { #[cfg(all(target_arch = "arm", not(feature = "disable-intrinsics")))] - core::arch::global_asm!( - // Mangle the name slightly, since this is a global symbol. - concat!(".global _rphal_", stringify!($name)), - concat!(".type _rphal_", stringify!($name), ", %function"), - ".align 2", - concat!("_rphal_", stringify!($name), ":"), - $( - concat!(".global ", stringify!($intrinsic)), - concat!(".type ", stringify!($intrinsic), ", %function"), - concat!(stringify!($intrinsic), ":"), - )* - - "hwdivider_head", - $($begin),+ , - "hwdivider_tail", - ); + intrinsics! { + #[naked] + unsafe extern "C" fn $intrinsic() { + core::arch::asm!( + "hwdivider_head", + $($begin),+ , + "hwdivider_tail", + options(noreturn) + ); + } + #[naked] + unsafe extern "C" fn $intrinsic_alias() { + core::arch::asm!( + "hwdivider_head", + $($begin),+ , + "hwdivider_tail", + options(noreturn) + ); + } + } - #[cfg(all(target_arch = "arm", feature = "disable-intrinsics"))] core::arch::global_asm!( // Mangle the name slightly, since this is a global symbol. concat!(".global _rphal_", stringify!($name)),