aboutsummaryrefslogtreecommitdiff
path: root/llvm/test/tools/llvm-readobj/COFF/arm64-unwind-pac.s
blob: b6e051908c88b32a3f0e8e7ed933e0a113ee8af1 (plain)
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
// REQUIRES: aarch64-registered-target
// RUN: llvm-mc -filetype=obj -triple aarch64-windows %s -o %t.o
// RUN: llvm-readobj --unwind %t.o | FileCheck --strict-whitespace %s

// CHECK:            Prologue [
// CHECK-NEXT:         0xd600              ; stp x19, lr, [sp, #0]
// CHECK-NEXT:         0x01                ; sub sp, #16
// CHECK-NEXT:         0xfc                ; pacibsp
// CHECK-NEXT:         0xe4                ; end
// CHECK-NEXT:       ]
// CHECK-NEXT:       Epilogue [
// CHECK-NEXT:         0x01                ; add sp, #16
// CHECK-NEXT:         0xfc                ; autibsp
// CHECK-NEXT:         0xe4                ; end
// CHECK-NEXT:       ]

.section .pdata,"dr"
        .long func@IMGREL
        .long "$unwind$func"@IMGREL

        .text
        .globl  func
func:
        pacibsp
        sub sp, sp, #16
        stp x19, x30, [sp]
        mov w19, w1
        blr x0
        mov w0, w19
        ldp x19, x30, [sp]
        add sp, sp, #16
        autibsp
        ret

.section .xdata,"dr"
"$unwind$func":
.byte 0x0a, 0x00, 0xa0, 0x10
.byte 0xd6, 0x00, 0x01, 0xfc
.byte 0xe4, 0xe3, 0xe3, 0xe3