Struct devices::irqchip::pic::Pic

source ·
pub struct Pic {
    interrupt_request: bool,
    resample_events: Vec<Vec<Event>>,
    pics: [PicState; 2],
}

Fields§

§interrupt_request: bool§resample_events: Vec<Vec<Event>>§pics: [PicState; 2]

Implementations§

source§

impl Pic

source

pub fn new() -> Pic

source

pub fn get_pic_state(&self, select: PicSelect) -> PicState

Get the current state of the primary or secondary PIC

source

pub fn set_pic_state(&mut self, select: PicSelect, state: &PicState)

Set the current state of the primary or secondary PIC

source

pub fn register_resample_events(&mut self, resample_events: Vec<Vec<Event>>)

source

pub fn service_irq(&mut self, irq: u8, level: bool) -> bool

source

pub fn masked(&self) -> bool

Determines whether the (primary) PIC is completely masked.

source

pub fn has_interrupt(&self) -> bool

Determines whether the PIC has an interrupt ready.

source

pub fn interrupt_requested(&self) -> bool

Determines whether the PIC has fired an interrupt to LAPIC.

source

pub fn get_external_interrupt(&mut self) -> Option<u8>

Determines the external interrupt number that the PIC is prepared to inject, if any.

source

fn pic_read_command(&mut self, pic_type: PicSelect) -> u8

source

fn pic_read_data(&mut self, pic_type: PicSelect) -> u8

source

fn pic_read_elcr(&mut self, pic_type: PicSelect) -> u8

source

fn pic_write_command(&mut self, pic_type: PicSelect, value: u8)

source

fn pic_write_data(&mut self, pic_type: PicSelect, value: u8)

source

fn pic_write_elcr(&mut self, pic_type: PicSelect, value: u8)

source

fn reset_pic(&mut self, pic_type: PicSelect)

source

fn poll_read(&mut self, pic_type: PicSelect) -> (u8, bool)

Determine the priority and whether an update_irq call is needed.

source

fn get_irq(&self, pic_type: PicSelect) -> Option<u8>

source

fn clear_isr(&mut self, pic_type: PicSelect, irq: u8)

source

fn update_irq(&mut self) -> bool

source

fn set_irq_internal(pic: &mut PicState, irq: u8, level: bool)

Set Irq level. If edge is detected, then IRR is set to 1.

source

fn get_priority(pic: &PicState, irq_bitmap: u8) -> Option<u8>

source

fn interrupt_ack(&mut self, pic_type: PicSelect, irq: u8)

Move interrupt from IRR to ISR to indicate that the interrupt is injected. If auto EOI is set, then ISR is immediately cleared (since the purpose of EOI is to clear ISR bit).

source

fn init_command_word_1(&mut self, pic_type: PicSelect, value: u8)

source

fn operation_command_word_2(&mut self, pic_type: PicSelect, value: u8)

source

fn operation_command_word_3(pic: &mut PicState, value: u8)

Trait Implementations§

source§

impl BusDevice for Pic

source§

fn device_id(&self) -> DeviceId

Returns a unique id per device type suitable for metrics gathering.
source§

fn debug_label(&self) -> String

Returns a label suitable for debug output.
source§

fn write(&mut self, info: BusAccessInfo, data: &[u8])

Writes at offset into this device
source§

fn read(&mut self, info: BusAccessInfo, data: &mut [u8])

Reads at offset from this device
source§

fn config_register_write( &mut self, reg_idx: usize, offset: u64, data: &[u8] ) -> ConfigWriteResult

Sets a register in the configuration space. Only used by PCI. Read more
source§

fn config_register_read(&self, reg_idx: usize) -> u32

Gets a register from the configuration space. Only used by PCI. Read more
source§

fn init_pci_config_mapping( &mut self, shmem: &SharedMemory, base: usize, len: usize ) -> bool

Provides a memory region to back MMIO access to the configuration space. If the device can keep the memory region up to date, then it should return true, after which no more calls to config_register_read will be made. Otherwise the device should return false. Read more
source§

fn virtual_config_register_write(&mut self, reg_idx: usize, value: u32)

Sets a register in the virtual config space. Only used by PCI. Read more
source§

fn virtual_config_register_read(&self, reg_idx: usize) -> u32

