23 lines
1.3 KiB
LLVM
23 lines
1.3 KiB
LLVM
; The default inliner doesn't elide @adder, it believes it's too costly to inline
|
|
; adder into switcher. The ML inliner carries out that inlining, resulting in
|
|
; a smaller result (part of it is that adder gets elided).
|
|
;
|
|
; This test uses Inputs/test-module.ll, as it shares it with a similar test
|
|
; for the 'release' mode.
|
|
;
|
|
; REQUIRES: have_tflite
|
|
; RUN: rm -rf %t
|
|
; RUN: rm -rf %t_savedmodel
|
|
; RUN: %python %S/../../../../lib/Analysis/models/gen-inline-oz-test-model.py %t_savedmodel
|
|
; RUN: %python %S/../../../../lib/Analysis/models/saved-model-to-tflite.py %t_savedmodel %t
|
|
; RUN: opt -passes=scc-oz-module-inliner -enable-ml-inliner=default -S < %S/Inputs/test-module.ll 2>&1 | FileCheck %S/Inputs/test-module.ll --check-prefix=DEFAULT
|
|
; RUN: opt -passes=scc-oz-module-inliner -enable-ml-inliner=development -ml-inliner-model-under-training=%t -S < %S/Inputs/test-module.ll 2>&1 | FileCheck %S/Inputs/test-module.ll --check-prefix=CHECK
|
|
; RUN: opt -passes=scc-oz-module-inliner -enable-ml-inliner=development -training-log=%t.log -S < %S/Inputs/test-module.ll 2>&1
|
|
; RUN: %python %S/../../../../lib/Analysis/models/log_reader.py %t.log | FileCheck %s --check-prefix=CHECK-LOG
|
|
|
|
CHECK-LOG: observation: 0
|
|
CHECK-LOG-NEXT: {{^sroa_savings:}} 0
|
|
CHECK-LOG: {{^cost_estimate:}} -30
|
|
CHECK-LOG: {{^inlining_decision:}} 1
|
|
CHECK-LOG-NEXT: observation: 1
|
|
CHECK-LOG: observation: 6
|