DEXT 在 macOS 10.15.7 上崩溃

问题描述

我在 macOS 11 上成功构建并运行了 Apple 的示例 Communicateing Between a DriverKit Extension and a Client App,这意味着我可以安装 DEXT 并通过它的客户端控制它。 不过,在 macOS 10.15.7 上,我可以构建它并安装 DEXT,但 DEXT 崩溃了。

systemextensionsclt 的输出

systemextensionsctl list
1 extension(s)
--- com.apple.system_extension.driver_extension enabled active  teamID  bundleID (version)  name    [state]
*   *   -   com.example.apple-samplecode.dext-to-user-client.driver (1.0/1) com.example.apple-samplecode.dext-to-user-client.driver [activated enabled]

但是当操作系统尝试运行它时,DEXT 本身显然会崩溃:

Dyld Error Message:
  Symbol not found: __ZN8OSAction18CreateWithTypeNameEP8OSObjectyymP8OsstringPPS_
  Referenced from: /Library/SystemExtensions/*/com.example.apple-samplecode.dext-to-user-client.driver (which was built for Mac OS X 19.0)
  Expected in: /System/DriverKit/System/Library/Frameworks/DriverKit.framework/DriverKit

Thread 2 Crashed:: dispatch queue: NullDriverUserClient-Default
0   dyld                            0x000000011bb05ede __abort_with_payload + 10
1   dyld                            0x000000011bb2f55d abort_with_payload_wrapper_internal + 80
2   dyld                            0x000000011bb2f58f abort_with_payload + 9
3   dyld                            0x000000011bb2cbf4 dyld::halt(char const*) + 463
4   dyld                            0x000000011bab4bc3 dyld::fastBindLazySymbol(ImageLoader**,unsigned long) + 140
5   libdyld.dylib                   0x000000010dcf5936 dyld_stub_binder + 282
6   ???                             0x000000010da6f1a0 0 + 4524011936
7   com.example.apple-samplecode.dext-to-user-client.driver 0x000000010da64c41 NullDriverUserClient::Start_Impl(IOService*) + 705 (NullDriverUserClient.cpp:223)
8   com.apple.DriverKit             0x000000010dae09e4 IOService::Start_Invoke(IORPC,OSMetaClassBase*,int (*)(OSMetaClassBase*,IOService*)) + 86
9   com.example.apple-samplecode.dext-to-user-client.driver 0x000000010da67f75 NullDriverUserClient::_dispatch(NullDriverUserClient*,IORPC) + 293 (NullDriverUserClient.iig.cpp:180)
10  com.example.apple-samplecode.dext-to-user-client.driver 0x000000010da67e3d NullDriverUserClient::dispatch(IORPC) + 77 (NullDriverUserClient.iig.cpp:167)
11  com.apple.DriverKit             0x000000010dacd241 invocation function for block in OSMetaClassBase::Invoke(IORPC) + 117

注意:同一构建的二进制文件在 macOS 11 上运行良好。

我在 macOS 11.4 (20F71) 和 10.15.7 (19H1217) 上使用 Xcode 12.4 (12D4e)。 理想情况下,DEXT 还应在 macOS 10.15 上运行。

这是 macOS 10.15.7 上 DriverKit.framework 中的错误还是我设置项目的方式不正确?

解决方法

缺少的符号 __ZN8OSAction18CreateWithTypeNameEP8OSObjectyymP8OSStringPPS_ 指的是 OSAction::CreateWithTypeName(OSObject*,unsigned long long,unsigned long,OSString*,OSAction**)This function is only available from Big Sur/macOS 11.0/DriverKit 20.0 onwards.

您可能应该为回调类型的 Create 使用自动生成的 OSAction 函数,否则使用旧的 OSAction::Create 函数。

相关问答

Selenium Web驱动程序和Java。元素在(x,y)点处不可单击。其...
Python-如何使用点“。” 访问字典成员?
Java 字符串是不可变的。到底是什么意思?
Java中的“ final”关键字如何工作?(我仍然可以修改对象。...
“loop:”在Java代码中。这是什么,为什么要编译?
java.lang.ClassNotFoundException:sun.jdbc.odbc.JdbcOdbc...