[<prev] [next>] [<thread-prev] [thread-next>] [day] [month] [year] [list]
Message-ID: <aef35907-b92a-4f56-a330-b4be06f11984@gmail.com>
Date: Sat, 12 Oct 2024 07:29:57 +0200
From: Dirk Behme <dirk.behme@...il.com>
To: Lyude Paul <lyude@...hat.com>, rust-for-linux@...r.kernel.org
Cc: Danilo Krummrich <dakr@...hat.com>, airlied@...hat.com,
Ingo Molnar <mingo@...hat.com>, Will Deacon <will@...nel.org>,
Waiman Long <longman@...hat.com>, Peter Zijlstra <peterz@...radead.org>,
Thomas Gleixner <tglx@...utronix.de>, linux-kernel@...r.kernel.org,
Miguel Ojeda <ojeda@...nel.org>, Alex Gaynor <alex.gaynor@...il.com>,
Wedson Almeida Filho <wedsonaf@...il.com>, Boqun Feng
<boqun.feng@...il.com>, Gary Guo <gary@...yguo.net>,
Björn Roy Baron <bjorn3_gh@...tonmail.com>,
Benno Lossin <benno.lossin@...ton.me>,
Andreas Hindborg <a.hindborg@...sung.com>, Alice Ryhl
<aliceryhl@...gle.com>, Trevor Gross <tmgross@...ch.edu>
Subject: Re: [PATCH v6 0/3] rust: Add irq abstraction, SpinLockIrq
Hi Lyude,
On 16.09.24 23:28, Lyude Paul wrote:
> This adds a simple interface for disabling and enabling CPUs, along with
> the ability to mark a function as expecting interrupts be disabled -
> along with adding bindings for spin_lock_irqsave/spin_lock_irqrestore().
>
> Current example usecase (very much WIP driver) in rvkms:
>
> https://gitlab.freedesktop.org/lyudess/linux/-/commits/rvkms-example-08012024
>
> specifically drivers/gpu/drm/rvkms/crtc.rs
>
> This series depends on
> https://lore.kernel.org/rust-for-linux/ZuKNszXSw-LbgW1e@boqun-archlinux/
>
> Lyude Paul (3):
> rust: Introduce irq module
> rust: sync: Introduce lock::Backend::Context
> rust: sync: Add SpinLockIrq
To have it in this thread as well I just want to mention the discussion in
https://lore.kernel.org/rust-for-linux/87a5falmjy.fsf@kernel.org/
which results in the impression that this patch series needs to update
`CondVar::wait` to support waiting with irq disabled.
Best regards
Dirk
> rust/helpers/helpers.c | 1 +
> rust/helpers/irq.c | 22 +++++++
> rust/kernel/irq.rs | 96 +++++++++++++++++++++++++++
> rust/kernel/lib.rs | 1 +
> rust/kernel/sync.rs | 2 +-
> rust/kernel/sync/lock.rs | 17 ++++-
> rust/kernel/sync/lock/mutex.rs | 1 +
> rust/kernel/sync/lock/spinlock.rs | 105 ++++++++++++++++++++++++++++++
> 8 files changed, 242 insertions(+), 3 deletions(-)
> create mode 100644 rust/helpers/irq.c
> create mode 100644 rust/kernel/irq.rs
>
>
> base-commit: a2f11547052001bd448ccec81dd1e68409078fbb
> prerequisite-patch-id: 926565461e47df321ce1bed92894cc1f265896ef
Powered by blists - more mailing lists