aboutsummaryrefslogtreecommitdiffstats
diff options
context:
space:
mode:
authorJames Zern <jzern@google.com>2011-02-04 18:29:46 -0800
committerRonald S. Bultje <rsbultje@gmail.com>2011-02-05 18:34:17 -0500
commit60ff9de6ffa740e0df8c2a019c72e2d332b9788d (patch)
tree81fb395b2d390616f03b20f3a0ea0e6d29260a95
parent3a6a9cdf5b8e4c4514e483484ef1f57b07ee16f2 (diff)
downloadffmpeg-60ff9de6ffa740e0df8c2a019c72e2d332b9788d.tar.gz
cmdutils: fix codec-specific options from preset
Using a preset file caused the address of a stack variable to be stored in opt_names/values. This change causes the strings to be dup'd then freed in uninit_opts. Signed-off-by: Ronald S. Bultje <rsbultje@gmail.com>
-rw-r--r--cmdutils.c12
1 files changed, 10 insertions, 2 deletions
diff --git a/cmdutils.c b/cmdutils.c
index 99e4c38af1..c68f37fe20 100644
--- a/cmdutils.c
+++ b/cmdutils.c
@@ -78,6 +78,14 @@ void uninit_opts(void)
#if CONFIG_SWSCALE
av_freep(&sws_opts);
#endif
+ for (i = 0; i < opt_name_count; i++) {
+ //opt_values are only stored for codec-specific options in which case
+ //both the name and value are dup'd
+ if (opt_values[i]) {
+ av_freep(&opt_names[i]);
+ av_freep(&opt_values[i]);
+ }
+ }
av_freep(&opt_names);
av_freep(&opt_values);
}
@@ -270,9 +278,9 @@ int opt_default(const char *opt, const char *arg){
//FIXME we should always use avcodec_opts, ... for storing options so there will not be any need to keep track of what i set over this
opt_values= av_realloc(opt_values, sizeof(void*)*(opt_name_count+1));
- opt_values[opt_name_count]= o ? NULL : arg;
+ opt_values[opt_name_count]= o ? NULL : av_strdup(arg);
opt_names= av_realloc(opt_names, sizeof(void*)*(opt_name_count+1));
- opt_names[opt_name_count++]= o ? o->name : opt;
+ opt_names[opt_name_count++]= o ? o->name : av_strdup(opt);
if ((*avcodec_opts && avcodec_opts[0]->debug) || (avformat_opts && avformat_opts->debug))
av_log_set_level(AV_LOG_DEBUG);