Files
clang-p2996/llvm/test/CodeGen/WinCFGuard/cfguard-cast.ll
Alvin Wong c0214db51a [llvm] Mark CFGuard fn ptr symbol as DSO local and add tests for mingw
For mingw target, if a symbol is not marked DSO local, a `.refptr` is
generated for it. This makes CFG check calls use an extra pointer
dereference, which adds extra overhead compared to the MSVC version,
so mark the CFG guard check funciton pointer DSO local to stop it.
This should have no effect on MSVC target.

Also adapt the existing cfguard tests to run for mingw targets, so that
this change is checked.

Reviewed By: rnk

Differential Revision: https://reviews.llvm.org/D132331
2022-08-23 23:39:39 +03:00

37 lines
906 B
LLVM

; RUN: llc < %s -mtriple=x86_64-pc-windows-msvc | FileCheck %s
; RUN: llc < %s -mtriple=x86_64-w64-windows-gnu | FileCheck %s
; Check how constant function pointer casts are handled.
declare void @unprototyped(...)
define i32 @call_unprototyped() {
call void bitcast (void (...)* @unprototyped to void ()*)()
ret i32 0
}
; CHECK-LABEL: call_unprototyped:
; CHECK: callq unprototyped
; CHECK: xorl %eax, %eax
; CHECK: retq
declare void @escaped_cast()
define i32 @escape_it_with_cast(i8** %p) {
store i8* bitcast (void ()* @escaped_cast to i8*), i8** %p
ret i32 0
}
declare void @dead_constant()
!llvm.module.flags = !{!0}
!0 = !{i32 2, !"cfguard", i32 1}
!dead_constant_root = !{!1}
!1 = !DITemplateValueParameter(name: "dead_constant", value: i8* bitcast (void ()* @dead_constant to i8*))
; CHECK-LABEL: .section .gfids$y,"dr"
; CHECK-NEXT: .symidx escaped_cast
; CHECK-NOT: .symidx