allow calls to start_io when already running and to stop_io when not running, only log a message in these cases

This commit is contained in:
B. Petersen
2020-05-26 14:08:47 +02:00
parent 4330da232c
commit 3db6d5a458
2 changed files with 13 additions and 3 deletions

View File

@@ -138,7 +138,10 @@ impl Context {
/// Starts the IO scheduler.
pub async fn start_io(&self) {
info!(self, "starting IO");
assert!(!self.is_io_running().await, "context is already running");
if self.is_io_running().await {
info!(self, "IO is already running");
return;
}
let l = &mut *self.inner.scheduler.write().await;
l.start(self.clone()).await;
@@ -152,6 +155,11 @@ impl Context {
/// Stops the IO scheduler.
pub async fn stop_io(&self) {
info!(self, "stopping IO");
if !self.is_io_running().await {
info!(self, "IO is not running");
return;
}
self.inner.stop_io().await;
}