summaryrefslogtreecommitdiffstats
diff options
context:
space:
mode:
-rw-r--r--demux/demux_lavf.c2
-rw-r--r--sub/lavc_conv.c9
2 files changed, 8 insertions, 3 deletions
diff --git a/demux/demux_lavf.c b/demux/demux_lavf.c
index 1b3105170d..8cd525b685 100644
--- a/demux/demux_lavf.c
+++ b/demux/demux_lavf.c
@@ -282,6 +282,8 @@ static void convert_charset(struct demuxer *demuxer)
// libavformat transparently converts UTF-16 to UTF-8
if (!mp_charset_is_utf16(cp) && !mp_charset_is_utf8(cp)) {
bstr conv = mp_iconv_to_utf8(demuxer->log, data, cp, MP_ICONV_VERBOSE);
+ if (conv.start && conv.start != data.start)
+ talloc_steal(alloc, conv.start);
if (conv.start)
data = conv;
}
diff --git a/sub/lavc_conv.c b/sub/lavc_conv.c
index 42f9563391..f6c9b5abe2 100644
--- a/sub/lavc_conv.c
+++ b/sub/lavc_conv.c
@@ -78,7 +78,10 @@ struct lavc_conv *lavc_conv_create(struct mp_log *log, const char *codec_name,
if (!avctx)
goto error;
avctx->extradata_size = extradata_len;
- avctx->extradata = talloc_memdup(priv, extradata, extradata_len);
+ avctx->extradata = av_malloc(extradata_len);
+ if (!avctx->extradata)
+ goto error;
+ memcpy(avctx->extradata, extradata, extradata_len);
if (avcodec_open2(avctx, codec, NULL) < 0)
goto error;
// Documented as "set by libavcodec", but there is no other way
@@ -264,7 +267,7 @@ void lavc_conv_reset(struct lavc_conv *priv)
void lavc_conv_uninit(struct lavc_conv *priv)
{
- avcodec_close(priv->avctx);
- av_free(priv->avctx);
+ avsubtitle_free(&priv->cur);
+ avcodec_free_context(&priv->avctx);
talloc_free(priv);
}