From: Alice Ryhl <aliceryhl@google.com>
To: rust-for-linux@vger.kernel.org
Cc: linux-kernel@vger.kernel.org, Alice Ryhl <aliceryhl@google.com>,
Boqun Feng <boqun.feng@gmail.com>, Gary Guo <gary@garyguo.net>,
Peter Zijlstra <peterz@infradead.org>,
Ingo Molnar <mingo@redhat.com>, Will Deacon <will@kernel.org>,
Waiman Long <longman@redhat.com>,
Mitchell Levy <levymitchell0@gmail.com>,
Benno Lossin <lossin@kernel.org>
Subject: [PATCH v2 20/27] rust: sync: add __rust_helper to helpers
Date: Mon, 05 Jan 2026 12:42:33 +0000 [thread overview]
Message-ID: <20260105-define-rust-helper-v2-20-51da5f454a67@google.com> (raw)
In-Reply-To: <20260105-define-rust-helper-v2-0-51da5f454a67@google.com>
This is needed to inline these helpers into Rust code.
Reviewed-by: Boqun Feng <boqun.feng@gmail.com>
Reviewed-by: Gary Guo <gary@garyguo.net>
Signed-off-by: Alice Ryhl <aliceryhl@google.com>
---
Cc: Peter Zijlstra <peterz@infradead.org>
Cc: Ingo Molnar <mingo@redhat.com>
Cc: Will Deacon <will@kernel.org>
Cc: Boqun Feng <boqun.feng@gmail.com>
Cc: Waiman Long <longman@redhat.com>
Cc: Mitchell Levy <levymitchell0@gmail.com>
Cc: Benno Lossin <lossin@kernel.org>
---
rust/helpers/mutex.c | 13 +++++++------
rust/helpers/spinlock.c | 13 +++++++------
rust/helpers/sync.c | 4 ++--
3 files changed, 16 insertions(+), 14 deletions(-)
diff --git a/rust/helpers/mutex.c b/rust/helpers/mutex.c
index e487819125f0dfe0741601205e8f84d322c973d5..1b07d6e64299d509bc3ce1af99b19aa97b721fc6 100644
--- a/rust/helpers/mutex.c
+++ b/rust/helpers/mutex.c
@@ -2,28 +2,29 @@
#include <linux/mutex.h>
-void rust_helper_mutex_lock(struct mutex *lock)
+__rust_helper void rust_helper_mutex_lock(struct mutex *lock)
{
mutex_lock(lock);
}
-int rust_helper_mutex_trylock(struct mutex *lock)
+__rust_helper int rust_helper_mutex_trylock(struct mutex *lock)
{
return mutex_trylock(lock);
}
-void rust_helper___mutex_init(struct mutex *mutex, const char *name,
- struct lock_class_key *key)
+__rust_helper void rust_helper___mutex_init(struct mutex *mutex,
+ const char *name,
+ struct lock_class_key *key)
{
__mutex_init(mutex, name, key);
}
-void rust_helper_mutex_assert_is_held(struct mutex *mutex)
+__rust_helper void rust_helper_mutex_assert_is_held(struct mutex *mutex)
{
lockdep_assert_held(mutex);
}
-void rust_helper_mutex_destroy(struct mutex *lock)
+__rust_helper void rust_helper_mutex_destroy(struct mutex *lock)
{
mutex_destroy(lock);
}
diff --git a/rust/helpers/spinlock.c b/rust/helpers/spinlock.c
index 42c4bf01a23e4003ea82c65b16bc8f495ad37750..4d13062cf253e67894aaa9ba968ff381db2c651e 100644
--- a/rust/helpers/spinlock.c
+++ b/rust/helpers/spinlock.c
@@ -2,8 +2,9 @@
#include <linux/spinlock.h>
-void rust_helper___spin_lock_init(spinlock_t *lock, const char *name,
- struct lock_class_key *key)
+__rust_helper void rust_helper___spin_lock_init(spinlock_t *lock,
+ const char *name,
+ struct lock_class_key *key)
{
#ifdef CONFIG_DEBUG_SPINLOCK
# if defined(CONFIG_PREEMPT_RT)
@@ -16,22 +17,22 @@ void rust_helper___spin_lock_init(spinlock_t *lock, const char *name,
#endif /* CONFIG_DEBUG_SPINLOCK */
}
-void rust_helper_spin_lock(spinlock_t *lock)
+__rust_helper void rust_helper_spin_lock(spinlock_t *lock)
{
spin_lock(lock);
}
-void rust_helper_spin_unlock(spinlock_t *lock)
+__rust_helper void rust_helper_spin_unlock(spinlock_t *lock)
{
spin_unlock(lock);
}
-int rust_helper_spin_trylock(spinlock_t *lock)
+__rust_helper int rust_helper_spin_trylock(spinlock_t *lock)
{
return spin_trylock(lock);
}
-void rust_helper_spin_assert_is_held(spinlock_t *lock)
+__rust_helper void rust_helper_spin_assert_is_held(spinlock_t *lock)
{
lockdep_assert_held(lock);
}
diff --git a/rust/helpers/sync.c b/rust/helpers/sync.c
index ff7e68b4881011ce0aa9beb2df14bf0ffd147337..82d6aff73b04f0ab1030bb5170e40ed6ccac41c0 100644
--- a/rust/helpers/sync.c
+++ b/rust/helpers/sync.c
@@ -2,12 +2,12 @@
#include <linux/lockdep.h>
-void rust_helper_lockdep_register_key(struct lock_class_key *k)
+__rust_helper void rust_helper_lockdep_register_key(struct lock_class_key *k)
{
lockdep_register_key(k);
}
-void rust_helper_lockdep_unregister_key(struct lock_class_key *k)
+__rust_helper void rust_helper_lockdep_unregister_key(struct lock_class_key *k)
{
lockdep_unregister_key(k);
}
--
2.52.0.351.gbe84eed79e-goog
next prev parent reply other threads:[~2026-01-05 12:43 UTC|newest]
Thread overview: 54+ messages / expand[flat|nested] mbox.gz Atom feed top
2026-01-05 12:42 [PATCH v2 00/27] Allow inlining C helpers into Rust when using LTO Alice Ryhl
2026-01-05 12:42 ` [PATCH v2 01/27] rust: barrier: add __rust_helper to helpers Alice Ryhl
2026-01-05 12:42 ` [PATCH v2 02/27] rust: blk: " Alice Ryhl
2026-01-07 10:53 ` Andreas Hindborg
2026-01-05 12:42 ` [PATCH v2 03/27] rust: bug: " Alice Ryhl
2026-01-05 12:42 ` [PATCH v2 04/27] rust: clk: " Alice Ryhl
2026-02-07 2:14 ` Stephen Boyd
2026-01-05 12:42 ` [PATCH v2 05/27] rust: completion: " Alice Ryhl
2026-01-05 12:42 ` [PATCH v2 06/27] rust: cpu: " Alice Ryhl
2026-01-05 12:42 ` [PATCH v2 07/27] rust: cred: " Alice Ryhl
2026-01-07 1:25 ` Paul Moore
2026-01-07 1:29 ` Paul Moore
2026-01-07 6:53 ` Alice Ryhl
2026-01-05 12:42 ` [PATCH v2 08/27] rust: err: " Alice Ryhl
2026-01-05 12:42 ` [PATCH v2 09/27] rust: jump_label: " Alice Ryhl
2026-02-10 17:54 ` Miguel Ojeda
2026-02-10 20:26 ` Peter Zijlstra
2026-02-10 23:11 ` Miguel Ojeda
2026-01-05 12:42 ` [PATCH v2 10/27] rust: maple_tree: " Alice Ryhl
2026-01-05 15:09 ` Liam R. Howlett
2026-01-05 12:42 ` [PATCH v2 11/27] rust: mm: " Alice Ryhl
2026-01-05 15:10 ` Liam R. Howlett
2026-01-05 15:22 ` Lorenzo Stoakes
2026-01-05 12:42 ` [PATCH v2 12/27] rust: of: " Alice Ryhl
2026-01-12 16:26 ` Rob Herring
2026-01-05 12:42 ` [PATCH v2 13/27] rust: processor: " Alice Ryhl
2026-01-05 12:42 ` [PATCH v2 14/27] rust: pwm: " Alice Ryhl
2026-01-05 17:09 ` Michal Wilczynski
2026-01-20 18:02 ` Uwe Kleine-König
2026-01-05 12:42 ` [PATCH v2 15/27] rust: rbtree: " Alice Ryhl
2026-01-05 12:42 ` [PATCH v2 16/27] rust: rcu: " Alice Ryhl
2026-01-05 15:26 ` Joel Fernandes
2026-01-05 12:42 ` [PATCH v2 17/27] rust: refcount: " Alice Ryhl
2026-01-05 12:42 ` [PATCH v2 18/27] rust: security: " Alice Ryhl
2026-01-07 1:29 ` Paul Moore
2026-01-05 12:42 ` [PATCH v2 19/27] rust: slab: " Alice Ryhl
2026-01-05 12:56 ` Danilo Krummrich
2026-01-05 13:06 ` Alice Ryhl
2026-01-05 17:04 ` Miguel Ojeda
2026-01-05 12:42 ` Alice Ryhl [this message]
2026-01-05 12:42 ` [PATCH v2 21/27] rust: task: " Alice Ryhl
2026-01-05 12:42 ` [PATCH v2 22/27] rust: time: " Alice Ryhl
2026-01-05 12:42 ` [PATCH v2 23/27] rust: uaccess: " Alice Ryhl
2026-01-05 12:42 ` [PATCH v2 24/27] rust: usb: " Alice Ryhl
2026-01-05 13:40 ` Daniel Almeida
2026-01-05 12:42 ` [PATCH v2 25/27] rust: wait: " Alice Ryhl
2026-01-05 12:42 ` [PATCH v2 26/27] rust: workqueue: " Alice Ryhl
2026-01-12 18:06 ` Tejun Heo
2026-01-05 12:42 ` [PATCH v2 27/27] rust: xarray: " Alice Ryhl
2026-01-05 15:26 ` Tamir Duberstein
2026-01-15 9:02 ` Andreas Hindborg
2026-01-05 15:41 ` [PATCH v2 00/27] Allow inlining C helpers into Rust when using LTO Boqun Feng
2026-01-26 5:08 ` Miguel Ojeda
2026-03-10 10:56 ` Miguel Ojeda
Reply instructions:
You may reply publicly to this message via plain-text email
using any one of the following methods:
* Save the following mbox file, import it into your mail client,
and reply-to-all from there: mbox
Avoid top-posting and favor interleaved quoting:
https://en.wikipedia.org/wiki/Posting_style#Interleaved_style
* Reply using the --to, --cc, and --in-reply-to
switches of git-send-email(1):
git send-email \
--in-reply-to=20260105-define-rust-helper-v2-20-51da5f454a67@google.com \
--to=aliceryhl@google.com \
--cc=boqun.feng@gmail.com \
--cc=gary@garyguo.net \
--cc=levymitchell0@gmail.com \
--cc=linux-kernel@vger.kernel.org \
--cc=longman@redhat.com \
--cc=lossin@kernel.org \
--cc=mingo@redhat.com \
--cc=peterz@infradead.org \
--cc=rust-for-linux@vger.kernel.org \
--cc=will@kernel.org \
/path/to/YOUR_REPLY
https://kernel.org/pub/software/scm/git/docs/git-send-email.html
* If your mail client supports setting the In-Reply-To header
via mailto: links, try the mailto: link
Be sure your reply has a Subject: header at the top and a blank line
before the message body.
This is a public inbox, see mirroring instructions
for how to clone and mirror all data and code used for this inbox