mirror of
https://github.com/RPCS3/llvm-mirror.git
synced 2024-11-23 03:02:36 +01:00
d090368b0c
Summary: A new function pass (Transforms/CFGuard/CFGuard.cpp) inserts CFGuard checks on indirect function calls, using either the check mechanism (X86, ARM, AArch64) or or the dispatch mechanism (X86-64). The check mechanism requires a new calling convention for the supported targets. The dispatch mechanism adds the target as an operand bundle, which is processed by SelectionDAG. Another pass (CodeGen/CFGuardLongjmp.cpp) identifies and emits valid longjmp targets, as required by /guard:cf. This feature is enabled using the `cfguard` CC1 option. Reviewers: thakis, rnk, theraven, pcc Subscribers: ychen, hans, metalcanine, dmajor, tomrittervg, alex, mehdi_amini, mgorny, javed.absar, kristof.beyls, hiraditya, steven_wu, dexonsmith, cfe-commits, llvm-commits Tags: #clang, #llvm Differential Revision: https://reviews.llvm.org/D65761
29 lines
807 B
LLVM
29 lines
807 B
LLVM
; RUN: llvm-as < %s | llvm-bcanalyzer -dump -disable-histogram | FileCheck %s
|
|
|
|
; CHECK: <OPERAND_BUNDLE_TAGS_BLOCK
|
|
; CHECK-NEXT: <OPERAND_BUNDLE_TAG
|
|
; CHECK-NEXT: <OPERAND_BUNDLE_TAG
|
|
; CHECK-NEXT: <OPERAND_BUNDLE_TAG
|
|
; CHECK-NEXT: <OPERAND_BUNDLE_TAG
|
|
; CHECK-NEXT: <OPERAND_BUNDLE_TAG
|
|
; CHECK-NEXT: <OPERAND_BUNDLE_TAG
|
|
; CHECK-NEXT: </OPERAND_BUNDLE_TAGS_BLOCK
|
|
|
|
; CHECK: <FUNCTION_BLOCK
|
|
; CHECK: <OPERAND_BUNDLE
|
|
; CHECK: <OPERAND_BUNDLE
|
|
; CHECK-NOT: <OPERAND_BUNDLE
|
|
; CHECK: </FUNCTION_BLOCK
|
|
|
|
; CHECK: Block ID #{{[0-9]+}} (OPERAND_BUNDLE_TAGS_BLOCK)
|
|
|
|
declare void @callee0()
|
|
|
|
define void @f0(i32* %ptr) {
|
|
entry:
|
|
%l = load i32, i32* %ptr
|
|
%x = add i32 42, 1
|
|
call void @callee0() [ "foo"(i32 42, i64 100, i32 %x), "bar"(float 0.000000e+00, i64 100, i32 %l) ]
|
|
ret void
|
|
}
|