mirror of
https://github.com/italicsjenga/rp-hal-boards.git
synced 2025-01-11 21:11:31 +11:00
pio: Fix clippy warnings and examples in doc comments.
This commit is contained in:
parent
d1bbceaab4
commit
4db944ad4e
|
@ -11,6 +11,7 @@ pub trait PIOExt:
|
||||||
core::ops::Deref<Target = rp2040_pac::pio0::RegisterBlock> + SubsystemReset + Sized
|
core::ops::Deref<Target = rp2040_pac::pio0::RegisterBlock> + SubsystemReset + Sized
|
||||||
{
|
{
|
||||||
/// Create a new PIO wrapper and split the state machines into individual objects.
|
/// Create a new PIO wrapper and split the state machines into individual objects.
|
||||||
|
#[allow(clippy::type_complexity)] // Required for symmetry with PIO::free().
|
||||||
fn split(
|
fn split(
|
||||||
self,
|
self,
|
||||||
resets: &mut pac::RESETS,
|
resets: &mut pac::RESETS,
|
||||||
|
@ -188,8 +189,7 @@ impl<P: PIOExt> PIO<P> {
|
||||||
{
|
{
|
||||||
self.pio.instr_mem[i + offset].write(|w| unsafe { w.bits(instr as u32) })
|
self.pio.instr_mem[i + offset].write(|w| unsafe { w.bits(instr as u32) })
|
||||||
}
|
}
|
||||||
self.used_instruction_space =
|
self.used_instruction_space |= ((1 << p.code.len()) - 1) << offset;
|
||||||
self.used_instruction_space | (((1 << p.code.len()) - 1) << offset);
|
|
||||||
Ok(InstalledProgram {
|
Ok(InstalledProgram {
|
||||||
offset: offset as u8,
|
offset: offset as u8,
|
||||||
length: p.code.len() as u8,
|
length: p.code.len() as u8,
|
||||||
|
@ -205,7 +205,7 @@ impl<P: PIOExt> PIO<P> {
|
||||||
/// Removes the specified program from instruction memory, freeing the allocated space.
|
/// Removes the specified program from instruction memory, freeing the allocated space.
|
||||||
pub fn uninstall(&mut self, p: InstalledProgram<P>) {
|
pub fn uninstall(&mut self, p: InstalledProgram<P>) {
|
||||||
let instr_mask = ((1 << p.length as u32) - 1) << p.offset as u32;
|
let instr_mask = ((1 << p.length as u32) - 1) << p.offset as u32;
|
||||||
self.used_instruction_space = self.used_instruction_space & !instr_mask;
|
self.used_instruction_space &= !instr_mask;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -220,12 +220,22 @@ impl<P: PIOExt> PIO<P> {
|
||||||
///
|
///
|
||||||
/// # Examples
|
/// # Examples
|
||||||
///
|
///
|
||||||
/// ```
|
/// ```no_run
|
||||||
/// let (mut pio, sm0, _, _, _) = pac.PIO0.split(&mut pac.RESETS);
|
/// use rp2040_hal::{pac, pio::PIOBuilder, pio::PIOExt};
|
||||||
|
/// let mut peripherals = pac::Peripherals::take().unwrap();
|
||||||
|
/// let (mut pio, sm0, _, _, _) = peripherals.PIO0.split(&mut peripherals.RESETS);
|
||||||
/// // Install a program in instruction memory.
|
/// // Install a program in instruction memory.
|
||||||
|
/// let program = pio_proc::pio!(
|
||||||
|
/// 32,
|
||||||
|
/// ".wrap_target
|
||||||
|
/// set pins, 1 [31]
|
||||||
|
/// set pins, 0 [31]
|
||||||
|
/// .wrap
|
||||||
|
/// "
|
||||||
|
/// ).program;
|
||||||
/// let installed = pio.install(&program).unwrap();
|
/// let installed = pio.install(&program).unwrap();
|
||||||
/// // Configure a state machine to use the program.
|
/// // Configure a state machine to use the program.
|
||||||
/// let (sm, rx, tx) = rp2040_hal::pio::PIOBuilder::from_program(installed).build(sm0);
|
/// let (sm, rx, tx) = PIOBuilder::from_program(installed).build(sm0);
|
||||||
/// // Uninitialize the state machine again, freeing the program.
|
/// // Uninitialize the state machine again, freeing the program.
|
||||||
/// let (sm, installed) = sm.uninit(rx, tx);
|
/// let (sm, installed) = sm.uninit(rx, tx);
|
||||||
/// // Uninstall the program to free instruction memory.
|
/// // Uninstall the program to free instruction memory.
|
||||||
|
@ -239,7 +249,7 @@ impl<P: PIOExt> PIO<P> {
|
||||||
/// the program anymore. The user must therefore make sure that `uninstall()` is only called on the
|
/// the program anymore. The user must therefore make sure that `uninstall()` is only called on the
|
||||||
/// PIO object which was used to install the program.
|
/// PIO object which was used to install the program.
|
||||||
///
|
///
|
||||||
/// ```
|
/// ```ignore
|
||||||
/// let (mut pio, sm0, sm1, sm2, sm3) = pac.PIO0.split(&mut pac.RESETS);
|
/// let (mut pio, sm0, sm1, sm2, sm3) = pac.PIO0.split(&mut pac.RESETS);
|
||||||
/// // Install a program in instruction memory.
|
/// // Install a program in instruction memory.
|
||||||
/// let installed = pio.install(&program).unwrap();
|
/// let installed = pio.install(&program).unwrap();
|
||||||
|
@ -530,7 +540,7 @@ impl<SM: ValidStateMachine> StateMachine<SM, Stopped> {
|
||||||
});
|
});
|
||||||
}
|
}
|
||||||
pin += 1;
|
pin += 1;
|
||||||
pins = pins >> 1;
|
pins >>= 1;
|
||||||
}
|
}
|
||||||
// We modified PINCTRL, yet the program assumes a certain configuration, so restore the
|
// We modified PINCTRL, yet the program assumes a certain configuration, so restore the
|
||||||
// previous value.
|
// previous value.
|
||||||
|
@ -554,7 +564,7 @@ impl<P: PIOExt, SM: StateMachineIndex> StateMachine<(P, SM), Stopped> {
|
||||||
///
|
///
|
||||||
/// # Example
|
/// # Example
|
||||||
///
|
///
|
||||||
/// ```
|
/// ```ignore
|
||||||
/// sm0.synchronize_with(sm1).and_with(sm2);
|
/// sm0.synchronize_with(sm1).and_with(sm2);
|
||||||
/// ```
|
/// ```
|
||||||
pub fn synchronize_with<'sm, SM2: StateMachineIndex>(
|
pub fn synchronize_with<'sm, SM2: StateMachineIndex>(
|
||||||
|
@ -1151,6 +1161,7 @@ impl<P: PIOExt> PIOBuilder<P> {
|
||||||
}
|
}
|
||||||
|
|
||||||
/// Build the config and deploy it to a StateMachine.
|
/// Build the config and deploy it to a StateMachine.
|
||||||
|
#[allow(clippy::type_complexity)] // The return type cannot really be simplified.
|
||||||
pub fn build<SM: StateMachineIndex>(
|
pub fn build<SM: StateMachineIndex>(
|
||||||
self,
|
self,
|
||||||
mut sm: UninitStateMachine<(P, SM)>,
|
mut sm: UninitStateMachine<(P, SM)>,
|
||||||
|
@ -1268,7 +1279,7 @@ impl<P: PIOExt> PIOBuilder<P> {
|
||||||
};
|
};
|
||||||
(
|
(
|
||||||
StateMachine {
|
StateMachine {
|
||||||
sm: sm,
|
sm,
|
||||||
program: self.program,
|
program: self.program,
|
||||||
_phantom: core::marker::PhantomData,
|
_phantom: core::marker::PhantomData,
|
||||||
},
|
},
|
||||||
|
|
Loading…
Reference in a new issue