diff options
| author | 2016-02-25 15:37:05 +0000 | |
|---|---|---|
| committer | 2016-02-25 15:37:05 +0000 | |
| commit | 1de3bb289ba5e8a249840c634ad5eb108b827d69 (patch) | |
| tree | d8faf2243c92442f0322c873555e3c695a254452 /compiler/optimizing/nodes.h | |
| parent | dcedaaa4dc6d05b6044ecef50f2d9bb95575d49c (diff) | |
| parent | 4a0dad67867f389e01a5a6c0fe381d210f687c0d (diff) | |
Merge "Revert "Revert "ARM/ARM64: Extend support of instruction combining."""
Diffstat (limited to 'compiler/optimizing/nodes.h')
| -rw-r--r-- | compiler/optimizing/nodes.h | 17 | 
1 files changed, 15 insertions, 2 deletions
| diff --git a/compiler/optimizing/nodes.h b/compiler/optimizing/nodes.h index b355883a72..4185b2f2c5 100644 --- a/compiler/optimizing/nodes.h +++ b/compiler/optimizing/nodes.h @@ -1247,6 +1247,16 @@ class HLoopInformationOutwardIterator : public ValueObject {    M(UShr, BinaryOperation)                                              \    M(Xor, BinaryOperation)                                               \ +/* + * Instructions, shared across several (not all) architectures. + */ +#if !defined(ART_ENABLE_CODEGEN_arm) && !defined(ART_ENABLE_CODEGEN_arm64) +#define FOR_EACH_CONCRETE_INSTRUCTION_SHARED(M) +#else +#define FOR_EACH_CONCRETE_INSTRUCTION_SHARED(M)                         \ +  M(MultiplyAccumulate, Instruction) +#endif +  #ifndef ART_ENABLE_CODEGEN_arm  #define FOR_EACH_CONCRETE_INSTRUCTION_ARM(M)  #else @@ -1259,8 +1269,7 @@ class HLoopInformationOutwardIterator : public ValueObject {  #else  #define FOR_EACH_CONCRETE_INSTRUCTION_ARM64(M)                          \    M(Arm64DataProcWithShifterOp, Instruction)                            \ -  M(Arm64IntermediateAddress, Instruction)                              \ -  M(Arm64MultiplyAccumulate, Instruction) +  M(Arm64IntermediateAddress, Instruction)  #endif  #define FOR_EACH_CONCRETE_INSTRUCTION_MIPS(M) @@ -1281,6 +1290,7 @@ class HLoopInformationOutwardIterator : public ValueObject {  #define FOR_EACH_CONCRETE_INSTRUCTION(M)                                \    FOR_EACH_CONCRETE_INSTRUCTION_COMMON(M)                               \ +  FOR_EACH_CONCRETE_INSTRUCTION_SHARED(M)                               \    FOR_EACH_CONCRETE_INSTRUCTION_ARM(M)                                  \    FOR_EACH_CONCRETE_INSTRUCTION_ARM64(M)                                \    FOR_EACH_CONCRETE_INSTRUCTION_MIPS(M)                                 \ @@ -6022,6 +6032,9 @@ class HParallelMove : public HTemplateInstruction<0> {  }  // namespace art +#if defined(ART_ENABLE_CODEGEN_arm) || defined(ART_ENABLE_CODEGEN_arm64) +#include "nodes_shared.h" +#endif  #ifdef ART_ENABLE_CODEGEN_arm  #include "nodes_arm.h"  #endif |