From 8dcc99dc684da4f128faa53f3988afa29e392afb Mon Sep 17 00:00:00 2001 From: Kieran Kunhya Date: Wed, 9 Dec 2015 00:05:31 +0000 Subject: [PATCH] diracdec: Extract version parameters --- libavcodec/dirac.c | 1 + libavcodec/dirac.h | 6 ++++++ libavcodec/diracdec.c | 3 ++- libavformat/oggparsedirac.c | 4 +++- 4 files changed, 12 insertions(+), 2 deletions(-) diff --git a/libavcodec/dirac.c b/libavcodec/dirac.c index aa82dd9854..fd6e869194 100644 --- a/libavcodec/dirac.c +++ b/libavcodec/dirac.c @@ -294,6 +294,7 @@ static int parse_source_parameters(AVCodecContext *avctx, GetBitContext *gb, /* [DIRAC_STD] 10. Sequence Header. sequence_header() */ int avpriv_dirac_parse_sequence_header(AVCodecContext *avctx, GetBitContext *gb, dirac_source_params *source, + DiracVersionInfo *version, int *bit_depth) { unsigned version_major; diff --git a/libavcodec/dirac.h b/libavcodec/dirac.h index 14653f1dc2..6852e82d7f 100644 --- a/libavcodec/dirac.h +++ b/libavcodec/dirac.h @@ -34,6 +34,11 @@ #include "avcodec.h" #include "get_bits.h" +typedef struct DiracVersionInfo { + int major; + int minor; +} DiracVersionInfo; + typedef struct dirac_source_params { unsigned width; unsigned height; @@ -56,6 +61,7 @@ typedef struct dirac_source_params { int avpriv_dirac_parse_sequence_header(AVCodecContext *avctx, GetBitContext *gb, dirac_source_params *source, + DiracVersionInfo *version, int *bit_depth); #endif /* AVCODEC_DIRAC_H */ diff --git a/libavcodec/diracdec.c b/libavcodec/diracdec.c index efd2ebd46f..83547eb7ed 100644 --- a/libavcodec/diracdec.c +++ b/libavcodec/diracdec.c @@ -140,6 +140,7 @@ typedef struct DiracContext { MpegvideoEncDSPContext mpvencdsp; VideoDSPContext vdsp; DiracDSPContext diracdsp; + DiracVersionInfo version; GetBitContext gb; dirac_source_params source; int seen_sequence_header; @@ -1914,7 +1915,7 @@ static int dirac_decode_data_unit(AVCodecContext *avctx, const uint8_t *buf, int /* [DIRAC_STD] 10. Sequence header */ ret = avpriv_dirac_parse_sequence_header(avctx, &s->gb, &s->source, - &s->bit_depth); + &s->version, &s->bit_depth); if (ret < 0) return ret; diff --git a/libavformat/oggparsedirac.c b/libavformat/oggparsedirac.c index b317f5aa1b..ff947a04e1 100644 --- a/libavformat/oggparsedirac.c +++ b/libavformat/oggparsedirac.c @@ -30,6 +30,7 @@ static int dirac_header(AVFormatContext *s, int idx) struct ogg_stream *os = ogg->streams + idx; AVStream *st = s->streams[idx]; dirac_source_params source; + DiracVersionInfo version; GetBitContext gb; int ret, bit_depth; @@ -41,7 +42,8 @@ static int dirac_header(AVFormatContext *s, int idx) if (ret < 0) return ret; - ret = avpriv_dirac_parse_sequence_header(st->codec, &gb, &source, &bit_depth); + ret = avpriv_dirac_parse_sequence_header(st->codec, &gb, &source, &version, + &bit_depth); if (ret < 0) return ret;