应用程序崩溃,Xcode11.4,iOS 10.3.3 10.3.4,iPhone 5c /5 iPad4 (armv7s)

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 功能。


nig*_*ann 2

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

此主题还有一个开放的 Bug,位于https://bugs.swift.org/browse/SR-12511