-
Notifications
You must be signed in to change notification settings - Fork 10.5k
/
Copy pathsymbolication.swift
45 lines (37 loc) · 1.74 KB
/
symbolication.swift
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
// RUN: %target-build-swift %s -sanitize=address -g -o %t
// RUN: env %env-ASAN_OPTIONS=abort_on_error=0 not %target-run %t 2>&1 | %FileCheck %s -check-prefix=OOP
// RUN: env %env-ASAN_OPTIONS=abort_on_error=0,external_symbolizer_path= not %target-run %t 2>&1 | %FileCheck %s -check-prefix=IP
// REQUIRES: executable_test
// REQUIRES: asan_runtime
// REQUIRES: VENDOR=apple
// REQUIRES: rdar107669811
// We copy the binary but not the corresponding .dSYM for remote runs (e.g.,
// on-device testing), and hence online symbolication fails.
// UNSUPPORTED: remote_run
// The 32-bit iOS simulator is old and has an outdated version of atos that
// can't demangle current Swift symbol names (the mangling scheme has changed).
// UNSUPPORTED: CPU=i386 && OS=ios
// Check that Sanitizer reports are properly symbolicated on Apple platforms,
// both out-of-process (via `atos`) and when falling back to in-process
// symbolication. Note that `atos` also demangles Swift symbol names.
@inline(never)
func foo() {
let x = UnsafeMutablePointer<Int>.allocate(capacity: 1)
x.deallocate()
print(x.pointee)
}
@inline(never)
func bar() {
foo()
print("Prevent tail call optimization")
}
bar()
// Out-of-process
// FIXME: There is no instruction with the location of the failing `.` operator and it's used inside implicit setup code, thus the crash is associated with the previous line.
// OOP: #0 0x{{[0-9a-f]+}} in foo() symbolication.swift
// OOP-NEXT: #1 0x{{[0-9a-f]+}} in bar() symbolication.swift:[[@LINE-9]]
// OOP-NEXT: #2 0x{{[0-9a-f]+}} in main symbolication.swift:[[@LINE-6]]
// In-process
// IP: #0 0x{{[0-9a-f]+}} in main.foo() -> ()+0x
// IP-NEXT: #1 0x{{[0-9a-f]+}} in main.bar() -> ()+0x
// IP-NEXT: #2 0x{{[0-9a-f]+}} in main+0x