summaryrefslogtreecommitdiff
path: root/rust/kernel/irq/flags.rs
diff options
context:
space:
mode:
authorDaniel Almeida <daniel.almeida@collabora.com>2025-08-11 13:03:41 -0300
committerDanilo Krummrich <dakr@kernel.org>2025-08-12 20:22:00 +0200
commit0851d34a8cc3a0a43acd79a5c4980d45c6471aab (patch)
tree0876ebc129a1a0c0dbcb37f845fcae0346da6da1 /rust/kernel/irq/flags.rs
parent746680ec6696585e30db3e18c93a63df9cbec39c (diff)
rust: irq: add support for non-threaded IRQs and handlers
This patch adds support for non-threaded IRQs and handlers through irq::Registration and the irq::Handler trait. Registering an irq is dependent upon having a IrqRequest that was previously allocated by a given device. This will be introduced in subsequent patches. Tested-by: Joel Fernandes <joelagnelf@nvidia.com> Tested-by: Dirk Behme <dirk.behme@de.bosch.com> Reviewed-by: Alice Ryhl <aliceryhl@google.com> Signed-off-by: Daniel Almeida <daniel.almeida@collabora.com> Link: https://lore.kernel.org/r/20250811-topics-tyr-request_irq2-v9-3-0485dcd9bcbf@collabora.com [ Remove expect(dead_code) from Flags::into_inner(), add expect(dead_code) to IrqRequest::new(), fix intra-doc links. - Danilo ] Signed-off-by: Danilo Krummrich <dakr@kernel.org>
Diffstat (limited to 'rust/kernel/irq/flags.rs')
-rw-r--r--rust/kernel/irq/flags.rs3
1 files changed, 1 insertions, 2 deletions
diff --git a/rust/kernel/irq/flags.rs b/rust/kernel/irq/flags.rs
index d769d68e8edc..adfde96ec47c 100644
--- a/rust/kernel/irq/flags.rs
+++ b/rust/kernel/irq/flags.rs
@@ -21,7 +21,7 @@ use crate::prelude::*;
/// If an invalid combination of flags is provided, the system will refuse to
/// register the handler, and lower layers will enforce certain flags when
/// necessary. This means, for example, that all the
-/// `crate::irq::Registration` for a shared interrupt have to agree on
+/// [`crate::irq::Registration`] for a shared interrupt have to agree on
/// [`Flags::SHARED`] and on the same trigger type, if set.
#[derive(Clone, Copy, PartialEq, Eq)]
pub struct Flags(c_ulong);
@@ -92,7 +92,6 @@ impl Flags {
/// `PERCPU`.
pub const NO_DEBUG: Flags = Flags::new(bindings::IRQF_NO_DEBUG);
- #[expect(dead_code)]
pub(crate) fn into_inner(self) -> c_ulong {
self.0
}