[<prev] [next>] [<thread-prev] [day] [month] [year] [list]
Message-ID: <20240914171836.6afbbe78.gary@garyguo.net>
Date: Sat, 14 Sep 2024 17:18:36 +0100
From: Gary Guo <gary@...yguo.net>
To: Lyude Paul <lyude@...hat.com>
Cc: rust-for-linux@...r.kernel.org, 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>, 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 v5 0/3] rust: Add irq abstraction, SpinLockIrq
On Thu, 12 Sep 2024 15:04:15 -0400
Lyude Paul <lyude@...hat.com> 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
>
> Lyude Paul (3):
> rust: Introduce irq module
> rust: sync: Introduce lock::Backend::Context
> rust: sync: Add SpinLockIrq
>
> rust/helpers/helpers.c | 1 +
> rust/helpers/irq.c | 22 +++++++
> rust/kernel/irq.rs | 90 +++++++++++++++++++++++++
> 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, 236 insertions(+), 3 deletions(-)
> create mode 100644 rust/helpers/irq.c
> create mode 100644 rust/kernel/irq.rs
>
>
> base-commit: 93dc3be19450447a3a7090bd1dfb9f3daac3e8d2
With the invariant documentation of `IrqDisabled` fixed:
Reviewed-by: Gary Guo <gary@...yguo.net>
Powered by blists - more mailing lists