Re: [PATCH] rust: sync: optimize rust symbol generation for CondVar
From: Benno Lossin
Date: Mon Mar 17 2025 - 06:19:46 EST
On Mon Mar 17, 2025 at 9:13 AM CET, Kunwu Chan wrote:
> From: Kunwu Chan <kunwu.chan@xxxxxxxxxxx>
>
> When build the kernel using the llvm-18.1.3-rust-1.85.0-x86_64
> with ARCH=arm64, the following symbols are generated:
>
> $nm vmlinux | grep ' _R'.*CondVar | rustfilt
> ... T <kernel::sync::condvar::CondVar>::notify_all
> ... T <kernel::sync::condvar::CondVar>::notify_one
> ... T <kernel::sync::condvar::CondVar>::notify_sync
> ... T <kernel::sync::condvar::CondVar>::new::{closure#0}::{closure#0}::panic_cold_explicit
> ... T <kernel::sync::condvar::CondVar>::new::{closure#0}::{closure#0}::panic_cold_explicit
> ... T <kernel::sync::poll::PollCondVar>::new::{closure#0}::{closure#0}::panic_cold_explicit
> ... T <kernel::sync::poll::PollCondVar as core::ops::drop::Drop>::drop
>
> These notify* symbols are trivial wrappers around the C functions
> __wake_up and __wake_up_sync.
> It doesn't make sense to go through a trivial wrapper for these
> functions, so mark them inline.
>
> Link: https://github.com/Rust-for-Linux/linux/issues/1145
> Suggested-by: Alice Ryhl <aliceryhl@xxxxxxxxxx>
> Co-developed-by: Grace Deng <Grace.Deng006@xxxxxxxxx>
> Signed-off-by: Grace Deng <Grace.Deng006@xxxxxxxxx>
> Signed-off-by: Kunwu Chan <kunwu.chan@xxxxxxxxxxx>
Reviewed-by: Benno Lossin <benno.lossin@xxxxxxxxx>
---
Cheers,
Benno
> ---
> rust/kernel/sync/condvar.rs | 4 ++++
> 1 file changed, 4 insertions(+)