1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
// Reexports.
pub use ;
pub use ;
;
/// Indicates that the `ICM42688` instance is ready to be used
;
/// Represents all possible errors that can occur in the icm426xx driver.
/// Helper trait to convert bus errors into our top-level Error::Bus variant.
/// ICM42688 top-level driver
///
/// Usage:
///
/// ```rust,ignore
/// # use async_std::prelude::*; // Just for the runtime
/// # use embedded_hal_mock::eh1::spi::{Mock as SpiMock, Transaction as SpiTransaction};
/// # use embedded_hal_mock::eh1::digital::Mock as PinMock;
/// # use embedded_hal_mock::eh1::digital::{State as PinState, Transaction as PinTransaction};
/// # use embedded_hal_mock::eh1::delay::NoopDelay as Delay;
/// # #[async_std::main]
/// async fn main() {
/// let spi = SpiMock::new(&[]);
/// let mut pin = PinMock::new(&[PinTransaction::set(PinState::High)]);
/// let spidev =
/// embedded_hal_bus::spi::ExclusiveDevice::new_no_delay(spi, pin.clone()).unwrap();
/// let mut icm = icm426xx::ICM42688::new(spidev);
/// let mut icm = icm.initialize(Delay).await.unwrap();
/// let mut bank = icm.ll().bank::<{ icm426xx::register_bank::BANK0 }>();
///
/// // print WHO_AM_I register
/// let who_am_i = bank.who_am_i().async_read().await;
/// loop {
/// let fifo_count = icm.read_fifo_count().await;
/// let mut fifo_buffer = [0u32; 128];
/// let num_read = icm.read_fifo(&mut fifo_buffer).await.unwrap();
/// }
/// }
/// ```