1 /*
2  * Copyright (C) 2014 The Android Open Source Project
3  *
4  * Licensed under the Apache License, Version 2.0 (the "License");
5  * you may not use this file except in compliance with the License.
6  * You may obtain a copy of the License at
7  *
8  *      http://www.apache.org/licenses/LICENSE-2.0
9  *
10  * Unless required by applicable law or agreed to in writing, software
11  * distributed under the License is distributed on an "AS IS" BASIS,
12  * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
13  * See the License for the specific language governing permissions and
14  * limitations under the License.
15  */
16 
17 #ifndef ART_COMPILER_OPTIMIZING_INSTRUCTION_SIMPLIFIER_H_
18 #define ART_COMPILER_OPTIMIZING_INSTRUCTION_SIMPLIFIER_H_
19 
20 #include "base/macros.h"
21 #include "nodes.h"
22 #include "optimization.h"
23 #include "optimizing_compiler_stats.h"
24 
25 namespace art HIDDEN {
26 
27 class CodeGenerator;
28 
29 /**
30  * Implements optimizations specific to each instruction.
31  *
32  * Note that graph simplifications producing a constant should be
33  * implemented in art::HConstantFolding, while graph simplifications
34  * not producing constants should be implemented in
35  * art::InstructionSimplifier.  (This convention is a choice that was
36  * made during the development of these parts of the compiler and is
37  * not bound by any technical requirement.)
38  */
39 class InstructionSimplifier : public HOptimization {
40  public:
41   InstructionSimplifier(HGraph* graph,
42                         CodeGenerator* codegen,
43                         OptimizingCompilerStats* stats = nullptr,
44                         const char* name = kInstructionSimplifierPassName,
45                         bool use_all_optimizations = false)
HOptimization(graph,name,stats)46       : HOptimization(graph, name, stats),
47         codegen_(codegen),
48         use_all_optimizations_(use_all_optimizations) {}
49 
50   static constexpr const char* kInstructionSimplifierPassName = "instruction_simplifier";
51 
52   bool Run() override;
53 
54  private:
55   CodeGenerator* codegen_;
56 
57   // Use all optimizations without restrictions.
58   bool use_all_optimizations_;
59 
60   DISALLOW_COPY_AND_ASSIGN(InstructionSimplifier);
61 };
62 
63 // For bitwise operations (And/Or/Xor) with a negated input, try to use
64 // a negated bitwise instruction.
65 bool TryMergeNegatedInput(HBinaryOperation* op);
66 
67 // Convert
68 // i1: AND a, b
69 //     SUB a, i1
70 // into:
71 //     BIC a, a, b
72 //
73 // It also works if `i1` is AND b, a
74 bool TryMergeWithAnd(HSub* instruction);
75 
76 }  // namespace art
77 
78 #endif  // ART_COMPILER_OPTIMIZING_INSTRUCTION_SIMPLIFIER_H_
79