diff options
| author | Petri Hintukainen <phintuka@users.sourceforge.net> | 2012-05-28 09:50:19 +0300 | 
|---|---|---|
| committer | Petri Hintukainen <phintuka@users.sourceforge.net> | 2012-05-28 09:50:19 +0300 | 
| commit | 3e460bf2e653cf8b8372290b03e3b5255fd65e4a (patch) | |
| tree | a6adc566d5cbe37ae69e7309964d353440252a30 /src/combined/ffmpeg | |
| parent | 1a0c8d7dd0155ac22aa2dd01f8292c00e1b97c80 (diff) | |
| parent | f70101339ec4ec3d203822fe3d1a92d86e007627 (diff) | |
| download | xine-lib-3e460bf2e653cf8b8372290b03e3b5255fd65e4a.tar.gz xine-lib-3e460bf2e653cf8b8372290b03e3b5255fd65e4a.tar.bz2 | |
Merge from 1.1
Diffstat (limited to 'src/combined/ffmpeg')
| -rw-r--r-- | src/combined/ffmpeg/ff_video_decoder.c | 19 | 
1 files changed, 10 insertions, 9 deletions
| diff --git a/src/combined/ffmpeg/ff_video_decoder.c b/src/combined/ffmpeg/ff_video_decoder.c index 0291e3f4b..8e291e22f 100644 --- a/src/combined/ffmpeg/ff_video_decoder.c +++ b/src/combined/ffmpeg/ff_video_decoder.c @@ -262,7 +262,7 @@ static int get_buffer(AVCodecContext *context, AVFrame *av_frame){    /* take over pts for this frame to have it reordered */    av_frame->reordered_opaque = context->reordered_opaque; -  xine_list_push_back(this->dr1_frames, av_frame); +  xine_list_push_back(this->dr1_frames, img);    return 0;  } @@ -279,10 +279,11 @@ static void release_buffer(struct AVCodecContext *context, AVFrame *av_frame){      xine_list_iterator_t it; -    it = xine_list_find(this->dr1_frames, av_frame); +    it = xine_list_find(this->dr1_frames, av_frame->opaque);      assert(it); -    if( it != NULL ) +    if( it != NULL ) {        xine_list_remove(this->dr1_frames, it); +    }    } else {      avcodec_default_release_buffer(context, av_frame);    } @@ -1712,7 +1713,6 @@ static void ff_reset (video_decoder_t *this_gen) {    if(this->context && this->decoder_ok)    {      xine_list_iterator_t it; -    AVFrame *av_frame;      avcodec_flush_buffers(this->context); @@ -1720,8 +1720,9 @@ static void ff_reset (video_decoder_t *this_gen) {       * don't release their DR1 frames */      while( (it = xine_list_front(this->dr1_frames)) != NULL )      { -      av_frame = (AVFrame *)xine_list_get_value(this->dr1_frames, it); -      release_buffer(this->context, av_frame); +      vo_frame_t *img = (vo_frame_t *)xine_list_get_value(this->dr1_frames, it); +      if (img) +        img->free(img);      }      xine_list_clear(this->dr1_frames);    } @@ -1782,7 +1783,6 @@ static void ff_dispose (video_decoder_t *this_gen) {    if (this->decoder_ok) {      xine_list_iterator_t it; -    AVFrame *av_frame;      pthread_mutex_lock(&ffmpeg_lock);      avcodec_close (this->context); @@ -1792,8 +1792,9 @@ static void ff_dispose (video_decoder_t *this_gen) {       * don't release their DR1 frames */      while( (it = xine_list_front(this->dr1_frames)) != NULL )      { -      av_frame = (AVFrame *)xine_list_get_value(this->dr1_frames, it); -      release_buffer(this->context, av_frame); +      vo_frame_t *img = (vo_frame_t *)xine_list_get_value(this->dr1_frames, it); +      if (img) +        img->free(img);      }      this->stream->video_out->close(this->stream->video_out, this->stream); | 
