mirror of
https://gitlab.freedesktop.org/gstreamer/gst-plugins-rs.git
synced 2025-01-25 10:28:09 +00:00
tttocea608: protect State with a simple mutex
There was no reason to use AtomicRefcell in this context, aside from the dubious pleasure of panicing when attempting to borrow mutably while another mutable borrow was already held. Part-of: <https://gitlab.freedesktop.org/gstreamer/gst-plugins-rs/-/merge_requests/314>
This commit is contained in:
parent
de796c95f0
commit
fbb2022b25
1 changed files with 12 additions and 12 deletions
|
@ -24,7 +24,7 @@ use gst::prelude::*;
|
||||||
use gst::subclass::prelude::*;
|
use gst::subclass::prelude::*;
|
||||||
|
|
||||||
use super::cea608tott_ffi as ffi;
|
use super::cea608tott_ffi as ffi;
|
||||||
use atomic_refcell::AtomicRefCell;
|
use std::sync::Mutex;
|
||||||
|
|
||||||
fn scale_round(val: u64, num: u64, denom: u64) -> u64 {
|
fn scale_round(val: u64, num: u64, denom: u64) -> u64 {
|
||||||
unsafe { gst_sys::gst_util_uint64_scale_round(val, num, denom) }
|
unsafe { gst_sys::gst_util_uint64_scale_round(val, num, denom) }
|
||||||
|
@ -183,7 +183,7 @@ struct TtToCea608 {
|
||||||
srcpad: gst::Pad,
|
srcpad: gst::Pad,
|
||||||
sinkpad: gst::Pad,
|
sinkpad: gst::Pad,
|
||||||
|
|
||||||
state: AtomicRefCell<State>,
|
state: Mutex<State>,
|
||||||
}
|
}
|
||||||
|
|
||||||
lazy_static! {
|
lazy_static! {
|
||||||
|
@ -203,7 +203,7 @@ impl TtToCea608 {
|
||||||
new_frame_no: u64,
|
new_frame_no: u64,
|
||||||
) -> Result<gst::FlowSuccess, gst::FlowError> {
|
) -> Result<gst::FlowSuccess, gst::FlowError> {
|
||||||
if last_frame_no != new_frame_no {
|
if last_frame_no != new_frame_no {
|
||||||
let state = self.state.borrow_mut();
|
let state = self.state.lock().unwrap();
|
||||||
let (fps_n, fps_d) = (
|
let (fps_n, fps_d) = (
|
||||||
*state.framerate.numer() as u64,
|
*state.framerate.numer() as u64,
|
||||||
*state.framerate.denom() as u64,
|
*state.framerate.denom() as u64,
|
||||||
|
@ -235,7 +235,7 @@ impl TtToCea608 {
|
||||||
min_frame_no: u64,
|
min_frame_no: u64,
|
||||||
mut erase_display_frame_no: u64,
|
mut erase_display_frame_no: u64,
|
||||||
) -> Result<gst::FlowSuccess, gst::FlowError> {
|
) -> Result<gst::FlowSuccess, gst::FlowError> {
|
||||||
let mut state = self.state.borrow_mut();
|
let mut state = self.state.lock().unwrap();
|
||||||
|
|
||||||
let (fps_n, fps_d) = (
|
let (fps_n, fps_d) = (
|
||||||
*state.framerate.numer() as u64,
|
*state.framerate.numer() as u64,
|
||||||
|
@ -291,7 +291,7 @@ impl TtToCea608 {
|
||||||
duration => Ok(duration),
|
duration => Ok(duration),
|
||||||
}?;
|
}?;
|
||||||
|
|
||||||
let mut state = self.state.borrow_mut();
|
let mut state = self.state.lock().unwrap();
|
||||||
let mut buffers = vec![];
|
let mut buffers = vec![];
|
||||||
|
|
||||||
{
|
{
|
||||||
|
@ -474,7 +474,7 @@ impl TtToCea608 {
|
||||||
let ret = self.sinkpad.peer_query(&mut peer_query);
|
let ret = self.sinkpad.peer_query(&mut peer_query);
|
||||||
|
|
||||||
if ret {
|
if ret {
|
||||||
let state = self.state.borrow();
|
let state = self.state.lock().unwrap();
|
||||||
let (live, mut min, mut max) = peer_query.get_result();
|
let (live, mut min, mut max) = peer_query.get_result();
|
||||||
let (fps_n, fps_d) = (
|
let (fps_n, fps_d) = (
|
||||||
*state.framerate.numer() as u64,
|
*state.framerate.numer() as u64,
|
||||||
|
@ -525,7 +525,7 @@ impl TtToCea608 {
|
||||||
);
|
);
|
||||||
s.fixate();
|
s.fixate();
|
||||||
|
|
||||||
let mut state = self.state.borrow_mut();
|
let mut state = self.state.lock().unwrap();
|
||||||
state.framerate = s.get_some::<gst::Fraction>("framerate").unwrap();
|
state.framerate = s.get_some::<gst::Fraction>("framerate").unwrap();
|
||||||
|
|
||||||
gst_debug!(CAT, obj: pad, "Pushing caps {}", caps);
|
gst_debug!(CAT, obj: pad, "Pushing caps {}", caps);
|
||||||
|
@ -537,7 +537,7 @@ impl TtToCea608 {
|
||||||
return self.srcpad.push_event(new_event);
|
return self.srcpad.push_event(new_event);
|
||||||
}
|
}
|
||||||
EventView::Gap(e) => {
|
EventView::Gap(e) => {
|
||||||
let mut state = self.state.borrow_mut();
|
let mut state = self.state.lock().unwrap();
|
||||||
let (fps_n, fps_d) = (
|
let (fps_n, fps_d) = (
|
||||||
*state.framerate.numer() as u64,
|
*state.framerate.numer() as u64,
|
||||||
*state.framerate.denom() as u64,
|
*state.framerate.denom() as u64,
|
||||||
|
@ -571,7 +571,7 @@ impl TtToCea608 {
|
||||||
return true;
|
return true;
|
||||||
}
|
}
|
||||||
EventView::Eos(_) => {
|
EventView::Eos(_) => {
|
||||||
let mut state = self.state.borrow_mut();
|
let mut state = self.state.lock().unwrap();
|
||||||
if let Some(erase_display_frame_no) = state.erase_display_frame_no {
|
if let Some(erase_display_frame_no) = state.erase_display_frame_no {
|
||||||
let min_frame_no = state.last_frame_no;
|
let min_frame_no = state.last_frame_no;
|
||||||
state.erase_display_frame_no = None;
|
state.erase_display_frame_no = None;
|
||||||
|
@ -633,7 +633,7 @@ impl ObjectSubclass for TtToCea608 {
|
||||||
Self {
|
Self {
|
||||||
srcpad,
|
srcpad,
|
||||||
sinkpad,
|
sinkpad,
|
||||||
state: AtomicRefCell::new(State::default()),
|
state: Mutex::new(State::default()),
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -699,7 +699,7 @@ impl ElementImpl for TtToCea608 {
|
||||||
|
|
||||||
match transition {
|
match transition {
|
||||||
gst::StateChange::ReadyToPaused => {
|
gst::StateChange::ReadyToPaused => {
|
||||||
let mut state = self.state.borrow_mut();
|
let mut state = self.state.lock().unwrap();
|
||||||
*state = State::default();
|
*state = State::default();
|
||||||
}
|
}
|
||||||
_ => (),
|
_ => (),
|
||||||
|
@ -709,7 +709,7 @@ impl ElementImpl for TtToCea608 {
|
||||||
|
|
||||||
match transition {
|
match transition {
|
||||||
gst::StateChange::PausedToReady => {
|
gst::StateChange::PausedToReady => {
|
||||||
let mut state = self.state.borrow_mut();
|
let mut state = self.state.lock().unwrap();
|
||||||
*state = State::default();
|
*state = State::default();
|
||||||
}
|
}
|
||||||
_ => (),
|
_ => (),
|
||||||
|
|
Loading…
Reference in a new issue