mirror of
https://gitlab.freedesktop.org/gstreamer/gst-plugins-rs.git
synced 2025-01-25 02:18:12 +00:00
uriplaylistbin: add Status::ShuttingDown
Fix a race where we were trying to process new decodedin pads while the element was being shutdown, resulting in a dead lock.
This commit is contained in:
parent
e3e4a109f9
commit
c86d5c78f4
1 changed files with 5 additions and 1 deletions
|
@ -106,6 +106,8 @@ enum Status {
|
||||||
Running,
|
Running,
|
||||||
/// the element stopped because of an error
|
/// the element stopped because of an error
|
||||||
Error,
|
Error,
|
||||||
|
/// the element is being shut down
|
||||||
|
ShuttingDown,
|
||||||
}
|
}
|
||||||
|
|
||||||
impl Status {
|
impl Status {
|
||||||
|
@ -113,7 +115,7 @@ impl Status {
|
||||||
fn done(&self) -> bool {
|
fn done(&self) -> bool {
|
||||||
match self {
|
match self {
|
||||||
Status::Running => false,
|
Status::Running => false,
|
||||||
Status::Error => true,
|
Status::Error | Status::ShuttingDown => true,
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
@ -951,6 +953,8 @@ impl ElementImpl for UriPlaylistBin {
|
||||||
let mut state_guard = self.state.lock().unwrap();
|
let mut state_guard = self.state.lock().unwrap();
|
||||||
let state = state_guard.as_mut().unwrap();
|
let state = state_guard.as_mut().unwrap();
|
||||||
|
|
||||||
|
state.status = Status::ShuttingDown;
|
||||||
|
|
||||||
// The probe callback owns a ref on the item and so on the sender as well.
|
// The probe callback owns a ref on the item and so on the sender as well.
|
||||||
// As a result we have to explicitly unblock all receivers as dropping the sender
|
// As a result we have to explicitly unblock all receivers as dropping the sender
|
||||||
// is not enough.
|
// is not enough.
|
||||||
|
|
Loading…
Reference in a new issue