Merge #874
874: Add inline attribute to embassy-rp async functions r=Dirbaio a=danbev This commit adds the inline attribute to the recently added async gpio functions. This is to enable cross-crate inlining and to be consistent with the other functions implemented for Input and Flex. Co-authored-by: Daniel Bevenius <daniel.bevenius@gmail.com>
This commit is contained in:
commit
4c0b79eaac
@ -84,22 +84,27 @@ impl<'d, T: Pin> Input<'d, T> {
|
||||
self.pin.get_level()
|
||||
}
|
||||
|
||||
#[inline]
|
||||
pub async fn wait_for_high<'a>(&mut self) {
|
||||
self.pin.wait_for_high().await;
|
||||
}
|
||||
|
||||
#[inline]
|
||||
pub async fn wait_for_low<'a>(&mut self) {
|
||||
self.pin.wait_for_low().await;
|
||||
}
|
||||
|
||||
#[inline]
|
||||
pub async fn wait_for_rising_edge<'a>(&mut self) {
|
||||
self.pin.wait_for_rising_edge().await;
|
||||
}
|
||||
|
||||
#[inline]
|
||||
pub async fn wait_for_falling_edge<'a>(&mut self) {
|
||||
self.pin.wait_for_falling_edge().await;
|
||||
}
|
||||
|
||||
#[inline]
|
||||
pub async fn wait_for_any_edge<'a>(&mut self) {
|
||||
self.pin.wait_for_any_edge().await;
|
||||
}
|
||||
@ -547,24 +552,29 @@ impl<'d, T: Pin> Flex<'d, T> {
|
||||
unsafe { self.pin.sio_out().value_xor().write_value(self.bit()) }
|
||||
}
|
||||
|
||||
#[inline]
|
||||
pub async fn wait_for_high<'a>(&mut self) {
|
||||
InputFuture::new(&mut self.pin, InterruptTrigger::LevelHigh).await;
|
||||
}
|
||||
|
||||
#[inline]
|
||||
pub async fn wait_for_low<'a>(&mut self) {
|
||||
InputFuture::new(&mut self.pin, InterruptTrigger::LevelLow).await;
|
||||
}
|
||||
|
||||
#[inline]
|
||||
pub async fn wait_for_rising_edge<'a>(&mut self) {
|
||||
self.wait_for_low().await;
|
||||
self.wait_for_high().await;
|
||||
}
|
||||
|
||||
#[inline]
|
||||
pub async fn wait_for_falling_edge<'a>(&mut self) {
|
||||
self.wait_for_high().await;
|
||||
self.wait_for_low().await;
|
||||
}
|
||||
|
||||
#[inline]
|
||||
pub async fn wait_for_any_edge<'a>(&mut self) {
|
||||
if self.is_high() {
|
||||
self.wait_for_low().await;
|
||||
|
Loading…
Reference in New Issue
Block a user