mirror of
https://github.com/RPCSX/llvm.git
synced 2025-01-27 15:22:29 +00:00
d2e75bd7aa
This new verifier rule lets us unambigously pick a calling convention when creating a new declaration for `@llvm.experimental.deoptimize.<ty>`. It is also congruent with our lowering strategy -- since all calls to `@llvm.experimental.deoptimize` are lowered to calls to `__llvm_deoptimize`, it is reasonable to enforce a unique calling convention. Some of the tests that were breaking this verifier rule have had to be split up into different .ll files. The inliner was violating this rule as well, and has been fixed to avoid producing invalid IR. git-svn-id: https://llvm.org/svn/llvm-project/llvm/trunk@269261 91177308-0d34-0410-b5e6-96231b3b80d8
57 lines
2.2 KiB
LLVM
57 lines
2.2 KiB
LLVM
; RUN: llc < %s | FileCheck %s
|
|
; RUN: llc -debug-only=stackmaps < %s 2>&1 | FileCheck --check-prefix=STACKMAPS %s
|
|
; REQUIRES: asserts
|
|
|
|
target datalayout = "e-m:o-i64:64-f80:128-n8:16:32:64-S128"
|
|
target triple = "x86_64-apple-macosx10.11.0"
|
|
|
|
declare i32 @llvm.experimental.deoptimize.i32(...)
|
|
declare i8 @llvm.experimental.deoptimize.i8(...)
|
|
|
|
define i32 @caller_0() {
|
|
; CHECK-LABEL: _caller_0:
|
|
; CHECK-NEXT: {{.+cfi.+}}
|
|
; CHECK-NEXT: ##{{.+}}
|
|
; CHECK-NEXT: pushq %rax
|
|
; CHECK-NEXT: {{Ltmp[0-9]+}}:
|
|
; CHECK-NEXT: {{.+cfi.+}}
|
|
; CHECK-NEXT: callq ___llvm_deoptimize
|
|
; CHECK-NEXT: {{Ltmp[0-9]+}}:
|
|
entry:
|
|
%v = call i32(...) @llvm.experimental.deoptimize.i32() [ "deopt"(i32 0) ]
|
|
ret i32 %v
|
|
}
|
|
|
|
define i8 @caller_1() {
|
|
; CHECK-LABEL: _caller_1:
|
|
; CHECK-NEXT: {{.+cfi.+}}
|
|
; CHECK-NEXT: ##{{.+}}
|
|
; CHECK-NEXT: pushq %rax
|
|
; CHECK-NEXT: {{Ltmp[0-9]+}}:
|
|
; CHECK-NEXT: {{.+cfi.+}}
|
|
; CHECK-NEXT: movss {{[a-zA-Z0-9_]+}}(%rip), %xmm0 ## xmm0 = mem[0],zero,zero,zero
|
|
; CHECK-NEXT: movl $42, %edi
|
|
; CHECK-NEXT: callq ___llvm_deoptimize
|
|
; CHECK-NEXT: {{Ltmp[0-9]+}}:
|
|
|
|
entry:
|
|
%v = call i8(...) @llvm.experimental.deoptimize.i8(i32 42, float 500.0) [ "deopt"(i32 1) ]
|
|
ret i8 %v
|
|
}
|
|
|
|
; STACKMAPS: Stack Maps: callsites:
|
|
; STACKMAPS-NEXT: Stack Maps: callsite 2882400015
|
|
; STACKMAPS-NEXT: Stack Maps: has 4 locations
|
|
; STACKMAPS-NEXT: Stack Maps: Loc 0: Constant 0 [encoding: .byte 4, .byte 8, .short 0, .int 0]
|
|
; STACKMAPS-NEXT: Stack Maps: Loc 1: Constant 0 [encoding: .byte 4, .byte 8, .short 0, .int 0]
|
|
; STACKMAPS-NEXT: Stack Maps: Loc 2: Constant 1 [encoding: .byte 4, .byte 8, .short 0, .int 1]
|
|
; STACKMAPS-NEXT: Stack Maps: Loc 3: Constant 0 [encoding: .byte 4, .byte 8, .short 0, .int 0]
|
|
; STACKMAPS-NEXT: Stack Maps: has 0 live-out registers
|
|
; STACKMAPS-NEXT: Stack Maps: callsite 2882400015
|
|
; STACKMAPS-NEXT: Stack Maps: has 4 locations
|
|
; STACKMAPS-NEXT: Stack Maps: Loc 0: Constant 0 [encoding: .byte 4, .byte 8, .short 0, .int 0]
|
|
; STACKMAPS-NEXT: Stack Maps: Loc 1: Constant 0 [encoding: .byte 4, .byte 8, .short 0, .int 0]
|
|
; STACKMAPS-NEXT: Stack Maps: Loc 2: Constant 1 [encoding: .byte 4, .byte 8, .short 0, .int 1]
|
|
; STACKMAPS-NEXT: Stack Maps: Loc 3: Constant 1 [encoding: .byte 4, .byte 8, .short 0, .int 1]
|
|
; STACKMAPS-NEXT: Stack Maps: has 0 live-out registers
|