1
0
mirror of https://github.com/RPCS3/llvm-mirror.git synced 2024-11-23 11:13:28 +01:00
llvm-mirror/test/CodeGen/X86/note-cet-property.ll
Alexander Ivchenko acf5a1a563 [X86][ELF][CET] Adding the .note.gnu.property ELF section in X86
In preparation for the proposed linker ABI changes
(https://github.com/hjl-tools/linux-abi/wiki/linux-abi-draft.pdf,
https://github.com/hjl-tools/x86-psABI/wiki/x86-64-psABI-cet.pdf),
this patch enables emission of the .note.gnu.property section to
ELF object files when building CET-enabled modules.

patch by mike.dvoretsky

Differential Revision: https://reviews.llvm.org/D47145

llvm-svn: 333951
2018-06-04 21:07:35 +00:00

33 lines
986 B
LLVM

; RUN: llc -mtriple i686-pc-linux < %s | FileCheck %s --check-prefix=X86
; RUN: llc -mtriple x86_64-pc-linux < %s | FileCheck %s --check-prefix=X86_64
; This test checks that the compiler emits a .note.gnu.property section for
; modules with "cf-protection" module flags.
; X86: .section .note.gnu.property,"a",@note
; X86-NEXT: .p2align 2
; X86-NEXT: .long 4
; X86-NEXT: .long 12
; X86-NEXT: .long 5
; X86-NEXT: .asciz "GNU"
; X86-NEXT: .long 3221225474
; X86-NEXT: .long 4
; X86-NEXT: .long 3
; X86-NEXT: .p2align 2
; X86_64: .section .note.gnu.property,"a",@note
; X86_64-NEXT: .p2align 3
; X86_64-NEXT: .long 4
; X86_64-NEXT: .long 16
; X86_64-NEXT: .long 5
; X86_64-NEXT: .asciz "GNU"
; X86_64-NEXT: .long 3221225474
; X86_64-NEXT: .long 8
; X86_64-NEXT: .quad 3
; X86_64-NEXT: .p2align 3
!llvm.module.flags = !{!0, !1}
!0 = !{i32 4, !"cf-protection-return", i32 1}
!1 = !{i32 4, !"cf-protection-branch", i32 1}