[FFmpeg-cvslog] paf: decode directly to the user-provided AVFrame

Paul B Mahol git at videolan.org
Wed Feb 13 13:36:22 CET 2013


ffmpeg | branch: master | Paul B Mahol <onemda at gmail.com> | Wed Feb 13 12:20:39 2013 +0000| [2cced2a85442cd70cf6ceec29aff9ab1dc7880aa] | committer: Paul B Mahol

paf: decode directly to the user-provided AVFrame

Signed-off-by: Paul B Mahol <onemda at gmail.com>

> http://git.videolan.org/gitweb.cgi/ffmpeg.git/?a=commit;h=2cced2a85442cd70cf6ceec29aff9ab1dc7880aa
---

 libavcodec/paf.c |   18 ++++--------------
 1 file changed, 4 insertions(+), 14 deletions(-)

diff --git a/libavcodec/paf.c b/libavcodec/paf.c
index aa8370c..78a5d97 100644
--- a/libavcodec/paf.c
+++ b/libavcodec/paf.c
@@ -377,22 +377,14 @@ static av_cold int paf_vid_close(AVCodecContext *avctx)
     return 0;
 }
 
-typedef struct PAFAudioDecContext {
-    AVFrame frame;
-} PAFAudioDecContext;
-
 static av_cold int paf_aud_init(AVCodecContext *avctx)
 {
-    PAFAudioDecContext *c = avctx->priv_data;
-
     if (avctx->channels != 2) {
         av_log(avctx, AV_LOG_ERROR, "invalid number of channels\n");
         return AVERROR_INVALIDDATA;
     }
 
-    avcodec_get_frame_defaults(&c->frame);
     avctx->channel_layout = AV_CH_LAYOUT_STEREO;
-    avctx->coded_frame    = &c->frame;
     avctx->sample_fmt     = AV_SAMPLE_FMT_S16;
 
     return 0;
@@ -401,7 +393,7 @@ static av_cold int paf_aud_init(AVCodecContext *avctx)
 static int paf_aud_decode(AVCodecContext *avctx, void *data,
                           int *got_frame_ptr, AVPacket *pkt)
 {
-    PAFAudioDecContext *c = avctx->priv_data;
+    AVFrame *frame = data;
     uint8_t *buf = pkt->data;
     int16_t *output_samples;
     const uint8_t *t;
@@ -411,11 +403,11 @@ static int paf_aud_decode(AVCodecContext *avctx, void *data,
     if (frames < 1)
         return AVERROR_INVALIDDATA;
 
-    c->frame.nb_samples = PAF_SOUND_SAMPLES * frames;
-    if ((ret = ff_get_buffer(avctx, &c->frame)) < 0)
+    frame->nb_samples = PAF_SOUND_SAMPLES * frames;
+    if ((ret = ff_get_buffer(avctx, frame)) < 0)
         return ret;
 
-    output_samples = (int16_t *)c->frame.data[0];
+    output_samples = (int16_t *)frame->data[0];
     for (i = 0; i < frames; i++) {
         t = buf + 256 * sizeof(uint16_t);
         for (j = 0; j < PAF_SOUND_SAMPLES; j++) {
@@ -428,7 +420,6 @@ static int paf_aud_decode(AVCodecContext *avctx, void *data,
     }
 
     *got_frame_ptr   = 1;
-    *(AVFrame *)data = c->frame;
 
     return pkt->size;
 }
@@ -449,7 +440,6 @@ AVCodec ff_paf_audio_decoder = {
     .name           = "paf_audio",
     .type           = AVMEDIA_TYPE_AUDIO,
     .id             = AV_CODEC_ID_PAF_AUDIO,
-    .priv_data_size = sizeof(PAFAudioDecContext),
     .init           = paf_aud_init,
     .decode         = paf_aud_decode,
     .capabilities   = CODEC_CAP_DR1,



More information about the ffmpeg-cvslog mailing list