Vic*_*hoy 11 compiler-optimization swift5 xcode11.4
我们的应用程序在 Xcode 11.4 编译的 os 10.3.3 10.3.4、iPhone 5c /5 iPad4 (armv7s 32) 上崩溃,快速优化。我们发现 PC 寄存器指向一个没有虚拟地址和堆栈信息的空地址。如果我们关闭 swift 优化,它会起作用。
那么有没有人找到问题和任何解决方案?
可以肯定,它与Xcode 11.4 swift优化有关。
我在这里找到了同样的问题。https://www.reddit.com/r/iOSProgramming/comments/frcpsc/xcode_114_builds_crashes_on_ios_10/
Incident Identifier: 2224949E-E5E3-479C-9B08-4FD1473144B3
CrashReporter Key: 052c9a28855da965790a6dcc0885097a66ee4eff
Hardware Model: iPad3,4
Process: AAAAA [34872]
Path: /private/var/containers/Bundle/Application/xxxxxx....
Identifier: com.xxx.xxxxx
Version: xxxx
Code Type: ARM (Native)
Role: Non UI
Parent Process: launchd [1]
Coalition: com.xxx.xxxxx [1932]
Date/Time: 2020-03-30 22:42:49.2564 +xxx
Launch Time: 2020-03-30 22:42:47.0000 +xxx
OS Version: iPhone OS 10.3.3 (14G60)
Report Version: 104
Exception Type: EXC_BAD_ACCESS (SIGBUS)
Exception Subtype: KERN_PROTECTION_FAILURE at 0x015fa500
Triggered by Thread: 0
Thread 0 name:
Thread 0 Crashed:
0 ??? 0x015fa500 0 + 23045376
Run Code Online (Sandbox Code Playgroud)
Vic*_*hoy 15
经过日志和指令调试等大量分析,我确定这是xcode 11.4 swift编译器优化的错误。详细地说,优化会在打开新函数堆栈帧时导致堆栈指针 (fp) 混乱。我在下面展示它。
这是type metadata accessor for myapp.MainViewController at <compiler-generated>编译器在我们的主视图控制器中生成的辅助函数。
<+0>、<+4> 是错误的。它应该是
0x6cd85c <+0>: push.w {r4, r5, r6, r7, lr}
0x6cd860 <+4>: add r7, sp, #0xc
Run Code Online (Sandbox Code Playgroud)
r7 是 fp。所以错误指令<+0>不保存r7,而<+4>子ins使得r7比sp低很多,导致整个堆栈混乱。所以很明显是错误的。
这就是 ins 执行时发生的情况。
由于 fp 错误,整个堆栈丢失。
我们也可以在 xcode 11.3 中验证。
<+0> <+2> 和我们上面的预期是一样的。
因此,我们也必须降级到 xcode 11.3,并使用运行时反射来适应应在 xcode 11.4 中调用的新 iOS SDK 功能。
我们还在装有 iOS 9 或 10 的旧 32 位设备上遇到了多次崩溃。使用 Xcode 11.3.1 重新编译修复了我的情况下的这些随机崩溃...
此主题还有一个开放的 Bug,位于https://bugs.swift.org/browse/SR-12511
| 归档时间: |
|
| 查看次数: |
2031 次 |
| 最近记录: |