Commit d1f9621d authored by Michael Niedermayer's avatar Michael Niedermayer

libx264: support passing arbitrary parameters.

Idea taken from mencoder. This should fix conflicts with presets as long as
the new system is used.
Signed-off-by: 's avatarMichael Niedermayer <michaelni@gmx.at>
parent e8940321
...@@ -42,6 +42,7 @@ typedef struct X264Context { ...@@ -42,6 +42,7 @@ typedef struct X264Context {
int fastfirstpass; int fastfirstpass;
char *stats; char *stats;
char *weightp; char *weightp;
char *x264opts;
} X264Context; } X264Context;
static void X264_log(void *p, int level, const char *fmt, va_list args) static void X264_log(void *p, int level, const char *fmt, va_list args)
...@@ -344,6 +345,17 @@ static av_cold int X264_init(AVCodecContext *avctx) ...@@ -344,6 +345,17 @@ static av_cold int X264_init(AVCodecContext *avctx)
OPT_STR("level", x4->level); OPT_STR("level", x4->level);
if(x4->x264opts){
const char *p= x4->x264opts;
while(p){
char param[256]={0}, val[256]={0};
sscanf(p, "%255[^:=]=%255[^:]", param, val);
OPT_STR(param, val);
p= strchr(p, ':');
p+=!!p;
}
}
if (x4->fastfirstpass) if (x4->fastfirstpass)
x264_param_apply_fastfirstpass(&x4->params); x264_param_apply_fastfirstpass(&x4->params);
...@@ -416,6 +428,7 @@ static const AVOption options[] = { ...@@ -416,6 +428,7 @@ static const AVOption options[] = {
{"level", "Specify level (as defined by Annex A)", OFFSET(level), FF_OPT_TYPE_STRING, 0, 0, 0, VE}, {"level", "Specify level (as defined by Annex A)", OFFSET(level), FF_OPT_TYPE_STRING, 0, 0, 0, VE},
{"passlogfile", "Filename for 2 pass stats", OFFSET(stats), FF_OPT_TYPE_STRING, 0, 0, 0, VE}, {"passlogfile", "Filename for 2 pass stats", OFFSET(stats), FF_OPT_TYPE_STRING, 0, 0, 0, VE},
{"wpredp", "Weighted prediction for P-frames", OFFSET(weightp), FF_OPT_TYPE_STRING, 0, 0, 0, VE}, {"wpredp", "Weighted prediction for P-frames", OFFSET(weightp), FF_OPT_TYPE_STRING, 0, 0, 0, VE},
{"x264opts", "x264 options", OFFSET(x264opts), FF_OPT_TYPE_STRING, 0, 0, 0, VE},
{ NULL }, { NULL },
}; };
......
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