diff --git a/cmdutils.c b/cmdutils.c
index f696700142cfe113b4a4ea30756616be24087117..248462fd8018b4564133cba15e53668b459584b1 100644
--- a/cmdutils.c
+++ b/cmdutils.c
@@ -528,6 +528,17 @@ int opt_loglevel(void *optctx, const char *opt, const char *arg)
     return 0;
 }
 
+int opt_report_file(void *optctx, const char *opt, const char *arg)
+{
+    report_file = fopen(arg, "w");
+    if (!report_file) {
+        av_log(NULL, AV_LOG_ERROR, "Failed to open report \"%s\": %s\n",
+               arg, strerror(errno));
+        return AVERROR(errno);
+    }
+    return 0;
+}
+
 int opt_report(const char *opt)
 {
     char filename[64];
diff --git a/cmdutils.h b/cmdutils.h
index 3885d9412c9e57eef1c85d456fe69ed2736f667c..4624f195e131967686dd8f4f0f5002708adae1d2 100644
--- a/cmdutils.h
+++ b/cmdutils.h
@@ -84,6 +84,8 @@ int opt_loglevel(void *optctx, const char *opt, const char *arg);
 
 int opt_report(const char *opt);
 
+int opt_report_file(void *optctx, const char *opt, const char *arg);
+
 int opt_max_alloc(void *optctx, const char *opt, const char *arg);
 
 int opt_cpuflags(void *optctx, const char *opt, const char *arg);
diff --git a/cmdutils_common_opts.h b/cmdutils_common_opts.h
index bfd71feb7dbbec29a73069c71af765a605d3cb56..2e1cf7db0343d7a7de8fb3fdaf779da1eaf9cd06 100644
--- a/cmdutils_common_opts.h
+++ b/cmdutils_common_opts.h
@@ -19,5 +19,6 @@
     { "debug"      , HAS_ARG,  {.func_arg = opt_codec_debug},   "set debug flags", "flags" },
     { "fdebug"     , HAS_ARG,  {.func_arg = opt_codec_debug},   "set debug flags", "flags" },
     { "report"     , 0,        {(void*)opt_report}, "generate a report" },
+    { "report_file", HAS_ARG,  {.func_arg = opt_report_file},   "filename for storing the report" },
     { "max_alloc"  , HAS_ARG,  {.func_arg = opt_max_alloc},     "set maximum size of a single allocated block", "bytes" },
     { "cpuflags"   , HAS_ARG | OPT_EXPERT, {.func_arg = opt_cpuflags}, "force specific cpu flags", "flags" },