fftools/ffmpeg: avoid possible invalid reads with short -tag values

Fixes #10319 and #10309.

(cherry picked from commit 89c9a3ac35)
Signed-off-by: Anton Khirnov <anton@khirnov.net>
release/6.0
Anton Khirnov 2 years ago
parent 2c11164707
commit 8f61cbf1b9
  1. 8
      fftools/ffmpeg_demux.c
  2. 7
      fftools/ffmpeg_mux_init.c

@ -628,8 +628,12 @@ static void add_input_streams(const OptionsContext *o, Demuxer *d)
MATCH_PER_STREAM_OPT(codec_tags, str, codec_tag, ic, st); MATCH_PER_STREAM_OPT(codec_tags, str, codec_tag, ic, st);
if (codec_tag) { if (codec_tag) {
uint32_t tag = strtol(codec_tag, &next, 0); uint32_t tag = strtol(codec_tag, &next, 0);
if (*next) if (*next) {
tag = AV_RL32(codec_tag); uint8_t buf[4] = { 0 };
memcpy(buf, codec_tag, FFMIN(sizeof(buf), strlen(codec_tag)));
tag = AV_RL32(buf);
}
st->codecpar->codec_tag = tag; st->codecpar->codec_tag = tag;
} }

@ -606,8 +606,11 @@ static OutputStream *new_output_stream(Muxer *mux, const OptionsContext *o,
MATCH_PER_STREAM_OPT(codec_tags, str, codec_tag, oc, st); MATCH_PER_STREAM_OPT(codec_tags, str, codec_tag, oc, st);
if (codec_tag) { if (codec_tag) {
uint32_t tag = strtol(codec_tag, &next, 0); uint32_t tag = strtol(codec_tag, &next, 0);
if (*next) if (*next) {
tag = AV_RL32(codec_tag); uint8_t buf[4] = { 0 };
memcpy(buf, codec_tag, FFMIN(sizeof(buf), strlen(codec_tag)));
tag = AV_RL32(buf);
}
ost->st->codecpar->codec_tag = tag; ost->st->codecpar->codec_tag = tag;
if (ost->enc_ctx) if (ost->enc_ctx)
ost->enc_ctx->codec_tag = tag; ost->enc_ctx->codec_tag = tag;

Loading…
Cancel
Save