[MachineOutliner] Never add the outliner in -O0

We shouldn't add the outliner when compiling at -O0 even if
-enable-machine-outliner is passed in. This makes sure that we
don't add it in this case.

This also updates machine-outliner-flags to reflect the change
and improves the comment describing what that test does.

llvm-svn: 335879
This commit is contained in:
Jessica Paquette 2018-06-28 17:05:57 +00:00
parent 719039ac2c
commit 5bfc8edb8b
2 changed files with 18 additions and 5 deletions

View File

@ -914,7 +914,8 @@ void TargetPassConfig::addMachinePasses() {
addPass(&XRayInstrumentationID, false);
addPass(&PatchableFunctionID, false);
if (EnableMachineOutliner == AlwaysOutline)
if (getOptLevel() != CodeGenOpt::None &&
EnableMachineOutliner == AlwaysOutline)
addPass(createMachineOutlinerPass());
// Add passes that directly emit MI after all other MI passes.

View File

@ -14,15 +14,27 @@
; RUN: -mtriple arm64---- -o /dev/null 2>&1 \
; RUN: | FileCheck %s -check-prefix=NOT-ADDED
; Make sure that the outliner flags all work properly. If we specify
; -enable-machine-outliner with always or no argument, it should be added to the
; pass pipeline. If we specify it with never, or don't pass the flag,
; then we shouldn't add it.
; RUN: llc %s -O=0 -debug-pass=Structure -verify-machineinstrs \
; RUN: -mtriple arm64---- -o /dev/null 2>&1 \
; RUN: | FileCheck %s -check-prefix=OPTNONE
; Make sure that the outliner is added to the pass pipeline only when the
; appropriate flags/settings are set. Make sure it isn't added otherwise.
;
; Cases where it should be added:
; * -enable-machine-outliner
; * -enable-machine-outliner=always
;
; Cases where it should not be added:
; * -enable-machine-outliner=never
; * -O0 or equivalent
; * -enable-machine-outliner is not passed
; ALWAYS: Machine Outliner
; ENABLE: Machine Outliner
; NEVER-NOT: Machine Outliner
; NOT-ADDED-NOT: Machine Outliner
; OPTNONE-NOT: Machine Outliner
define void @foo() {
ret void;