fix Fix problematic realloc (#19812)

old-commit-hash: e736029235
commatwo_master
Dean Lee 4 years ago committed by GitHub
parent bea33f843e
commit 21346b0980
  1. 6
      selfdrive/loggerd/omx_encoder.cc

@ -349,12 +349,10 @@ void OmxEncoder::handle_out_buf(OmxEncoder *e, OMX_BUFFERHEADERTYPE *out_buf) {
if (e->remuxing) {
if (!e->wrote_codec_config && e->codec_config_len > 0) {
if (e->codec_ctx->extradata_size < e->codec_config_len) {
e->codec_ctx->extradata = (uint8_t *)realloc(e->codec_ctx->extradata, e->codec_config_len + AV_INPUT_BUFFER_PADDING_SIZE);
}
// extradata will be freed by av_free() in avcodec_free_context()
e->codec_ctx->extradata = (uint8_t*)av_mallocz(e->codec_config_len + AV_INPUT_BUFFER_PADDING_SIZE);
e->codec_ctx->extradata_size = e->codec_config_len;
memcpy(e->codec_ctx->extradata, e->codec_config, e->codec_config_len);
memset(e->codec_ctx->extradata + e->codec_ctx->extradata_size, 0, AV_INPUT_BUFFER_PADDING_SIZE);
err = avcodec_parameters_from_context(e->out_stream->codecpar, e->codec_ctx);
assert(err >= 0);

Loading…
Cancel
Save