use crate::bindings;
use crate::prelude::*;
#[derive(Clone, Copy, PartialEq, Eq)]
pub struct Flags(c_ulong);
impl Flags {
pub const TRIGGER_NONE: Flags = Flags::new(bindings::IRQF_TRIGGER_NONE);
pub const TRIGGER_RISING: Flags = Flags::new(bindings::IRQF_TRIGGER_RISING);
pub const TRIGGER_FALLING: Flags = Flags::new(bindings::IRQF_TRIGGER_FALLING);
pub const TRIGGER_HIGH: Flags = Flags::new(bindings::IRQF_TRIGGER_HIGH);
pub const TRIGGER_LOW: Flags = Flags::new(bindings::IRQF_TRIGGER_LOW);
pub const SHARED: Flags = Flags::new(bindings::IRQF_SHARED);
pub const PROBE_SHARED: Flags = Flags::new(bindings::IRQF_PROBE_SHARED);
pub const TIMER: Flags = Flags::new(bindings::IRQF_TIMER);
pub const PERCPU: Flags = Flags::new(bindings::IRQF_PERCPU);
pub const NOBALANCING: Flags = Flags::new(bindings::IRQF_NOBALANCING);
pub const IRQPOLL: Flags = Flags::new(bindings::IRQF_IRQPOLL);
pub const ONESHOT: Flags = Flags::new(bindings::IRQF_ONESHOT);
pub const NO_SUSPEND: Flags = Flags::new(bindings::IRQF_NO_SUSPEND);
pub const FORCE_RESUME: Flags = Flags::new(bindings::IRQF_FORCE_RESUME);
pub const NO_THREAD: Flags = Flags::new(bindings::IRQF_NO_THREAD);
pub const EARLY_RESUME: Flags = Flags::new(bindings::IRQF_EARLY_RESUME);
pub const COND_SUSPEND: Flags = Flags::new(bindings::IRQF_COND_SUSPEND);
pub const NO_AUTOEN: Flags = Flags::new(bindings::IRQF_NO_AUTOEN);
pub const NO_DEBUG: Flags = Flags::new(bindings::IRQF_NO_DEBUG);
pub(crate) fn into_inner(self) -> c_ulong {
self.0
}
#[inline(always)]
const fn new(value: u32) -> Self {
build_assert!(value as u64 <= c_ulong::MAX as u64);
Self(value as c_ulong)
}
}
impl core::ops::BitOr for Flags {
type Output = Self;
fn bitor(self, rhs: Self) -> Self::Output {
Self(self.0 | rhs.0)
}
}
impl core::ops::BitAnd for Flags {
type Output = Self;
fn bitand(self, rhs: Self) -> Self::Output {
Self(self.0 & rhs.0)
}
}
impl core::ops::Not for Flags {
type Output = Self;
fn not(self) -> Self::Output {
Self(!self.0)
}
}