From 0314fd1631454084e823e94918edb79019b96e63 Mon Sep 17 00:00:00 2001 From: Juergen Keil Date: Sat, 12 Oct 2002 17:11:58 +0000 Subject: While the demuxer mutex is unlocked, relinquish the processor in the main demuxer loop, otherwise (on solaris) demux_*_stop() has no chance to lock the mutex and change the demuxer status variable for interrupting the demuxer. Fixes xine_stop() problems on solaris. CVS patchset: 2815 CVS date: 2002/10/12 17:11:58 --- src/demuxers/demux_idcin.c | 4 +++- 1 file changed, 3 insertions(+), 1 deletion(-) (limited to 'src/demuxers/demux_idcin.c') diff --git a/src/demuxers/demux_idcin.c b/src/demuxers/demux_idcin.c index 217c5faba..a606dace4 100644 --- a/src/demuxers/demux_idcin.c +++ b/src/demuxers/demux_idcin.c @@ -63,7 +63,7 @@ * - if any bytes exceed 63, do not shift the bytes at all before * transmitting them to the video decoder * - * $Id: demux_idcin.c,v 1.15 2002/10/06 03:48:13 komadori Exp $ + * $Id: demux_idcin.c,v 1.16 2002/10/12 17:11:58 jkeil Exp $ */ #ifdef HAVE_CONFIG_H @@ -151,6 +151,8 @@ static void *demux_idcin_loop (void *this_gen) { /* someone may want to interrupt us */ pthread_mutex_unlock( &this->mutex ); + /* give demux_*_stop a chance to interrupt us */ + sched_yield(); pthread_mutex_lock( &this->mutex ); current_file_pos = this->input->get_current_pos(this->input); -- cgit v1.2.3