pub type L3gd20ComponentType<S> = L3gd20Spi<'static, S>;
Aliased Type§
struct L3gd20ComponentType<S> { /* private fields */ }
Implementations
Source§impl<'a, S> L3gd20Spi<'a, S>where
S: SpiMasterDevice<'a>,
impl<'a, S> L3gd20Spi<'a, S>where
S: SpiMasterDevice<'a>,
pub fn new( spi: &'a S, txbuffer: &'static mut [u8; 10], rxbuffer: &'static mut [u8; 10], grants: Grant<App, UpcallCount<1>, AllowRoCount<0>, AllowRwCount<0>>, ) -> L3gd20Spi<'a, S>
pub fn is_present(&self) -> bool
pub fn power_on(&self)
pub fn configure(&self) -> Result<(), ErrorCode>
Trait Implementations
Source§impl<'a, S> NineDof<'a> for L3gd20Spi<'a, S>where
S: SpiMasterDevice<'a>,
impl<'a, S> NineDof<'a> for L3gd20Spi<'a, S>where
S: SpiMasterDevice<'a>,
Source§fn set_client(&self, nine_dof_client: &'a dyn NineDofClient)
fn set_client(&self, nine_dof_client: &'a dyn NineDofClient)
Set the client to be notified when the capsule has data ready or
has finished some command. This is likely called in a board’s main.rs
and is set to the virtual_ninedof.rs driver.
Source§fn read_gyroscope(&self) -> Result<(), ErrorCode>
fn read_gyroscope(&self) -> Result<(), ErrorCode>
Get a single instantaneous reading from the gyroscope of the rotation
around all three axes.
Source§impl<'a, S> SpiMasterClient for L3gd20Spi<'a, S>where
S: SpiMasterDevice<'a>,
impl<'a, S> SpiMasterClient for L3gd20Spi<'a, S>where
S: SpiMasterDevice<'a>,
Source§fn read_write_done(
&self,
write_buffer: SubSliceMut<'static, u8>,
read_buffer: Option<SubSliceMut<'static, u8>>,
status: Result<usize, ErrorCode>,
)
fn read_write_done( &self, write_buffer: SubSliceMut<'static, u8>, read_buffer: Option<SubSliceMut<'static, u8>>, status: Result<usize, ErrorCode>, )
Callback issued when a read/write operation finishes. Read more
Source§impl<'a, S> SyscallDriver for L3gd20Spi<'a, S>where
S: SpiMasterDevice<'a>,
impl<'a, S> SyscallDriver for L3gd20Spi<'a, S>where
S: SpiMasterDevice<'a>,
Source§fn command(
&self,
command_num: usize,
data1: usize,
data2: usize,
process_id: ProcessId,
) -> CommandReturn
fn command( &self, command_num: usize, data1: usize, data2: usize, process_id: ProcessId, ) -> CommandReturn
System call for a process to perform a short synchronous operation or
start a long-running split-phase operation (whose completion is signaled
with an upcall). Command 0 is a reserved command to detect if a
peripheral system call driver is installed and must always return a
CommandReturn::success
.Source§fn allocate_grant(&self, processid: ProcessId) -> Result<(), Error>
fn allocate_grant(&self, processid: ProcessId) -> Result<(), Error>
Request to allocate a capsule’s grant for a specific process. Read more
Source§fn allow_userspace_readable(
&self,
app: ProcessId,
which: usize,
slice: ReadWriteProcessBuffer,
) -> Result<ReadWriteProcessBuffer, (ReadWriteProcessBuffer, ErrorCode)>
fn allow_userspace_readable( &self, app: ProcessId, which: usize, slice: ReadWriteProcessBuffer, ) -> Result<ReadWriteProcessBuffer, (ReadWriteProcessBuffer, ErrorCode)>
System call for a process to pass a buffer (a
UserspaceReadableProcessBuffer
) to the kernel that the kernel can
either read or write. The kernel calls this method only after it checks
that the entire buffer is within memory the process can both read and
write. Read more