mirror of
https://github.com/RPCS3/llvm-mirror.git
synced 2024-11-25 04:02:41 +01:00
2f69ee6563
This adds a cost model that takes into account the total number of machine instructions to be removed from each region, the number of instructions added by adding a new function with a set of instructions, and the instructions added by handling arguments. Tests not adding flags: llvm/test/Transforms/IROutliner/outlining-cost-model.ll Reviewers: jroelofs, paquette Differential Revision: https://reviews.llvm.org/D87299
50 lines
1.3 KiB
LLVM
50 lines
1.3 KiB
LLVM
; NOTE: Assertions have been autogenerated by utils/update_test_checks.py
|
|
; RUN: opt -S -verify -iroutliner -ir-outlining-no-cost < %s | FileCheck %s
|
|
|
|
; Show that we do not extract freeze instructions, since extra handling is
|
|
; required to mark any outputs used with freeze.
|
|
|
|
define void @function1(i32* %a, i32* %b) {
|
|
; CHECK-LABEL: @function1(
|
|
; CHECK-NEXT: entry:
|
|
; CHECK-NEXT: br label [[FIRST:%.*]]
|
|
; CHECK: first:
|
|
; CHECK-NEXT: [[C:%.*]] = freeze i32* [[A:%.*]]
|
|
; CHECK-NEXT: call void @outlined_ir_func_0(i32* [[C]], i32* [[B:%.*]])
|
|
; CHECK-NEXT: ret void
|
|
; CHECK: next:
|
|
; CHECK-NEXT: br label [[FIRST]]
|
|
;
|
|
entry:
|
|
br label %first
|
|
first:
|
|
%c = freeze i32* %a
|
|
store i32 2, i32* %c, align 4
|
|
store i32 3, i32* %b, align 4
|
|
ret void
|
|
next:
|
|
br label %first
|
|
}
|
|
|
|
define void @function2(i32* %a, i32* %b) {
|
|
; CHECK-LABEL: @function2(
|
|
; CHECK-NEXT: entry:
|
|
; CHECK-NEXT: br label [[FIRST:%.*]]
|
|
; CHECK: first:
|
|
; CHECK-NEXT: [[C:%.*]] = freeze i32* [[A:%.*]]
|
|
; CHECK-NEXT: call void @outlined_ir_func_0(i32* [[C]], i32* [[B:%.*]])
|
|
; CHECK-NEXT: ret void
|
|
; CHECK: next:
|
|
; CHECK-NEXT: br label [[FIRST]]
|
|
;
|
|
entry:
|
|
br label %first
|
|
first:
|
|
%c = freeze i32* %a
|
|
store i32 2, i32* %c, align 4
|
|
store i32 3, i32* %b, align 4
|
|
ret void
|
|
next:
|
|
br label %first
|
|
}
|