| /* |
| * Copyright (C) 2009 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_UTILS_ARM_CONSTANTS_ARM_H_ |
| #define ART_COMPILER_UTILS_ARM_CONSTANTS_ARM_H_ |
| |
| #include <stdint.h> |
| |
| #include <iosfwd> |
| |
| #include <android-base/logging.h> |
| |
| #include "arch/arm/registers_arm.h" |
| #include "base/casts.h" |
| #include "base/globals.h" |
| #include "base/macros.h" |
| |
| namespace art HIDDEN { |
| namespace arm { |
| |
| // Defines constants and accessor classes to assemble, disassemble and |
| // simulate ARM instructions. |
| // |
| // Section references in the code refer to the "ARM Architecture |
| // Reference Manual ARMv7-A and ARMv7-R edition", issue C.b (24 July |
| // 2012). |
| // |
| // Constants for specific fields are defined in their respective named enums. |
| // General constants are in an anonymous enum in class Instr. |
| |
| // 4 bits option for the dmb instruction. |
| // Order and values follows those of the ARM Architecture Reference Manual. |
| enum DmbOptions { |
| SY = 0xf, |
| ST = 0xe, |
| ISH = 0xb, |
| ISHST = 0xa, |
| NSH = 0x7, |
| NSHST = 0x6 |
| }; |
| |
| // Values for double-precision floating point registers. |
| enum DRegister { // private marker to avoid generate-operator-out.py from processing. |
| D0 = 0, |
| D1 = 1, |
| D2 = 2, |
| D3 = 3, |
| D4 = 4, |
| D5 = 5, |
| D6 = 6, |
| D7 = 7, |
| D8 = 8, |
| D9 = 9, |
| D10 = 10, |
| D11 = 11, |
| D12 = 12, |
| D13 = 13, |
| D14 = 14, |
| D15 = 15, |
| D16 = 16, |
| D17 = 17, |
| D18 = 18, |
| D19 = 19, |
| D20 = 20, |
| D21 = 21, |
| D22 = 22, |
| D23 = 23, |
| D24 = 24, |
| D25 = 25, |
| D26 = 26, |
| D27 = 27, |
| D28 = 28, |
| D29 = 29, |
| D30 = 30, |
| D31 = 31, |
| kNumberOfDRegisters = 32, |
| kNumberOfOverlappingDRegisters = 16, |
| kNoDRegister = -1, |
| }; |
| std::ostream& operator<<(std::ostream& os, const DRegister& rhs); |
| |
| // Opcodes for Data-processing instructions (instructions with a type 0 and 1) |
| // as defined in section A3.4 |
| enum Opcode { |
| kNoOperand = -1, |
| AND = 0, // Logical AND |
| EOR = 1, // Logical Exclusive OR |
| SUB = 2, // Subtract |
| RSB = 3, // Reverse Subtract |
| ADD = 4, // Add |
| ADC = 5, // Add with Carry |
| SBC = 6, // Subtract with Carry |
| RSC = 7, // Reverse Subtract with Carry |
| TST = 8, // Test |
| TEQ = 9, // Test Equivalence |
| CMP = 10, // Compare |
| CMN = 11, // Compare Negated |
| ORR = 12, // Logical (inclusive) OR |
| MOV = 13, // Move |
| BIC = 14, // Bit Clear |
| MVN = 15, // Move Not |
| ORN = 16, // Logical OR NOT. |
| kMaxOperand = 17 |
| }; |
| |
| // Size (in bytes) of registers. |
| const int kRegisterSize = 4; |
| |
| // List of registers used in load/store multiple. |
| using RegList = uint16_t; |
| |
| } // namespace arm |
| } // namespace art |
| |
| #endif // ART_COMPILER_UTILS_ARM_CONSTANTS_ARM_H_ |