macos下程序报Symbol not found _VTRegisterSuppIementalVideoDecoderlfAvailable

 electronApp在macOS10.15.7系统上启动报错如上,是加载libLiveTranslate.dylib库失败了。

在/System/Library/Frameworks/VideoToolbox.framework/Versions/A/VideoToolbox里找不到符号:_VTRegisterSuppIementalVideoDecoderlfAvailable。

1)首先查看libLiveTranslate.dylib库依赖了哪些库?

otool -L -X -v libLiveTranslate.dylib

可以看到确实依赖了 /System/Library/Frameworks/VideoToolbox.framework/Versions/A/VideoToolbox库,这个是系统自带的。

2)查看libLiveTranslate.dylib库对_VTRegisterSuppIementalVideoDecoderlfAvailable的引用

nm -m libLiveTranslate.dylib| grep VTRegister

上面显示是从VideoToolbox链接进来的。

3) libLiveTranslate.dylib库因为静态链接了ffmpeg库,所以间接需要链接VideoToolbox库,所以在ffmpeg源码里搜索_VTRegisterSuppIementalVideoDecoderlfAvailable使用的地方

 首先if (__builtin_available(macOS 11.0, *))是编译时判断sdk是否是11.0以上,我的sdk是macOS 13.1。通过下面查看

xcodebuild -showsdks

所以,下面这段代码如果为true就会去调用VTRegisterSupplementalVideoDecoderIfAvailable。

#if defined(MAC_OS_VERSION_11_0) && !TARGET_OS_IPHONE && (MAC_OS_X_VERSION_MAX_ALLOWED >= MAC_OS_VERSION_11_0) && AV_HAS_BUILTIN(__builtin_available)

上面这几个宏是定义在下面头文件,
#include <AvailabilityMacros.h>

这几个宏的值应该是由编译时指定的最小macOS版本决定的,具体内部逻辑没细查。

4)查看libLiveTranslate.dylib库链接的ffmpeg静态库支持的最小系统版本

otool -l libavcodec.a| grep -E "(minos|sdk)"

 现在需要编译ffmpeg,让它支持最低macOS10.15。

5)macOS下编译支持最低macOS10.15版本的ffmpeg静态库,参考的GitHub - ColorsWind/FFmpeg-macOS: FFmpeg shared universal binaries (x86_64 and arm64) for macOS.

make_compile.py修改如下:

make_universal.py修改如下: 

执行完make_universal.py后,在ffmpeg/install_universal/lib目录下 找到了需要的lib,再执行上面的命令,可以看到minos变成10.15.

6)编译支持最低macOS10.15版本的liblmp3lame静态库,这个是mp3的编解码器。 

参考的 MacOS 编译 x86_64/arm64 lame - 知乎

对build-lame.sh做了如下修改 

编译完后在lame-osx-build/fat-lame/lib 找到需要的libmp3lame.a

7)编译支持最低macOS10.15版本的openssl静态库

参考Mac下openssl的编译和使用_mac openssl-CSDN博客

重新编译libLiveTranslate.dylib库,最后验证这个问题解决了。

8)查看符号表,第一个带weak的是正确的

  • 25
    点赞
  • 17
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值