mirror of
https://git.ffmpeg.org/ffmpeg.git
synced 2025-02-02 12:53:29 +00:00
avconv: only apply presets when we have an encoder.
Fixes a crash when using a preset with stream copy.
(cherry picked from commit 4e61a38aa0
)
Signed-off-by: Reinhard Tartler <siretart@tauware.de>
This commit is contained in:
parent
0ba0e31955
commit
50b8e4c8fd
13
avconv.c
13
avconv.c
@ -3468,8 +3468,6 @@ static OutputStream *new_output_stream(OptionsContext *o, AVFormatContext *oc, e
|
|||||||
char *bsf = NULL, *next, *codec_tag = NULL;
|
char *bsf = NULL, *next, *codec_tag = NULL;
|
||||||
AVBitStreamFilterContext *bsfc, *bsfc_prev = NULL;
|
AVBitStreamFilterContext *bsfc, *bsfc_prev = NULL;
|
||||||
double qscale = -1;
|
double qscale = -1;
|
||||||
char *buf = NULL, *arg = NULL, *preset = NULL;
|
|
||||||
AVIOContext *s = NULL;
|
|
||||||
|
|
||||||
if (!st) {
|
if (!st) {
|
||||||
av_log(NULL, AV_LOG_FATAL, "Could not alloc stream.\n");
|
av_log(NULL, AV_LOG_FATAL, "Could not alloc stream.\n");
|
||||||
@ -3488,11 +3486,10 @@ static OutputStream *new_output_stream(OptionsContext *o, AVFormatContext *oc, e
|
|||||||
st->codec->codec_type = type;
|
st->codec->codec_type = type;
|
||||||
choose_encoder(o, oc, ost);
|
choose_encoder(o, oc, ost);
|
||||||
if (ost->enc) {
|
if (ost->enc) {
|
||||||
ost->opts = filter_codec_opts(codec_opts, ost->enc->id, oc, st);
|
AVIOContext *s = NULL;
|
||||||
}
|
char *buf = NULL, *arg = NULL, *preset = NULL;
|
||||||
|
|
||||||
avcodec_get_context_defaults3(st->codec, ost->enc);
|
ost->opts = filter_codec_opts(codec_opts, ost->enc->id, oc, st);
|
||||||
st->codec->codec_type = type; // XXX hack, avcodec_get_context_defaults2() sets type to unknown for stream copy
|
|
||||||
|
|
||||||
MATCH_PER_STREAM_OPT(presets, str, preset, oc, st);
|
MATCH_PER_STREAM_OPT(presets, str, preset, oc, st);
|
||||||
if (preset && (!(ret = get_preset_file_2(preset, ost->enc->name, &s)))) {
|
if (preset && (!(ret = get_preset_file_2(preset, ost->enc->name, &s)))) {
|
||||||
@ -3518,6 +3515,10 @@ static OutputStream *new_output_stream(OptionsContext *o, AVFormatContext *oc, e
|
|||||||
preset, ost->file_index, ost->index);
|
preset, ost->file_index, ost->index);
|
||||||
exit_program(1);
|
exit_program(1);
|
||||||
}
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
avcodec_get_context_defaults3(st->codec, ost->enc);
|
||||||
|
st->codec->codec_type = type; // XXX hack, avcodec_get_context_defaults2() sets type to unknown for stream copy
|
||||||
|
|
||||||
ost->max_frames = INT64_MAX;
|
ost->max_frames = INT64_MAX;
|
||||||
MATCH_PER_STREAM_OPT(max_frames, i64, ost->max_frames, oc, st);
|
MATCH_PER_STREAM_OPT(max_frames, i64, ost->max_frames, oc, st);
|
||||||
|
Loading…
Reference in New Issue
Block a user