diff options
author | Kieran Kunhya <kierank@ob-encoder.com> | 2015-12-09 00:05:31 +0000 |
---|---|---|
committer | Rostislav Pehlivanov <atomnuker@gmail.com> | 2015-12-10 21:26:35 +0000 |
commit | 8dcc99dc684da4f128faa53f3988afa29e392afb (patch) | |
tree | 71303dc837cf8491b7f7b19cbf5455f3bee34e39 | |
parent | 9f374c59061be6b3e5d394678e08adce42c1392e (diff) | |
download | ffmpeg-8dcc99dc684da4f128faa53f3988afa29e392afb.tar.gz |
diracdec: Extract version parameters
-rw-r--r-- | libavcodec/dirac.c | 1 | ||||
-rw-r--r-- | libavcodec/dirac.h | 6 | ||||
-rw-r--r-- | libavcodec/diracdec.c | 3 | ||||
-rw-r--r-- | 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; |