Commit 9c0a70ee authored by michael's avatar michael

"Flush" the picture que on seeks, this prevents the display thread from

having frames from before and after the seek which just isnt a good idea.


git-svn-id: file:///var/local/repositories/ffmpeg/trunk@21588 9553f0bf-9b14-0410-a0b8-cfaf0461ba5b
parent 956871fc
...@@ -90,6 +90,7 @@ typedef struct VideoPicture { ...@@ -90,6 +90,7 @@ typedef struct VideoPicture {
SDL_Overlay *bmp; SDL_Overlay *bmp;
int width, height; /* source height & width */ int width, height; /* source height & width */
int allocated; int allocated;
SDL_TimerID timer_id;
} VideoPicture; } VideoPicture;
typedef struct SubPicture { typedef struct SubPicture {
...@@ -913,10 +914,10 @@ static Uint32 sdl_refresh_timer_cb(Uint32 interval, void *opaque) ...@@ -913,10 +914,10 @@ static Uint32 sdl_refresh_timer_cb(Uint32 interval, void *opaque)
} }
/* schedule a video refresh in 'delay' ms */ /* schedule a video refresh in 'delay' ms */
static void schedule_refresh(VideoState *is, int delay) static SDL_TimerID schedule_refresh(VideoState *is, int delay)
{ {
if(!delay) delay=1; //SDL seems to be buggy when the delay is 0 if(!delay) delay=1; //SDL seems to be buggy when the delay is 0
SDL_AddTimer(delay, sdl_refresh_timer_cb, is); return SDL_AddTimer(delay, sdl_refresh_timer_cb, is);
} }
/* get the current audio clock value */ /* get the current audio clock value */
...@@ -1122,6 +1123,7 @@ static void video_refresh_timer(void *opaque) ...@@ -1122,6 +1123,7 @@ static void video_refresh_timer(void *opaque)
is->pictq_rindex = 0; is->pictq_rindex = 0;
SDL_LockMutex(is->pictq_mutex); SDL_LockMutex(is->pictq_mutex);
vp->timer_id= 0;
is->pictq_size--; is->pictq_size--;
SDL_CondSignal(is->pictq_cond); SDL_CondSignal(is->pictq_cond);
SDL_UnlockMutex(is->pictq_mutex); SDL_UnlockMutex(is->pictq_mutex);
...@@ -1277,8 +1279,9 @@ static int queue_picture(VideoState *is, AVFrame *src_frame, double pts) ...@@ -1277,8 +1279,9 @@ static int queue_picture(VideoState *is, AVFrame *src_frame, double pts)
is->pictq_windex = 0; is->pictq_windex = 0;
SDL_LockMutex(is->pictq_mutex); SDL_LockMutex(is->pictq_mutex);
is->pictq_size++; is->pictq_size++;
//We must schedule in a mutex as we must store the timer id before the timer dies or might end up freeing a alraedy freed id
vp->timer_id= schedule_refresh(is, (int)(compute_frame_delay(vp->pts, is) * 1000 + 0.5));
SDL_UnlockMutex(is->pictq_mutex); SDL_UnlockMutex(is->pictq_mutex);
schedule_refresh(is, (int)(compute_frame_delay(vp->pts, is) * 1000 + 0.5));
} }
return 0; return 0;
} }
...@@ -1326,7 +1329,7 @@ static int video_thread(void *arg) ...@@ -1326,7 +1329,7 @@ static int video_thread(void *arg)
{ {
VideoState *is = arg; VideoState *is = arg;
AVPacket pkt1, *pkt = &pkt1; AVPacket pkt1, *pkt = &pkt1;
int len1, got_picture; int len1, got_picture, i;
AVFrame *frame= avcodec_alloc_frame(); AVFrame *frame= avcodec_alloc_frame();
double pts; double pts;
...@@ -1339,6 +1342,21 @@ static int video_thread(void *arg) ...@@ -1339,6 +1342,21 @@ static int video_thread(void *arg)
if(pkt->data == flush_pkt.data){ if(pkt->data == flush_pkt.data){
avcodec_flush_buffers(is->video_st->codec); avcodec_flush_buffers(is->video_st->codec);
SDL_LockMutex(is->pictq_mutex);
//Make sure there are no long delay timers (ideally we should just flush the que but thats harder)
for(i=0; i<VIDEO_PICTURE_QUEUE_SIZE; i++){
if(is->pictq[i].timer_id){
SDL_RemoveTimer(is->pictq[i].timer_id);
is->pictq[i].timer_id=0;
schedule_refresh(is, 1);
}
}
while (is->pictq_size && !is->videoq.abort_request) {
SDL_CondWait(is->pictq_cond, is->pictq_mutex);
}
SDL_UnlockMutex(is->pictq_mutex);
is->last_dts_for_fault_detection= is->last_dts_for_fault_detection=
is->last_pts_for_fault_detection= INT64_MIN; is->last_pts_for_fault_detection= INT64_MIN;
continue; continue;
......
Markdown is supported
0%
or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment