
If both `-fptrauth-init-fini` and `-fptrauth-calls` are passed, sign function pointers in `llvm.global_ctors` and `llvm.global_dtors` with constant discriminator 0xD9D4 (`ptrauth_string_discriminator("init_fini")`). Additionally, if `-fptrauth-init-fini-address-discrimination` is passed, address discrimination is used for signing (otherwise, just constant discriminator is used). For address discrimination, we use it's special form since uses of `llvm.global_{c|d}tors` are disallowed (see `Verifier::visitGlobalVariable`) and we can't emit `getelementptr` expressions referencing these special arrays. A signed ctor/dtor pointer with special address discrimination applied looks like the following: ``` ptr ptrauth (ptr @foo, i32 0, i64 55764, ptr inttoptr (i64 1 to ptr)) ```
105 lines
4.8 KiB
LLVM
105 lines
4.8 KiB
LLVM
; 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
|
|
}
|