spi.rs 736 B

1234567891011121314151617181920212223
  1. //! Chapter 7. IPI Extension (EID #0x735049 "sPI: s-mode IPI")
  2. use crate::binary::{sbi_call_2, SbiRet};
  3. use sbi_spec::{
  4. binary::HartMask,
  5. spi::{EID_SPI, SEND_IPI},
  6. };
  7. /// Send an inter-processor interrupt to all harts defined in hart mask.
  8. ///
  9. /// Inter-processor interrupts manifest at the receiving harts as the supervisor software interrupts.
  10. ///
  11. /// # Return value
  12. ///
  13. /// Should return `SbiRet::success()` if IPI was sent to all the targeted harts successfully.
  14. ///
  15. /// This function is defined in RISC-V SBI Specification chapter 7.1.
  16. #[inline]
  17. pub fn send_ipi(hart_mask: HartMask) -> SbiRet {
  18. let (hart_mask, hart_mask_base) = hart_mask.into_inner();
  19. sbi_call_2(EID_SPI, SEND_IPI, hart_mask, hart_mask_base)
  20. }