mirror of
https://github.com/italicsjenga/rp-hal-boards.git
synced 2025-01-23 01:36:35 +11:00
Merge pull request #406 from ithinuel/add-suspend-and-remote-wakeup-support
Add suspend, resume and remote wakeup support.
This commit is contained in:
commit
b1fcb7eff8
1 changed files with 30 additions and 4 deletions
|
@ -402,6 +402,14 @@ impl UsbBus {
|
||||||
inner: Mutex::new(RefCell::new(Inner::new(ctrl_reg, ctrl_dpram))),
|
inner: Mutex::new(RefCell::new(Inner::new(ctrl_reg, ctrl_dpram))),
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
/// Generates a resume request on the bus.
|
||||||
|
pub fn remote_wakeup(&self) {
|
||||||
|
interrupt::free(|cs| {
|
||||||
|
let inner = self.inner.borrow(cs).borrow_mut();
|
||||||
|
inner.ctrl_reg.sie_ctrl.modify(|_, w| w.resume().set_bit());
|
||||||
|
});
|
||||||
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
impl UsbBusTrait for UsbBus {
|
impl UsbBusTrait for UsbBus {
|
||||||
|
@ -434,6 +442,10 @@ impl UsbBusTrait for UsbBus {
|
||||||
.set_bit()
|
.set_bit()
|
||||||
.bus_reset()
|
.bus_reset()
|
||||||
.set_bit()
|
.set_bit()
|
||||||
|
.dev_resume_from_host()
|
||||||
|
.set_bit()
|
||||||
|
.dev_suspend()
|
||||||
|
.set_bit()
|
||||||
.setup_req()
|
.setup_req()
|
||||||
.set_bit()
|
.set_bit()
|
||||||
});
|
});
|
||||||
|
@ -518,21 +530,35 @@ impl UsbBusTrait for UsbBus {
|
||||||
})
|
})
|
||||||
}
|
}
|
||||||
fn suspend(&self) {
|
fn suspend(&self) {
|
||||||
todo!()
|
interrupt::free(|cs| {
|
||||||
|
let inner = self.inner.borrow(cs).borrow_mut();
|
||||||
|
inner
|
||||||
|
.ctrl_reg
|
||||||
|
.sie_status
|
||||||
|
.modify(|_, w| w.suspended().set_bit());
|
||||||
|
});
|
||||||
}
|
}
|
||||||
fn resume(&self) {
|
fn resume(&self) {
|
||||||
todo!()
|
interrupt::free(|cs| {
|
||||||
|
let inner = self.inner.borrow(cs).borrow_mut();
|
||||||
|
inner
|
||||||
|
.ctrl_reg
|
||||||
|
.sie_status
|
||||||
|
.modify(|_, w| w.resume().set_bit());
|
||||||
|
});
|
||||||
}
|
}
|
||||||
fn poll(&self) -> PollResult {
|
fn poll(&self) -> PollResult {
|
||||||
interrupt::free(|cs| {
|
interrupt::free(|cs| {
|
||||||
let mut inner = self.inner.borrow(cs).borrow_mut();
|
let mut inner = self.inner.borrow(cs).borrow_mut();
|
||||||
// TODO: check for suspend request
|
|
||||||
// TODO: check for resume request
|
|
||||||
|
|
||||||
// check for bus reset
|
// check for bus reset
|
||||||
let sie_status = inner.ctrl_reg.sie_status.read();
|
let sie_status = inner.ctrl_reg.sie_status.read();
|
||||||
if sie_status.bus_reset().bit_is_set() {
|
if sie_status.bus_reset().bit_is_set() {
|
||||||
return PollResult::Reset;
|
return PollResult::Reset;
|
||||||
|
} else if sie_status.suspended().bit_is_set() {
|
||||||
|
return PollResult::Suspend;
|
||||||
|
} else if sie_status.resume().bit_is_set() {
|
||||||
|
return PollResult::Resume;
|
||||||
}
|
}
|
||||||
|
|
||||||
let (mut ep_out, mut ep_in_complete, mut ep_setup): (u16, u16, u16) = (0, 0, 0);
|
let (mut ep_out, mut ep_in_complete, mut ep_setup): (u16, u16, u16) = (0, 0, 0);
|
||||||
|
|
Loading…
Add table
Reference in a new issue