[FFmpeg-devel] [PATCH 1/6] lavc/vp56: Refactor ff_vp56_init into ff_vp56_init/ff_vp56_init_context

Ben Jackson ben at ben.com
Sat Sep 15 19:32:39 CEST 2012


Pave the way for per-thread context initialization.

Signed-off-by: Ben Jackson <ben at ben.com>
---
 libavcodec/vp56.c |   12 ++++++++++++
 libavcodec/vp56.h |    3 +++
 2 files changed, 15 insertions(+), 0 deletions(-)

diff --git a/libavcodec/vp56.c b/libavcodec/vp56.c
index f3f7eca..b8e183c 100644
--- a/libavcodec/vp56.c
+++ b/libavcodec/vp56.c
@@ -661,6 +661,12 @@ int ff_vp56_decode_frame(AVCodecContext *avctx, void *data, int *data_size,
 av_cold void ff_vp56_init(AVCodecContext *avctx, int flip, int has_alpha)
 {
     VP56Context *s = avctx->priv_data;
+    ff_vp56_init_context(avctx, s, flip, has_alpha);
+}
+
+av_cold void ff_vp56_init_context(AVCodecContext *avctx, VP56Context *s,
+                                  int flip, int has_alpha)
+{
     int i;
 
     s->avctx = avctx;
@@ -702,6 +708,12 @@ av_cold void ff_vp56_init(AVCodecContext *avctx, int flip, int has_alpha)
 av_cold int ff_vp56_free(AVCodecContext *avctx)
 {
     VP56Context *s = avctx->priv_data;
+    return ff_vp56_free_context(s);
+}
+
+av_cold int ff_vp56_free_context(VP56Context *s)
+{
+    AVCodecContext *avctx = s->avctx;
 
     av_freep(&s->qscale_table);
     av_freep(&s->above_blocks);
diff --git a/libavcodec/vp56.h b/libavcodec/vp56.h
index d8f7ce6..8256bee 100644
--- a/libavcodec/vp56.h
+++ b/libavcodec/vp56.h
@@ -174,7 +174,10 @@ struct vp56_context {
 
 
 void ff_vp56_init(AVCodecContext *avctx, int flip, int has_alpha);
+void ff_vp56_init_context(AVCodecContext *avctx, VP56Context *s,
+                          int flip, int has_alpha);
 int ff_vp56_free(AVCodecContext *avctx);
+int ff_vp56_free_context(VP56Context *s);
 void ff_vp56_init_dequant(VP56Context *s, int quantizer);
 int ff_vp56_decode_frame(AVCodecContext *avctx, void *data, int *data_size,
                          AVPacket *avpkt);
-- 
1.6.3.GIT



More information about the ffmpeg-devel mailing list