mirror of
https://github.com/mpv-player/mpv
synced 2025-01-24 08:33:34 +00:00
player: fatal error if linked and compiled FFmpeg versions mismatch
We don't support this anymore. This tries to exit in a controlled way after command line options are applied in order to honor logging options and, in case of libmpv, not to kill the host. Not sure if it would be better to just vomit text to stderr and call abort().
This commit is contained in:
parent
3738bfb451
commit
d057e7a142
@ -148,6 +148,9 @@ The reason for not supporting this is because it creates far too much complexity
|
||||
with little to no benefit, coupled with absurd and unusable FFmpeg API
|
||||
artifacts.
|
||||
|
||||
Newer mpv versiosn will refuse to start if runtime and compile time FFmpeg
|
||||
library versions mismatch.
|
||||
|
||||
## Release cycle
|
||||
|
||||
Every other month, an arbitrary git snapshot is made, and is assigned
|
||||
|
@ -189,7 +189,7 @@ struct lib {
|
||||
unsigned runv;
|
||||
};
|
||||
|
||||
void print_libav_versions(struct mp_log *log, int v)
|
||||
bool print_libav_versions(struct mp_log *log, int v)
|
||||
{
|
||||
const struct lib libs[] = {
|
||||
{"libavutil", LIBAVUTIL_VERSION_INT, avutil_version()},
|
||||
@ -222,14 +222,7 @@ void print_libav_versions(struct mp_log *log, int v)
|
||||
mp_msg(log, v, "%s version: %s\n", LIB_PREFIX, av_version_info());
|
||||
#endif
|
||||
|
||||
if (mismatch) {
|
||||
// Using mismatched libraries can be legitimate, but even then it's
|
||||
// a bad idea. We don't acknowledge its usefulness and stability.
|
||||
mp_warn(log, "Warning: mpv was compiled against a different version of "
|
||||
"%s than the shared\nlibrary it is linked against. This is "
|
||||
"most likely a broken build\nand misbehavior and crashes are "
|
||||
"to be expected.\n", LIB_PREFIX);
|
||||
}
|
||||
return !mismatch;
|
||||
}
|
||||
|
||||
#undef V
|
||||
|
@ -1,8 +1,11 @@
|
||||
#ifndef MP_AV_LOG_H
|
||||
#define MP_AV_LOG_H
|
||||
|
||||
#include <stdbool.h>
|
||||
|
||||
struct mpv_global;
|
||||
struct mp_log;
|
||||
void init_libav(struct mpv_global *global);
|
||||
void uninit_libav(struct mpv_global *global);
|
||||
void print_libav_versions(struct mp_log *log, int v);
|
||||
bool print_libav_versions(struct mp_log *log, int v);
|
||||
#endif
|
||||
|
@ -418,6 +418,18 @@ int mp_initialize(struct MPContext *mpctx, char **options)
|
||||
if (handle_help_options(mpctx))
|
||||
return -2;
|
||||
|
||||
if (!print_libav_versions(mp_null_log, 0)) {
|
||||
// Using mismatched libraries can be legitimate, but even then it's
|
||||
// a bad idea. We don't acknowledge its usefulness and stability.
|
||||
print_libav_versions(mpctx->log, MSGL_FATAL);
|
||||
MP_FATAL(mpctx, "\nmpv was compiled against a different version of "
|
||||
"FFmpeg/Libav than the shared\nlibrary it is linked against. "
|
||||
"This is most likely a broken build and could\nresult in "
|
||||
"misbehavior and crashes.\n\nmpv does not support this"
|
||||
"configuration and will not run - rebuild mpv instead.\n");
|
||||
return -1;
|
||||
}
|
||||
|
||||
if (opts->dump_stats && opts->dump_stats[0]) {
|
||||
if (mp_msg_open_stats_file(mpctx->global, opts->dump_stats) < 0)
|
||||
MP_ERR(mpctx, "Failed to open stats file '%s'\n", opts->dump_stats);
|
||||
|
Loading…
Reference in New Issue
Block a user