11

我们的应用在 Xcode 11.4 编译的 os 10.3.3 10.3.4、iPhone 5c /5 iPad4 (armv7s 32) 上崩溃,开启了快速优化。我们发现PC寄存器指向一个没有虚拟地址和堆栈信息的空洞地址。如果我们关闭快速优化,它会起作用。

那么有没有人发现问题和解决方案?

可以肯定,它与 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
4

3 回答 3

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

r7 是 fp。所以错误指令 <+0> 不保存 r7,而 <+4> sub ins 使 r7 比 sp 低很多,导致整个堆栈混乱。所以很明显是错的。

这就是 ins 执行时发生的情况。

前: 在此处输入图像描述

后: 在此处输入图像描述

由于 fp 错误,整个堆栈都会丢失。

我们也可以在 xcode 11.3 中验证这一点。 在此处输入图像描述 <+0> <+2> 与我们上面的预期相同。

所以我们也必须降级到 xcode 11.3 并使用运行时反射来适应应该在 xcode 11.4 中调用的新 iOS SDK 功能。

于 2020-04-15T07:34:21.997 回答
2

我们还在装有 iOS 9 或 10 的旧 32 位设备上遇到多次崩溃。在我的情况下,使用 Xcode 11.3.1 重新编译修复了这些随机崩溃...

在https://bugs.swift.org/browse/SR-12511上还有一个针对此主题的未解决的错误

于 2020-04-14T13:00:40.827 回答
1

这是在 Xcode 11.5 中为我们修复的。GM_Seed 自 5 月 18 日起可用。

https://developer.apple.com/services-account/download?path=/Developer_Tools/Xcode_11.5_GM_Seed/Xcode_11.5_GM_Seed.xip

于 2020-05-18T20:51:34.223 回答