| ; RUN: llc -mtriple=aarch64-linux-gnu -global-isel=0 -fast-isel=0 -verify-machineinstrs \ |
| ; RUN: -relocation-model=pic -mattr=+pauth -mattr=+fpac %s -o - | FileCheck %s --check-prefixes=CHECK,NOTRAP |
| ; RUN: llc -mtriple=aarch64-linux-gnu -global-isel=0 -fast-isel=0 -verify-machineinstrs \ |
| ; RUN: -relocation-model=pic -mattr=+pauth %s -o - | FileCheck %s --check-prefixes=CHECK,TRAP |
| |
| ; RUN: llc -mtriple=aarch64-linux-gnu -global-isel=0 -fast-isel=1 -verify-machineinstrs \ |
| ; RUN: -relocation-model=pic -mattr=+pauth -mattr=+fpac %s -o - | FileCheck %s --check-prefixes=CHECK,NOTRAP |
| ; RUN: llc -mtriple=aarch64-linux-gnu -global-isel=0 -fast-isel=1 -verify-machineinstrs \ |
| ; RUN: -relocation-model=pic -mattr=+pauth %s -o - | FileCheck %s --check-prefixes=CHECK,TRAP |
| |
| ; RUN: llc -mtriple=aarch64-linux-gnu -global-isel=1 -global-isel-abort=1 -verify-machineinstrs \ |
| ; RUN: -relocation-model=pic -mattr=+pauth -mattr=+fpac %s -o - | FileCheck %s --check-prefixes=CHECK,NOTRAP |
| ; RUN: llc -mtriple=aarch64-linux-gnu -global-isel=1 -global-isel-abort=1 -verify-machineinstrs \ |
| ; RUN: -relocation-model=pic -mattr=+pauth %s -o - | FileCheck %s --check-prefixes=CHECK,TRAP |
| |
| ;; Note: for FastISel, we fall back to SelectionDAG |
| |
| @var = global i32 0 |
| |
| define i32 @get_globalvar() { |
| ; CHECK-LABEL: get_globalvar: |
| ; CHECK: adrp x17, :got_auth:var |
| ; CHECK-NEXT: add x17, x17, :got_auth_lo12:var |
| ; NOTRAP-NEXT: ldr x8, [x17] |
| ; NOTRAP-NEXT: autda x8, x17 |
| ; TRAP-NEXT: ldr x16, [x17] |
| ; TRAP-NEXT: autda x16, x17 |
| ; TRAP-NEXT: mov x17, x16 |
| ; TRAP-NEXT: xpacd x17 |
| ; TRAP-NEXT: cmp x16, x17 |
| ; TRAP-NEXT: b.eq .Lauth_success_0 |
| ; TRAP-NEXT: brk #0xc472 |
| ; TRAP-NEXT: .Lauth_success_0: |
| ; TRAP-NEXT: mov x8, x16 |
| ; CHECK-NEXT: ldr w0, [x8] |
| ; CHECK-NEXT: ret |
| |
| %val = load i32, ptr @var |
| ret i32 %val |
| } |
| |
| define ptr @get_globalvaraddr() { |
| ; CHECK-LABEL: get_globalvaraddr: |
| ; CHECK: adrp x17, :got_auth:var |
| ; CHECK-NEXT: add x17, x17, :got_auth_lo12:var |
| ; NOTRAP-NEXT: ldr x0, [x17] |
| ; NOTRAP-NEXT: autda x0, x17 |
| ; TRAP-NEXT: ldr x16, [x17] |
| ; TRAP-NEXT: autda x16, x17 |
| ; TRAP-NEXT: mov x17, x16 |
| ; TRAP-NEXT: xpacd x17 |
| ; TRAP-NEXT: cmp x16, x17 |
| ; TRAP-NEXT: b.eq .Lauth_success_1 |
| ; TRAP-NEXT: brk #0xc472 |
| ; TRAP-NEXT: .Lauth_success_1: |
| ; TRAP-NEXT: mov x0, x16 |
| ; CHECK-NEXT: ret |
| |
| %val = load i32, ptr @var |
| ret ptr @var |
| } |
| |
| declare i32 @foo() |
| |
| define ptr @resign_globalfunc() { |
| ; CHECK-LABEL: resign_globalfunc: |
| ; CHECK: adrp x17, :got_auth:foo |
| ; CHECK-NEXT: add x17, x17, :got_auth_lo12:foo |
| ; CHECK-NEXT: ldr x16, [x17] |
| ; CHECK-NEXT: autia x16, x17 |
| ; TRAP-NEXT: mov x17, x16 |
| ; TRAP-NEXT: xpaci x17 |
| ; TRAP-NEXT: cmp x16, x17 |
| ; TRAP-NEXT: b.eq .Lauth_success_2 |
| ; TRAP-NEXT: brk #0xc470 |
| ; TRAP-NEXT: .Lauth_success_2: |
| ; CHECK-NEXT: mov x17, #42 |
| ; CHECK-NEXT: pacia x16, x17 |
| ; CHECK-NEXT: mov x0, x16 |
| ; CHECK-NEXT: ret |
| |
| ret ptr ptrauth (ptr @foo, i32 0, i64 42) |
| } |
| |
| define ptr @resign_globalvar() { |
| ; CHECK-LABEL: resign_globalvar: |
| ; CHECK: adrp x17, :got_auth:var |
| ; CHECK-NEXT: add x17, x17, :got_auth_lo12:var |
| ; CHECK-NEXT: ldr x16, [x17] |
| ; CHECK-NEXT: autda x16, x17 |
| ; TRAP-NEXT: mov x17, x16 |
| ; TRAP-NEXT: xpacd x17 |
| ; TRAP-NEXT: cmp x16, x17 |
| ; TRAP-NEXT: b.eq .Lauth_success_3 |
| ; TRAP-NEXT: brk #0xc472 |
| ; TRAP-NEXT: .Lauth_success_3: |
| ; CHECK-NEXT: mov x17, #43 |
| ; CHECK-NEXT: pacdb x16, x17 |
| ; CHECK-NEXT: mov x0, x16 |
| ; CHECK-NEXT: ret |
| |
| ret ptr ptrauth (ptr @var, i32 3, i64 43) |
| } |
| |
| define ptr @resign_globalvar_offset() { |
| ; CHECK-LABEL: resign_globalvar_offset: |
| ; CHECK: adrp x17, :got_auth:var |
| ; CHECK-NEXT: add x17, x17, :got_auth_lo12:var |
| ; CHECK-NEXT: ldr x16, [x17] |
| ; CHECK-NEXT: autda x16, x17 |
| ; TRAP-NEXT: mov x17, x16 |
| ; TRAP-NEXT: xpacd x17 |
| ; TRAP-NEXT: cmp x16, x17 |
| ; TRAP-NEXT: b.eq .Lauth_success_4 |
| ; TRAP-NEXT: brk #0xc472 |
| ; TRAP-NEXT: .Lauth_success_4: |
| ; CHECK-NEXT: add x16, x16, #16 |
| ; CHECK-NEXT: mov x17, #44 |
| ; CHECK-NEXT: pacda x16, x17 |
| ; CHECK-NEXT: mov x0, x16 |
| ; CHECK-NEXT: ret |
| |
| ret ptr ptrauth (ptr getelementptr (i8, ptr @var, i64 16), i32 2, i64 44) |
| } |
| |
| !llvm.module.flags = !{!0} |
| !0 = !{i32 8, !"ptrauth-elf-got", i32 1} |