1
0
mirror of https://github.com/RPCS3/llvm-mirror.git synced 2025-02-01 13:11:39 +01:00
llvm-mirror/test/CodeGen/AMDGPU/speculative-execution-freecasts.ll
dfukalov e81c6d4c67 SpeculativeExecution: fixed ingoring free execution
Summary:
After updating cost model in AMDGPU target (47a5c36b37f0) the pass started to
ignore some BBs since they got all instructions estimated as free.

Reviewers: arsenm, chandlerc, nhaehnle

Reviewed By: nhaehnle

Subscribers: jvesely, wdng, nhaehnle, tpr, hiraditya, kerbowa, llvm-commits

Tags: #llvm

Differential Revision: https://reviews.llvm.org/D74825
2020-02-20 14:45:02 +03:00

31 lines
624 B
LLVM

; RUN: opt < %s -S -mtriple=amdgcn-unknown-amdhsa -speculative-execution \
; RUN: -spec-exec-max-speculation-cost 1 -spec-exec-max-not-hoisted 1 \
; RUN: | FileCheck %s
; CHECK-LABEL: @ifThen_bitcast(
; CHECK: bitcast
; CHECK: br i1 true
define void @ifThen_bitcast(i32 %y) {
br i1 true, label %a, label %b
a:
%x = bitcast i32 %y to float
br label %b
b:
ret void
}
; CHECK-LABEL: @ifThen_addrspacecast(
; CHECK: addrspacecast
; CHECK: br i1 true
define void @ifThen_addrspacecast(i32* %y) {
br i1 true, label %a, label %b
a:
%x = addrspacecast i32* %y to i32 addrspace(1)*
br label %b
b:
ret void
}