mirror of
https://github.com/italicsjenga/agb.git
synced 2025-01-26 00:56:38 +11:00
add docs
This commit is contained in:
parent
f312ff7df8
commit
aa0337941a
2 changed files with 17 additions and 1 deletions
|
@ -227,6 +227,18 @@ fn interrupt_to_root(interrupt: Interrupt) -> &'static InterruptRoot {
|
|||
}
|
||||
|
||||
#[must_use]
|
||||
/// Adds an interrupt handler as long as the returned value is alive. The
|
||||
/// closure takes a [`CriticalSection`] which can be used for mutexes.
|
||||
///
|
||||
/// [`CriticalSection`]: bare_metal::CriticalSection
|
||||
///
|
||||
/// # Examples
|
||||
///
|
||||
/// ```
|
||||
/// let _a = add_interrupt_handler(Interrupt::VBlank, |_: &CriticalSection| {
|
||||
/// println!("Woah there! There's been a vblank!");
|
||||
/// });
|
||||
/// ```
|
||||
pub fn add_interrupt_handler<'a>(
|
||||
interrupt: Interrupt,
|
||||
handler: impl Fn(&CriticalSection) + 'a,
|
||||
|
@ -264,6 +276,10 @@ pub fn add_interrupt_handler<'a>(
|
|||
do_with_inner(interrupt, inner)
|
||||
}
|
||||
|
||||
/// How you can access mutexes outside of interrupts by being given a
|
||||
/// [`CriticalSection`]
|
||||
///
|
||||
/// [`CriticalSection`]: bare_metal::CriticalSection
|
||||
pub fn free<F, R>(f: F) -> R
|
||||
where
|
||||
F: FnOnce(&CriticalSection) -> R,
|
||||
|
|
|
@ -145,7 +145,7 @@ pub mod display;
|
|||
mod dma;
|
||||
/// Button inputs to the system.
|
||||
pub mod input;
|
||||
#[doc(hidden)] // hide for now as the implementation in here is unsound
|
||||
/// Interacting with the GBA interrupts
|
||||
pub mod interrupt;
|
||||
mod memory_mapped;
|
||||
/// Implements logging to the mgba emulator.
|
||||
|
|
Loading…
Add table
Reference in a new issue