; RUN: rm -rf %t && split-file %s %t && cd %t
;--- nodisc.ll
; RUN: llc -mtriple aarch64-elf -mattr=+pauth -filetype=asm -o - nodisc.ll | \
; RUN: FileCheck %s --check-prefix=ASM
; RUN: llc -mtriple aarch64-elf -mattr=+pauth -filetype=obj -o - nodisc.ll | \
; RUN: llvm-readelf -r -x .init_array -x .fini_array - | FileCheck %s --check-prefix=OBJ
; ASM: .section .init_array,"aw",@init_array
; ASM-NEXT: .p2align 3, 0x0
; ASM-NEXT: .xword foo@AUTH(ia,55764)
; ASM-NEXT: .section .fini_array,"aw",@fini_array
; ASM-NEXT: .p2align 3, 0x0
; ASM-NEXT: .xword bar@AUTH(ia,55764)
; OBJ: Relocation section '.rela.init_array' at offset 0x[[#]] contains 1 entries:
; OBJ-NEXT: Offset Info Type Symbol's Value Symbol's Name + Addend
; OBJ-NEXT: 0000000000000000 0000000700000244 R_AARCH64_AUTH_ABS64 0000000000000000 foo + 0
; OBJ: Relocation section '.rela.fini_array' at offset 0x[[#]] contains 1 entries:
; OBJ-NEXT: Offset Info Type Symbol's Value Symbol's Name + Addend
; OBJ-NEXT: 0000000000000000 0000000800000244 R_AARCH64_AUTH_ABS64 0000000000000004 bar + 0
; OBJ: Hex dump of section '.init_array':
; OBJ-NEXT: 0x00000000 00000000 d4d90000
; OBJ: Hex dump of section '.fini_array':
; OBJ-NEXT: 0x00000000 00000000 d4d90000
;; ^^^^ 0xD9D4: constant discriminator = 55764
;; ^^ 0x80: bits 61..60 key = IA; bit 63 addr disc = false
@llvm.global_ctors = appending global [1 x { i32, ptr, ptr }] [{ i32, ptr, ptr } { i32 65535, ptr ptrauth (ptr @foo, i32 0, i64 55764), ptr null }]
@llvm.global_dtors = appending global [1 x { i32, ptr, ptr }] [{ i32, ptr, ptr } { i32 65535, ptr ptrauth (ptr @bar, i32 0, i64 55764), ptr null }]
define void @foo() {
ret void
}
define void @bar() {
ret void
}
;--- disc.ll
; RUN: llc -mtriple aarch64-elf -mattr=+pauth -filetype=asm -o - disc.ll | \
; RUN: FileCheck %s --check-prefix=ASM-DISC
; RUN: llc -mtriple aarch64-elf -mattr=+pauth -filetype=obj -o - disc.ll | \
; RUN: llvm-readelf -r -x .init_array -x .fini_array - | FileCheck %s --check-prefix=OBJ-DISC
; ASM-DISC: .section .init_array,"aw",@init_array
; ASM-DISC-NEXT: .p2align 3, 0x0
; ASM-DISC-NEXT: .xword foo@AUTH(ia,55764,addr)
; ASM-DISC-NEXT: .section .fini_array,"aw",@fini_array
; ASM-DISC-NEXT: .p2align 3, 0x0
; ASM-DISC-NEXT: .xword bar@AUTH(ia,55764,addr)
; OBJ-DISC: Relocation section '.rela.init_array' at offset 0x[[#]] contains 1 entries:
; OBJ-DISC-NEXT: Offset Info Type Symbol's Value Symbol's Name + Addend
; OBJ-DISC-NEXT: 0000000000000000 0000000700000244 R_AARCH64_AUTH_ABS64 0000000000000000 foo + 0
; OBJ-DISC: Relocation section '.rela.fini_array' at offset 0x[[#]] contains 1 entries:
; OBJ-DISC-NEXT: Offset Info Type Symbol's Value Symbol's Name + Addend
; OBJ-DISC-NEXT: 0000000000000000 0000000800000244 R_AARCH64_AUTH_ABS64 0000000000000004 bar + 0
; OBJ-DISC: Hex dump of section '.init_array':
; OBJ-DISC-NEXT: 0x00000000 00000000 d4d90080
; OBJ-DISC: Hex dump of section '.fini_array':
; OBJ-DISC-NEXT: 0x00000000 00000000 d4d90080
;; ^^^^ 0xD9D4: constant discriminator = 55764
;; ^^ 0x80: bits 61..60 key = IA; bit 63 addr disc = true
@llvm.global_ctors = appending global [1 x { i32, ptr, ptr }] [{ i32, ptr, ptr } { i32 65535, ptr ptrauth (ptr @foo, i32 0, i64 55764, ptr inttoptr (i64 1 to ptr)), ptr null }]
@llvm.global_dtors = appending global [1 x { i32, ptr, ptr }] [{ i32, ptr, ptr } { i32 65535, ptr ptrauth (ptr @bar, i32 0, i64 55764, ptr inttoptr (i64 1 to ptr)), ptr null }]
define void @foo() {
ret void
}
define void @bar() {
ret void
}
;--- err1.ll
; RUN: not --crash llc -mtriple aarch64-elf -mattr=+pauth -filetype=asm -o - err1.ll 2>&1 | \
; RUN: FileCheck %s --check-prefix=ERR1
; ERR1: LLVM ERROR: unexpected address discrimination value for ctors/dtors entry, only 'ptr inttoptr (i64 1 to ptr)' is allowed
@llvm.global_ctors = appending global [1 x { i32, ptr, ptr }] [{ i32, ptr, ptr } { i32 65535, ptr ptrauth (ptr @foo, i32 0, i64 55764, ptr inttoptr (i64 2 to ptr)), ptr null }]
define void @foo() {
ret void
}
;--- err2.ll
; RUN: not --crash llc -mtriple aarch64-elf -mattr=+pauth -filetype=asm -o - err2.ll 2>&1 | \
; RUN: FileCheck %s --check-prefix=ERR2
; ERR2: LLVM ERROR: unexpected address discrimination value for ctors/dtors entry, only 'ptr inttoptr (i64 1 to ptr)' is allowed
@g = external global ptr
@llvm.global_dtors = appending global [1 x { i32, ptr, ptr }] [{ i32, ptr, ptr } { i32 65535, ptr ptrauth (ptr @bar, i32 0, i64 55764, ptr @g), ptr null }]
define void @bar() {
ret void
}