blob: c743db40d9b5ecbd157cb9953684f414a88d8fa3 [file] [log] [blame]
/*
* Copyright (C) 2017 The Android Open Source Project
*
* Licensed under the Apache License, Version 2.0 (the "License");
* you may not use this file except in compliance with the License.
* You may obtain a copy of the License at
*
* http://www.apache.org/licenses/LICENSE-2.0
*
* Unless required by applicable law or agreed to in writing, software
* distributed under the License is distributed on an "AS IS" BASIS,
* WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
* See the License for the specific language governing permissions and
* limitations under the License.
*/
#ifndef ART_COMPILER_OPTIMIZING_CODE_SINKING_H_
#define ART_COMPILER_OPTIMIZING_CODE_SINKING_H_
#include "base/macros.h"
#include "nodes.h"
#include "optimization.h"
namespace art HIDDEN {
/**
* Optimization pass to move instructions into uncommon branches,
* when it is safe to do so.
*/
class CodeSinking : public HOptimization {
public:
CodeSinking(HGraph* graph,
OptimizingCompilerStats* stats,
const char* name = kCodeSinkingPassName)
: HOptimization(graph, name, stats) {}
bool Run() override;
static constexpr const char* kCodeSinkingPassName = "code_sinking";
private:
// Tries to sink code to uncommon branches.
void UncommonBranchSinking();
// Tries to move code only used by `end_block` and all its post-dominated / dominated
// blocks, to these blocks.
void SinkCodeToUncommonBranch(HBasicBlock* end_block);
// Coalesces the Return/ReturnVoid instructions into one, if we have two or more. We do this to
// avoid generating the exit frame code several times.
void ReturnSinking();
DISALLOW_COPY_AND_ASSIGN(CodeSinking);
};
} // namespace art
#endif // ART_COMPILER_OPTIMIZING_CODE_SINKING_H_