Gets a register from the virtual config space. Only used by PCI. Read more
source§

fn on_sandboxed(&mut self)

Invoked when the device is sandboxed.
source§

fn get_ranges(&self) -> Vec<(BusRange, BusType)>

Gets a list of all ranges registered by this BusDevice.
source§

fn destroy_device(&mut self)

Invoked when the device is destroyed
source§

fn is_bridge(&self) -> Option<u8>

Returns the secondary bus number if this bus device is pci bridge
source§

impl Default for Pic

source§

fn default() -> Self

Returns the “default value” for a type. Read more
source§

impl Suspendable for Pic

The PIC is only used in very early boot on x86_64, and snapshots are not generally taken during that time, so we can safely skip the PIC for now.

source§

fn sleep(&mut self) -> Result<()>

Stop all threads related to the device. Sleep should be idempotent.
source§

fn wake(&mut self) -> Result<()>

Create/Resume all threads related to the device. Wake should be idempotent.
source§

fn snapshot(&mut self) -> Result<Value>

Save the device state in an image that can be restored.
source§

fn restore(&mut self, _data: Value) -> Result<()>

Load a saved snapshot of an image.

Auto Trait Implementations§

§

impl RefUnwindSafe for Pic

§

impl Send for Pic

§

impl Sync for Pic

§

impl Unpin for Pic

§

impl UnwindSafe for Pic

Blanket Implementations§

source§

impl<T> Any for Twhere T: 'static + ?Sized,

source§

fn type_id(&self) -> TypeId

Gets the TypeId of self. Read more
source§

impl<T> Borrow<T> for Twhere T: ?Sized,

source§

fn borrow(&self) -> &T

Immutably borrows from an owned value. Read more
source§

impl<T> BorrowMut<T> for Twhere T: ?Sized,

source§

fn borrow_mut(&mut self) -> &mut T

Mutably borrows from an owned value. Read more
§

impl<T> Downcast for Twhere T: Any,

§

fn into_any(self: Box<T, Global>) -> Box<dyn Any, Global>

Convert Box<dyn Trait> (where Trait: Downcast) to Box<dyn Any>. Box<dyn Any> can then be further downcast into Box<ConcreteType> where ConcreteType implements Trait.
§

fn into_any_rc(self: Rc<T, Global>) -> Rc<dyn Any, Global>

Convert Rc<Trait> (where Trait: Downcast) to Rc<Any>. Rc<Any> can then be further downcast into Rc<ConcreteType> where ConcreteType implements Trait.
§

fn as_any(&self) -> &(dyn Any + 'static)

Convert &Trait (where Trait: Downcast) to &Any. This is needed since Rust cannot generate &Any’s vtable from &Trait’s.
§

fn as_any_mut(&mut self) -> &mut (dyn Any + 'static)

Convert &mut Trait (where Trait: Downcast) to &Any. This is needed since Rust cannot generate &mut Any’s vtable from &mut Trait’s.
§

impl<T> DowncastSync for Twhere T: Any + Send + Sync,

§

fn into_any_arc(self: Arc<T, Global>) -> Arc<dyn Any + Sync + Send, Global>

Convert Arc<Trait> (where Trait: Downcast) to Arc<Any>. Arc<Any> can then be further downcast into Arc<ConcreteType> where ConcreteType implements Trait.
source§

impl<T> From<T> for T

source§

fn from(t: T) -> T

Returns the argument unchanged.

source§

impl<T, U> Into<U> for Twhere U: From<T>,

source§

fn into(self) -> U

Calls U::from(self).

That is, this conversion is whatever the implementation of From<T> for U chooses to do.

source§

impl<T, U> TryFrom<U> for Twhere U: Into<T>,

§

type Error = Infallible

The type returned in the event of a conversion error.
source§

fn try_from(value: U) -> Result<T, <T as TryFrom<U>>::Error>

Performs the conversion.
source§

impl<T, U> TryInto<U> for Twhere U: TryFrom<T>,

§

type Error = <U as TryFrom<T>>::Error

The type returned in the event of a conversion error.
source§

fn try_into(self) -> Result<U, <U as TryFrom<T>>::Error>

Performs the conversion.
§

impl<V, T> VZip<V> for Twhere V: MultiLane<T>,

§

fn vzip(self) -> V