170f8d0acSMircea Trofin; The default inliner doesn't elide @adder, it believes it's too costly to inline 270f8d0acSMircea Trofin; adder into switcher. The ML inliner carries out that inlining, resulting in 370f8d0acSMircea Trofin; a smaller result (part of it is that adder gets elided). 470f8d0acSMircea Trofin; 570f8d0acSMircea Trofin; This test uses Inputs/test-module.ll, as it shares it with a similar test 670f8d0acSMircea Trofin; for the 'release' mode. 770f8d0acSMircea Trofin; 834423091SKazu Hirata; REQUIRES: have_tflite 95ce4c9aaSMircea Trofin; RUN: rm -rf %t 105ce4c9aaSMircea Trofin; RUN: rm -rf %t_savedmodel 115ce4c9aaSMircea Trofin; RUN: %python %S/../../../../lib/Analysis/models/gen-inline-oz-test-model.py %t_savedmodel 125ce4c9aaSMircea Trofin; RUN: %python %S/../../../../lib/Analysis/models/saved-model-to-tflite.py %t_savedmodel %t 1370f8d0acSMircea Trofin; 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 14f86d1f99SJacob Hegna; 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 15*5898be19SMircea Trofin; RUN: opt -passes=scc-oz-module-inliner -enable-ml-inliner=development -training-log=%t.log -S < %S/Inputs/test-module.ll 2>&1 164c97745bSMircea Trofin; RUN: %python %S/../../../../lib/Analysis/models/log_reader.py %t.log | FileCheck %s --check-prefix=CHECK-LOG 174c97745bSMircea Trofin 184c97745bSMircea TrofinCHECK-LOG: observation: 0 194c97745bSMircea TrofinCHECK-LOG-NEXT: {{^sroa_savings:}} 0 204c97745bSMircea TrofinCHECK-LOG: {{^cost_estimate:}} -30 214c97745bSMircea TrofinCHECK-LOG: {{^inlining_decision:}} 1 224c97745bSMircea TrofinCHECK-LOG-NEXT: observation: 1 234c97745bSMircea TrofinCHECK-LOG: observation: 6 24