Commit cdb1236e authored by rtognimp's avatar rtognimp

Add cr codec capability and buffer hints


git-svn-id: file:///var/local/repositories/ffmpeg/trunk@2484 9553f0bf-9b14-0410-a0b8-cfaf0461ba5b
parent efe23f80
...@@ -16,7 +16,7 @@ extern "C" { ...@@ -16,7 +16,7 @@ extern "C" {
#define FFMPEG_VERSION_INT 0x000408 #define FFMPEG_VERSION_INT 0x000408
#define FFMPEG_VERSION "0.4.8" #define FFMPEG_VERSION "0.4.8"
#define LIBAVCODEC_BUILD 4690 #define LIBAVCODEC_BUILD 4691
#define LIBAVCODEC_VERSION_INT FFMPEG_VERSION_INT #define LIBAVCODEC_VERSION_INT FFMPEG_VERSION_INT
#define LIBAVCODEC_VERSION FFMPEG_VERSION #define LIBAVCODEC_VERSION FFMPEG_VERSION
...@@ -275,6 +275,10 @@ static const __attribute__((unused)) int Motion_Est_QTab[] = ...@@ -275,6 +275,10 @@ static const __attribute__((unused)) int Motion_Est_QTab[] =
used */ used */
#define CODEC_CAP_PARSE_ONLY 0x0004 #define CODEC_CAP_PARSE_ONLY 0x0004
#define CODEC_CAP_TRUNCATED 0x0008 #define CODEC_CAP_TRUNCATED 0x0008
/*
* Codec can use conditional replenishment if available.
*/
#define CODEC_CAP_CR 0x0010
/** /**
* Pan Scan area. * Pan Scan area.
...@@ -460,6 +464,13 @@ typedef struct AVPanScan{ ...@@ -460,6 +464,13 @@ typedef struct AVPanScan{
* - decoding: set by lavc (default 0)\ * - decoding: set by lavc (default 0)\
*/\ */\
int palette_has_changed;\ int palette_has_changed;\
\
/**\
* Codec suggestion on buffer type if != 0\
* - encoding: unused\
* - decoding: set by lavc (before get_buffer() call))\
*/\
int buffer_hints;\
#define FF_QSCALE_TYPE_MPEG1 0 #define FF_QSCALE_TYPE_MPEG1 0
#define FF_QSCALE_TYPE_MPEG2 1 #define FF_QSCALE_TYPE_MPEG2 1
...@@ -477,6 +488,11 @@ typedef struct AVPanScan{ ...@@ -477,6 +488,11 @@ typedef struct AVPanScan{
#define FF_SI_TYPE 5 #define FF_SI_TYPE 5
#define FF_SP_TYPE 6 #define FF_SP_TYPE 6
#define FF_BUFFER_HINTS_VALID 0x01 // Buffer hints value is meaningful (if 0 ignore)
#define FF_BUFFER_HINTS_READABLE 0x02 // Codec will read from buffer
#define FF_BUFFER_HINTS_PRESERVE 0x04 // User must not alter buffer content
#define FF_BUFFER_HINTS_REUSABLE 0x08 // Codec will reuse the buffer (update)
/** /**
* Audio Video Frame. * Audio Video Frame.
*/ */
...@@ -1366,6 +1382,13 @@ typedef struct AVCodecContext { ...@@ -1366,6 +1382,13 @@ typedef struct AVCodecContext {
*/ */
int noise_reduction; int noise_reduction;
/**
* Conditional replenishment support
* - encoding: unused
* - decoding: set by user, if 1 user can allocate reusable buffers
*/
int cr_available;
} AVCodecContext; } AVCodecContext;
......
...@@ -326,6 +326,7 @@ void avcodec_get_context_defaults(AVCodecContext *s){ ...@@ -326,6 +326,7 @@ void avcodec_get_context_defaults(AVCodecContext *s){
s->intra_quant_bias= FF_DEFAULT_QUANT_BIAS; s->intra_quant_bias= FF_DEFAULT_QUANT_BIAS;
s->inter_quant_bias= FF_DEFAULT_QUANT_BIAS; s->inter_quant_bias= FF_DEFAULT_QUANT_BIAS;
s->palctrl = NULL; s->palctrl = NULL;
s->cr_available = 0;
} }
/** /**
......
Markdown is supported
0%
or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment