|
@@ -101,8 +101,6 @@ static const OptionDef options[];
|
|
|
static int *streamid_map = NULL;
|
|
|
static int nb_streamid_map = 0;
|
|
|
|
|
|
-static uint16_t *intra_matrix = NULL;
|
|
|
-static uint16_t *inter_matrix = NULL;
|
|
|
static int video_discard = 0;
|
|
|
static int same_quant = 0;
|
|
|
static int do_deinterlace = 0;
|
|
@@ -324,6 +322,10 @@ typedef struct OptionsContext {
|
|
|
int nb_frame_aspect_ratios;
|
|
|
SpecifierOpt *rc_overrides;
|
|
|
int nb_rc_overrides;
|
|
|
+ SpecifierOpt *intra_matrices;
|
|
|
+ int nb_intra_matrices;
|
|
|
+ SpecifierOpt *inter_matrices;
|
|
|
+ int nb_inter_matrices;
|
|
|
} OptionsContext;
|
|
|
|
|
|
#define MATCH_PER_STREAM_OPT(name, type, outvar, fmtctx, st)\
|
|
@@ -510,9 +512,6 @@ void exit_program(int ret)
|
|
|
for (i = 0; i < nb_input_streams; i++)
|
|
|
av_dict_free(&input_streams[i].opts);
|
|
|
|
|
|
- av_free(intra_matrix);
|
|
|
- av_free(inter_matrix);
|
|
|
-
|
|
|
if (vstats_file)
|
|
|
fclose(vstats_file);
|
|
|
av_free(vstats_filename);
|
|
@@ -3003,6 +3002,23 @@ static OutputStream *new_output_stream(OptionsContext *o, AVFormatContext *oc, e
|
|
|
return ost;
|
|
|
}
|
|
|
|
|
|
+static void parse_matrix_coeffs(uint16_t *dest, const char *str)
|
|
|
+{
|
|
|
+ int i;
|
|
|
+ const char *p = str;
|
|
|
+ for(i = 0;; i++) {
|
|
|
+ dest[i] = atoi(p);
|
|
|
+ if(i == 63)
|
|
|
+ break;
|
|
|
+ p = strchr(p, ',');
|
|
|
+ if(!p) {
|
|
|
+ fprintf(stderr, "Syntax error in matrix \"%s\" at coeff %d\n", str, i);
|
|
|
+ exit_program(1);
|
|
|
+ }
|
|
|
+ p++;
|
|
|
+ }
|
|
|
+}
|
|
|
+
|
|
|
static OutputStream *new_video_stream(OptionsContext *o, AVFormatContext *oc)
|
|
|
{
|
|
|
AVStream *st;
|
|
@@ -3028,6 +3044,7 @@ static OutputStream *new_video_stream(OptionsContext *o, AVFormatContext *oc)
|
|
|
const char *p = NULL;
|
|
|
char *forced_key_frames = NULL, *frame_rate = NULL, *frame_size = NULL;
|
|
|
char *frame_aspect_ratio = NULL, *frame_pix_fmt = NULL;
|
|
|
+ char *intra_matrix = NULL, *inter_matrix = NULL;
|
|
|
int i, force_fps = 0;
|
|
|
|
|
|
MATCH_PER_STREAM_OPT(frame_rates, str, frame_rate, oc, st);
|
|
@@ -3053,10 +3070,22 @@ static OutputStream *new_video_stream(OptionsContext *o, AVFormatContext *oc)
|
|
|
}
|
|
|
st->sample_aspect_ratio = video_enc->sample_aspect_ratio;
|
|
|
|
|
|
- if(intra_matrix)
|
|
|
- video_enc->intra_matrix = intra_matrix;
|
|
|
- if(inter_matrix)
|
|
|
- video_enc->inter_matrix = inter_matrix;
|
|
|
+ MATCH_PER_STREAM_OPT(intra_matrices, str, intra_matrix, oc, st);
|
|
|
+ if (intra_matrix) {
|
|
|
+ if (!(video_enc->intra_matrix = av_mallocz(sizeof(*video_enc->intra_matrix) * 64))) {
|
|
|
+ av_log(NULL, AV_LOG_ERROR, "Could not allocate memory for intra matrix.\n");
|
|
|
+ exit_program(1);
|
|
|
+ }
|
|
|
+ parse_matrix_coeffs(video_enc->intra_matrix, intra_matrix);
|
|
|
+ }
|
|
|
+ MATCH_PER_STREAM_OPT(inter_matrices, str, inter_matrix, oc, st);
|
|
|
+ if (inter_matrix) {
|
|
|
+ if (!(video_enc->inter_matrix = av_mallocz(sizeof(*video_enc->inter_matrix) * 64))) {
|
|
|
+ av_log(NULL, AV_LOG_ERROR, "Could not allocate memory for inter matrix.\n");
|
|
|
+ exit_program(1);
|
|
|
+ }
|
|
|
+ parse_matrix_coeffs(video_enc->inter_matrix, inter_matrix);
|
|
|
+ }
|
|
|
|
|
|
MATCH_PER_STREAM_OPT(rc_overrides, str, p, oc, st);
|
|
|
for(i=0; p; i++){
|
|
@@ -3608,35 +3637,6 @@ static int64_t getmaxrss(void)
|
|
|
#endif
|
|
|
}
|
|
|
|
|
|
-static void parse_matrix_coeffs(uint16_t *dest, const char *str)
|
|
|
-{
|
|
|
- int i;
|
|
|
- const char *p = str;
|
|
|
- for(i = 0;; i++) {
|
|
|
- dest[i] = atoi(p);
|
|
|
- if(i == 63)
|
|
|
- break;
|
|
|
- p = strchr(p, ',');
|
|
|
- if(!p) {
|
|
|
- fprintf(stderr, "Syntax error in matrix \"%s\" at coeff %d\n", str, i);
|
|
|
- exit_program(1);
|
|
|
- }
|
|
|
- p++;
|
|
|
- }
|
|
|
-}
|
|
|
-
|
|
|
-static void opt_inter_matrix(const char *arg)
|
|
|
-{
|
|
|
- inter_matrix = av_mallocz(sizeof(uint16_t) * 64);
|
|
|
- parse_matrix_coeffs(inter_matrix, arg);
|
|
|
-}
|
|
|
-
|
|
|
-static void opt_intra_matrix(const char *arg)
|
|
|
-{
|
|
|
- intra_matrix = av_mallocz(sizeof(uint16_t) * 64);
|
|
|
- parse_matrix_coeffs(intra_matrix, arg);
|
|
|
-}
|
|
|
-
|
|
|
static int opt_audio_qscale(OptionsContext *o, const char *opt, const char *arg)
|
|
|
{
|
|
|
return parse_option(o, "q:a", arg, options);
|
|
@@ -3968,8 +3968,8 @@ static const OptionDef options[] = {
|
|
|
#if CONFIG_AVFILTER
|
|
|
{ "vf", OPT_STRING | HAS_ARG, {(void*)&vfilters}, "video filters", "filter list" },
|
|
|
#endif
|
|
|
- { "intra_matrix", HAS_ARG | OPT_EXPERT | OPT_VIDEO, {(void*)opt_intra_matrix}, "specify intra matrix coeffs", "matrix" },
|
|
|
- { "inter_matrix", HAS_ARG | OPT_EXPERT | OPT_VIDEO, {(void*)opt_inter_matrix}, "specify inter matrix coeffs", "matrix" },
|
|
|
+ { "intra_matrix", HAS_ARG | OPT_EXPERT | OPT_VIDEO | OPT_STRING | OPT_SPEC, {.off = OFFSET(intra_matrices)}, "specify intra matrix coeffs", "matrix" },
|
|
|
+ { "inter_matrix", HAS_ARG | OPT_EXPERT | OPT_VIDEO | OPT_STRING | OPT_SPEC, {.off = OFFSET(inter_matrices)}, "specify inter matrix coeffs", "matrix" },
|
|
|
{ "top", HAS_ARG | OPT_EXPERT | OPT_VIDEO, {(void*)opt_top_field_first}, "top=1/bottom=0/auto=-1 field first", "" },
|
|
|
{ "dc", OPT_INT | HAS_ARG | OPT_EXPERT | OPT_VIDEO, {(void*)&intra_dc_precision}, "intra_dc_precision", "precision" },
|
|
|
{ "vtag", HAS_ARG | OPT_EXPERT | OPT_VIDEO | OPT_FUNC2, {(void*)opt_video_tag}, "force video tag/fourcc", "fourcc/tag" },
|