| /* |
| * 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_CONSTRUCTOR_FENCE_REDUNDANCY_ELIMINATION_H_ |
| #define ART_COMPILER_OPTIMIZING_CONSTRUCTOR_FENCE_REDUNDANCY_ELIMINATION_H_ |
| |
| #include "optimization.h" |
| |
| namespace art { |
| |
| /* |
| * Constructor Fence Redundancy Elimination (CFRE). |
| * |
| * A local optimization pass that merges redundant constructor fences |
| * together within the same basic block. |
| * |
| * Abbreviations: |
| * - CF: Constructor Fence |
| * - CFS: Constructor Fence Set |
| * - CFTargets: The unique set of the inputs of all the instructions in CFS. |
| * |
| * Given any CFS = { CF(x), CF(y), CF(z), ... }, define CFTargets = { x, y, z, ... }. |
| * - Publish(R) must not exist for any R in CFTargets if this Publish(R) is between any CF in CFS. |
| * - This type of Publish(R) is called an "interesting publish". |
| * |
| * A Publish(R) is considered any instruction at which the reference to "R" |
| * may escape (e.g. invoke, store, return, etc) to another thread. |
| * |
| * Starting at the beginning of the block: |
| * - Find the largest contiguous CFS. |
| * - If we see an interesting publish, merge all instructions in CFS into a single CF(CFTargets). |
| * - Repeat until the block is fully visited. |
| * - At the end of the block, merge all instructions in CFS into a single CF(CFTargets). |
| */ |
| class ConstructorFenceRedundancyElimination : public HOptimization { |
| public: |
| ConstructorFenceRedundancyElimination(HGraph* graph, |
| OptimizingCompilerStats* stats, |
| const char* name = kCFREPassName) |
| : HOptimization(graph, name, stats) {} |
| |
| bool Run() override; |
| |
| static constexpr const char* kCFREPassName = "constructor_fence_redundancy_elimination"; |
| |
| private: |
| DISALLOW_COPY_AND_ASSIGN(ConstructorFenceRedundancyElimination); |
| }; |
| |
| } // namespace art |
| |
| #endif // ART_COMPILER_OPTIMIZING_CONSTRUCTOR_FENCE_REDUNDANCY_ELIMINATION_H_ |