mirror of
https://github.com/cloud-hypervisor/cloud-hypervisor.git
synced 2025-01-19 02:55:20 +00:00
3bd47ffdc1
Both GIC and IOAPIC must implement a new method notifier() in order to provide the caller with an EventFd corresponding to the IRQ it refers to. This is needed in anticipation for supporting INTx with VFIO PCI devices. Signed-off-by: Sebastien Boeuf <sebastien.boeuf@intel.com>
62 lines
1.8 KiB
Rust
62 lines
1.8 KiB
Rust
// Copyright 2020, ARM Limited.
|
|
//
|
|
// SPDX-License-Identifier: Apache-2.0 AND BSD-3-Clause
|
|
|
|
use std::io;
|
|
use std::result;
|
|
use vmm_sys_util::eventfd::EventFd;
|
|
|
|
#[derive(Debug)]
|
|
pub enum Error {
|
|
/// Invalid trigger mode.
|
|
InvalidTriggerMode,
|
|
/// Invalid delivery mode.
|
|
InvalidDeliveryMode,
|
|
/// Failed creating the interrupt source group.
|
|
CreateInterruptSourceGroup(io::Error),
|
|
/// Failed triggering the interrupt.
|
|
TriggerInterrupt(io::Error),
|
|
/// Failed masking the interrupt.
|
|
MaskInterrupt(io::Error),
|
|
/// Failed unmasking the interrupt.
|
|
UnmaskInterrupt(io::Error),
|
|
/// Failed updating the interrupt.
|
|
UpdateInterrupt(io::Error),
|
|
/// Failed enabling the interrupt.
|
|
EnableInterrupt(io::Error),
|
|
}
|
|
|
|
type Result<T> = result::Result<T, Error>;
|
|
|
|
pub struct MsiMessage {
|
|
// Message Address Register
|
|
// 31-20: Base address. Fixed value (0x0FEE)
|
|
// 19-12: Destination ID
|
|
// 11-4: Reserved
|
|
// 3: Redirection Hint indication
|
|
// 2: Destination Mode
|
|
// 1-0: Reserved
|
|
pub addr: u32,
|
|
// Message Data Register
|
|
// 32-16: Reserved
|
|
// 15: Trigger Mode. 0 = Edge, 1 = Level
|
|
// 14: Level. 0 = Deassert, 1 = Assert
|
|
// 13-11: Reserved
|
|
// 10-8: Delivery Mode
|
|
// 7-0: Vector
|
|
pub data: u32,
|
|
}
|
|
|
|
// Introduce trait InterruptController to uniform the interrupt
|
|
// service provided for devices.
|
|
// Device manager uses this trait without caring whether it is a
|
|
// IOAPIC (X86) or GIC (Arm).
|
|
pub trait InterruptController: Send {
|
|
fn service_irq(&mut self, irq: usize) -> Result<()>;
|
|
#[cfg(target_arch = "aarch64")]
|
|
fn enable(&self) -> Result<()>;
|
|
#[cfg(target_arch = "x86_64")]
|
|
fn end_of_interrupt(&mut self, vec: u8);
|
|
fn notifier(&self, irq: usize) -> Option<EventFd>;
|
|
}
|