[<prev] [next>] [thread-next>] [day] [month] [year] [list]
Message-ID: <20240912005539.175428-1-lyude@redhat.com>
Date: Wed, 11 Sep 2024 20:55:31 -0400
From: Lyude Paul <lyude@...hat.com>
To: 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>,
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>
Subject: [PATCH v4 0/3] rust: Add irq abstraction, SpinLockIrq
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.c | 23 +++++++
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 ++++++++++++++++++++++++++++++
7 files changed, 236 insertions(+), 3 deletions(-)
create mode 100644 rust/kernel/irq.rs
base-commit: 8d8d276ba2fb5f9ac4984f5c10ae60858090babc
--
2.46.0
Powered by blists - more mailing lists