#550: additional logging and search paths for ffmpeg + #549: bustage fix

This commit is contained in:
Cameron Kaiser 2019-03-16 23:22:10 -07:00
parent 284830e5ef
commit 4922145621
3 changed files with 40 additions and 9 deletions

View File

@ -5351,6 +5351,7 @@ WINNT|Darwin|Android)
;;
esac
MOZ_FFMPEG=1
MOZ_ARG_DISABLE_BOOL(ffmpeg,
[ --disable-ffmpeg Disable FFmpeg for fragmented H264/AAC decoding],
MOZ_FFMPEG=,

View File

@ -11,6 +11,7 @@
#include "prlink.h"
#ifdef XP_DARWIN
#include "prenv.h"
#include <dlfcn.h>
#include <libgen.h>
#include <mach-o/dyld.h>
@ -81,19 +82,44 @@ FFmpegRuntimeLinker::Link()
for (size_t i = 0; i < ArrayLength(sLibs); i++) {
const char* lib = sLibs[i];
#ifdef XP_DARWIN
/* Loading FFMPEG on Mac OS X (macOS is a typo) fails because mozilla
searches for sybols defined in libavutil with a handle to libavcodec.
This is due to the fact that NSPR uses NSAddressOfSymbol & cie who limits
its researches only to libavcodec and not its dependencies. We don't have
/* OlgaTPark's ffmpeg loader hack.
Loading ffmpeg on Darwin fails because by default Mozilla
searches for symbols defined in libavutil with a handle to libavcodec.
This is due to the fact that NSPR uses NSAddressOfSymbol et al. that
limit search only to libavcodec and not its dependencies. We don't have
this issue with dlsym(). */
if (!(sLinkedLib = dlopen(lib, RTLD_NOW | RTLD_LOCAL))) {
/* Bonus time: if we don't find libavcodec in standard locations, we look
if our venerable FFMPEG's libraries are in the same folder as XUL. */
if our venerable ffmpeg's libraries are in the same folder as XUL. */
char *libFullPath = NULL;
if (asprintf(&libFullPath, "%s/%s", execDir, lib) > 0 && libFullPath)
if (asprintf(&libFullPath, "%s/%s", execDir, lib) > 0 && libFullPath) {
#if DEBUG
fprintf(stderr, "TenFourFox looking for FFmpeg: %s\n", libFullPath);
#endif
sLinkedLib = dlopen(libFullPath, RTLD_NOW | RTLD_LOCAL);
#if DEBUG
if (!sLinkedLib)
fprintf(stderr, "Failed to load %s: %s\n", libFullPath, dlerror());
#endif
free(libFullPath);
}
// Try also finding the library in ~/Library/ffmpeg.
if (!sLinkedLib &&
PR_GetEnv("HOME") &&
asprintf(&libFullPath, "%s/Library/ffmpeg/%s", PR_GetEnv("HOME"), lib)
> 0 && libFullPath) {
#if DEBUG
fprintf(stderr, "TenFourFox looking for FFmpeg: %s\n", libFullPath);
#endif
sLinkedLib = dlopen(libFullPath, RTLD_NOW | RTLD_LOCAL);
#if DEBUG
if (!sLinkedLib)
fprintf(stderr, "Failed to load %s: %s\n", libFullPath, dlerror());
#endif
free(libFullPath);
}
}
#else
PRLibSpec lspec;
lspec.type = PR_LibSpec_Pathname;
@ -104,6 +130,7 @@ FFmpegRuntimeLinker::Link()
if (Bind(lib)) {
sLib = lib;
sLinkStatus = LinkStatus_SUCCEEDED;
NS_WARNING("FFmpeg successfully linked to TenFourFox");
return true;
}
// Shouldn't happen but if it does then we try the next lib..
@ -119,6 +146,7 @@ FFmpegRuntimeLinker::Link()
Unlink();
fprintf(stderr, "Warning: FFmpeg could not be linked into TenFourFox. H.264 video will not be available.\n");
sLinkStatus = LinkStatus_FAILED;
return false;
}
@ -232,6 +260,7 @@ FFmpegRuntimeLinker::Unlink()
{
if (sLinkedLib) {
#ifdef XP_DARWIN
NS_WARNING("FFmpeg Runtime unlinked");
dlclose(sLinkedLib);
#else
PR_UnloadLibrary(sLinkedLib);

View File

@ -38,6 +38,7 @@
#include "nsXPCOM.h"
#include "nsApplescriptService.h"
#include "nsString.h"
#ifdef XP_MACOSX
#include "MacScripting.h"
@ -167,7 +168,7 @@ nsApplescriptService::RunScriptInTabAtIndexInWindow(uint32_t index,
return tabCallback->RunScriptInTabAtIndexInWindow(index, window_index, script, result, ok);
}
*ok = false;
result = NULL;
result.Truncate();
return NS_OK;
}