forked from teamnwah/openmw-tes3coop
Fix for compiler warnings and deprecated functions usage in videoplayer.
Deprecated functions were: - AVCodecContext::get_buffer - AVCodecContext::release_buffer Changed to: AVCodecContext::get_buffer2 and setting AVCodecContext::refcounted_frames to 1 before call to avcodec_open2(). release_buffer usage was removed. Also changed places when some fileds were compared to AV_NOPTS_VALUE - it's signed, so removed unsigned int casting, or changed casting to signed int. Signed-off-by: Lukasz Gromanowski <lgromanowski@gmail.com>
This commit is contained in:
parent
cf5c5cbce7
commit
d77546b7dc
1 changed files with 8 additions and 14 deletions
|
@ -220,7 +220,7 @@ void PacketQueue::put(AVPacket *pkt)
|
|||
pkt1->pkt = *pkt;
|
||||
pkt1->next = NULL;
|
||||
|
||||
if(pkt1->pkt.destruct == NULL)
|
||||
if(pkt1->pkt.buf == NULL)
|
||||
{
|
||||
if(av_dup_packet(&pkt1->pkt) < 0)
|
||||
{
|
||||
|
@ -425,7 +425,7 @@ class MovieAudioDecoder : public MWSound::Sound_Decoder
|
|||
return -1;
|
||||
|
||||
/* if update, update the audio clock w/pts */
|
||||
if((uint64_t)pkt->pts != AV_NOPTS_VALUE)
|
||||
if(pkt->pts != AV_NOPTS_VALUE)
|
||||
mAudioClock = av_q2d(mAVStream->time_base)*pkt->pts;
|
||||
}
|
||||
}
|
||||
|
@ -820,20 +820,14 @@ double VideoState::synchronize_video(AVFrame *src_frame, double pts)
|
|||
* a frame at the time it is allocated.
|
||||
*/
|
||||
static uint64_t global_video_pkt_pts = static_cast<uint64_t>(AV_NOPTS_VALUE);
|
||||
static int our_get_buffer(struct AVCodecContext *c, AVFrame *pic)
|
||||
static int our_get_buffer2(struct AVCodecContext *c, AVFrame *pic, int flags = AV_GET_BUFFER_FLAG_REF)
|
||||
{
|
||||
int ret = avcodec_default_get_buffer(c, pic);
|
||||
int ret = avcodec_default_get_buffer2(c, pic, flags);
|
||||
uint64_t *pts = (uint64_t*)av_malloc(sizeof(uint64_t));
|
||||
*pts = global_video_pkt_pts;
|
||||
pic->opaque = pts;
|
||||
return ret;
|
||||
}
|
||||
static void our_release_buffer(struct AVCodecContext *c, AVFrame *pic)
|
||||
{
|
||||
if(pic) av_freep(&pic->opaque);
|
||||
avcodec_default_release_buffer(c, pic);
|
||||
}
|
||||
|
||||
|
||||
void VideoState::video_thread_loop(VideoState *self)
|
||||
{
|
||||
|
@ -856,9 +850,9 @@ void VideoState::video_thread_loop(VideoState *self)
|
|||
throw std::runtime_error("Error decoding video frame");
|
||||
|
||||
pts = 0;
|
||||
if((uint64_t)packet->dts != AV_NOPTS_VALUE)
|
||||
if(packet->dts != AV_NOPTS_VALUE)
|
||||
pts = packet->dts;
|
||||
else if(pFrame->opaque && *(uint64_t*)pFrame->opaque != AV_NOPTS_VALUE)
|
||||
else if(pFrame->opaque && *(int64_t*)pFrame->opaque != AV_NOPTS_VALUE)
|
||||
pts = *(uint64_t*)pFrame->opaque;
|
||||
pts *= av_q2d((*self->video_st)->time_base);
|
||||
|
||||
|
@ -959,6 +953,7 @@ int VideoState::stream_open(int stream_index, AVFormatContext *pFormatCtx)
|
|||
// Get a pointer to the codec context for the video stream
|
||||
codecCtx = pFormatCtx->streams[stream_index]->codec;
|
||||
codec = avcodec_find_decoder(codecCtx->codec_id);
|
||||
codecCtx->refcounted_frames = 1;
|
||||
if(!codec || (avcodec_open2(codecCtx, codec, NULL) < 0))
|
||||
{
|
||||
fprintf(stderr, "Unsupported codec!\n");
|
||||
|
@ -985,8 +980,7 @@ int VideoState::stream_open(int stream_index, AVFormatContext *pFormatCtx)
|
|||
|
||||
this->frame_last_delay = 40e-3;
|
||||
|
||||
codecCtx->get_buffer = our_get_buffer;
|
||||
codecCtx->release_buffer = our_release_buffer;
|
||||
codecCtx->get_buffer2 = our_get_buffer2;
|
||||
this->video_thread = boost::thread(video_thread_loop, this);
|
||||
this->refresh_thread = boost::thread(video_refresh, this);
|
||||
break;
|
||||
|
|
Loading…
Reference in a new issue