xref: /DragonOS/kernel/src/arch/x86_64/msi.rs (revision 0dd8ff43325b494ea777dbe6e552fdc77b9dabc8)
1cc36cf4aSYJwu2023 use crate::driver::pci::pci_irq::TriggerMode;
2cc36cf4aSYJwu2023 /// @brief 获得MSI Message Address
3cc36cf4aSYJwu2023 /// @param processor 目标CPU ID号
4cc36cf4aSYJwu2023 /// @return MSI Message Address
5cc36cf4aSYJwu2023 pub fn ia64_pci_get_arch_msi_message_address(processor: u16) -> u32 {
6*0dd8ff43SYJwu2023     0xfee00000 | ((processor as u32) << 12)
7cc36cf4aSYJwu2023 }
8cc36cf4aSYJwu2023 /// @brief 获得MSI Message Data
9cc36cf4aSYJwu2023 /// @param vector 分配的中断向量号
10cc36cf4aSYJwu2023 /// @param processor 目标CPU ID号
11cc36cf4aSYJwu2023 /// @param trigger  申请中断的触发模式,MSI默认为边沿触发
12cc36cf4aSYJwu2023 /// @return MSI Message Address
13cc36cf4aSYJwu2023 pub fn ia64_pci_get_arch_msi_message_data(
14cc36cf4aSYJwu2023     vector: u16,
1540fe15e0SLoGin     _processor: u16,
16cc36cf4aSYJwu2023     trigger: TriggerMode,
17cc36cf4aSYJwu2023 ) -> u32 {
18cc36cf4aSYJwu2023     match trigger {
19cc36cf4aSYJwu2023         TriggerMode::EdgeTrigger => vector as u32,
20cc36cf4aSYJwu2023         TriggerMode::AssertHigh => vector as u32 | 1 << 15 | 1 << 14,
21cc36cf4aSYJwu2023         TriggerMode::AssertLow => vector as u32 | 1 << 15,
22cc36cf4aSYJwu2023     }
23cc36cf4aSYJwu2023 }
24