Mercurial > libavcodec.hg
comparison cook.c @ 9355:54bc8a2727b0 libavcodec
Implement avcodec_decode_video2(), _audio3() and _subtitle2() which takes an
AVPacket argument rather than a const uint8_t *buf + int buf_size. This allows
passing of packet-specific flags from demuxer to decoder, such as the keyframe
flag, which appears necessary to playback corePNG P-frames.
Patch by Thilo Borgmann thilo.borgmann googlemail com, see also the thread
"Google Summer of Code participation" on the mailinglist.
author | rbultje |
---|---|
date | Tue, 07 Apr 2009 15:59:50 +0000 |
parents | bb35ea566fe5 |
children | 0dce4fe6e6f3 |
comparison
equal
deleted
inserted
replaced
9354:174309386512 | 9355:54bc8a2727b0 |
---|---|
977 * @param avctx pointer to the AVCodecContext | 977 * @param avctx pointer to the AVCodecContext |
978 */ | 978 */ |
979 | 979 |
980 static int cook_decode_frame(AVCodecContext *avctx, | 980 static int cook_decode_frame(AVCodecContext *avctx, |
981 void *data, int *data_size, | 981 void *data, int *data_size, |
982 const uint8_t *buf, int buf_size) { | 982 AVPacket *avpkt) { |
983 const uint8_t *buf = avpkt->data; | |
984 int buf_size = avpkt->size; | |
983 COOKContext *q = avctx->priv_data; | 985 COOKContext *q = avctx->priv_data; |
984 | 986 |
985 if (buf_size < avctx->block_align) | 987 if (buf_size < avctx->block_align) |
986 return buf_size; | 988 return buf_size; |
987 | 989 |