stm32/eth: impl. poll interval
This commit is contained in:
parent
c3774607a5
commit
975a780efe
6 changed files with 29 additions and 6 deletions
|
@ -1,6 +1,10 @@
|
||||||
//! Generic SMI Ethernet PHY
|
//! Generic SMI Ethernet PHY
|
||||||
|
|
||||||
|
#[cfg(feature = "time")]
|
||||||
|
use embassy_time::{Duration, Timer};
|
||||||
use futures::task::Context;
|
use futures::task::Context;
|
||||||
|
#[cfg(feature = "time")]
|
||||||
|
use futures::FutureExt;
|
||||||
|
|
||||||
use super::{StationManagement, PHY};
|
use super::{StationManagement, PHY};
|
||||||
|
|
||||||
|
@ -38,7 +42,22 @@ mod phy_consts {
|
||||||
use self::phy_consts::*;
|
use self::phy_consts::*;
|
||||||
|
|
||||||
/// Generic SMI Ethernet PHY
|
/// Generic SMI Ethernet PHY
|
||||||
pub struct GenericSMI;
|
pub struct GenericSMI {
|
||||||
|
#[cfg(feature = "time")]
|
||||||
|
poll_interval: Duration,
|
||||||
|
}
|
||||||
|
|
||||||
|
impl GenericSMI {
|
||||||
|
#[cfg(feature = "time")]
|
||||||
|
pub fn new(poll_interval: Duration) -> Self {
|
||||||
|
Self { poll_interval }
|
||||||
|
}
|
||||||
|
|
||||||
|
#[cfg(not(feature = "time"))]
|
||||||
|
pub fn new() -> Self {
|
||||||
|
Self {}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
unsafe impl PHY for GenericSMI {
|
unsafe impl PHY for GenericSMI {
|
||||||
/// Reset PHY and wait for it to come out of reset.
|
/// Reset PHY and wait for it to come out of reset.
|
||||||
|
@ -57,8 +76,12 @@ unsafe impl PHY for GenericSMI {
|
||||||
}
|
}
|
||||||
|
|
||||||
fn poll_link<S: StationManagement>(&mut self, sm: &mut S, cx: &mut Context) -> bool {
|
fn poll_link<S: StationManagement>(&mut self, sm: &mut S, cx: &mut Context) -> bool {
|
||||||
|
#[cfg(not(feature = "time"))]
|
||||||
cx.waker().wake_by_ref();
|
cx.waker().wake_by_ref();
|
||||||
|
|
||||||
|
#[cfg(feature = "time")]
|
||||||
|
let _ = Timer::after(self.poll_interval).poll_unpin(cx);
|
||||||
|
|
||||||
let bsr = sm.smi_read(PHY_REG_BSR);
|
let bsr = sm.smi_read(PHY_REG_BSR);
|
||||||
|
|
||||||
// No link without autonegotiate
|
// No link without autonegotiate
|
||||||
|
|
|
@ -56,7 +56,7 @@ async fn main(spawner: Spawner) -> ! {
|
||||||
p.PG13,
|
p.PG13,
|
||||||
p.PB13,
|
p.PB13,
|
||||||
p.PG11,
|
p.PG11,
|
||||||
GenericSMI,
|
GenericSMI::new(Duration::from_millis(500)),
|
||||||
mac_addr,
|
mac_addr,
|
||||||
0,
|
0,
|
||||||
);
|
);
|
||||||
|
|
|
@ -57,7 +57,7 @@ async fn main(spawner: Spawner) -> ! {
|
||||||
p.PG13,
|
p.PG13,
|
||||||
p.PB13,
|
p.PB13,
|
||||||
p.PG11,
|
p.PG11,
|
||||||
GenericSMI,
|
GenericSMI::new(Duration::from_millis(500)),
|
||||||
mac_addr,
|
mac_addr,
|
||||||
0,
|
0,
|
||||||
);
|
);
|
||||||
|
|
|
@ -76,7 +76,7 @@ async fn main(spawner: Spawner) -> ! {
|
||||||
p.PG13,
|
p.PG13,
|
||||||
p.PB15,
|
p.PB15,
|
||||||
p.PG11,
|
p.PG11,
|
||||||
GenericSMI,
|
GenericSMI::new(Duration::from_millis(500)),
|
||||||
mac_addr,
|
mac_addr,
|
||||||
0,
|
0,
|
||||||
);
|
);
|
||||||
|
|
|
@ -58,7 +58,7 @@ async fn main(spawner: Spawner) -> ! {
|
||||||
p.PG13,
|
p.PG13,
|
||||||
p.PB13,
|
p.PB13,
|
||||||
p.PG11,
|
p.PG11,
|
||||||
GenericSMI,
|
GenericSMI::new(Duration::from_millis(500)),
|
||||||
mac_addr,
|
mac_addr,
|
||||||
0,
|
0,
|
||||||
);
|
);
|
||||||
|
|
|
@ -59,7 +59,7 @@ async fn main(spawner: Spawner) -> ! {
|
||||||
p.PG13,
|
p.PG13,
|
||||||
p.PB13,
|
p.PB13,
|
||||||
p.PG11,
|
p.PG11,
|
||||||
GenericSMI,
|
GenericSMI::new(Duration::from_millis(500)),
|
||||||
mac_addr,
|
mac_addr,
|
||||||
0,
|
0,
|
||||||
);
|
);
|
||||||
|
|
Loading…
Reference in a new issue