1 // Copyright 2014 the V8 project authors. All rights reserved. 2 // Use of this source code is governed by a BSD-style license that can be 3 // found in the LICENSE file. 4 5 #ifndef V8_COMPILER_MIPS_INSTRUCTION_CODES_MIPS_H_ 6 #define V8_COMPILER_MIPS_INSTRUCTION_CODES_MIPS_H_ 7 8 namespace v8 { 9 namespace internal { 10 namespace compiler { 11 12 // MIPS64-specific opcodes that specify which assembly sequence to emit. 13 // Most opcodes specify a single instruction. 14 #define TARGET_ARCH_OPCODE_LIST(V) \ 15 V(Mips64Add) \ 16 V(Mips64Dadd) \ 17 V(Mips64DaddOvf) \ 18 V(Mips64Sub) \ 19 V(Mips64Dsub) \ 20 V(Mips64DsubOvf) \ 21 V(Mips64Mul) \ 22 V(Mips64MulOvf) \ 23 V(Mips64MulHigh) \ 24 V(Mips64DMulHigh) \ 25 V(Mips64MulHighU) \ 26 V(Mips64Dmul) \ 27 V(Mips64Div) \ 28 V(Mips64Ddiv) \ 29 V(Mips64DivU) \ 30 V(Mips64DdivU) \ 31 V(Mips64Mod) \ 32 V(Mips64Dmod) \ 33 V(Mips64ModU) \ 34 V(Mips64DmodU) \ 35 V(Mips64And) \ 36 V(Mips64And32) \ 37 V(Mips64Or) \ 38 V(Mips64Or32) \ 39 V(Mips64Nor) \ 40 V(Mips64Nor32) \ 41 V(Mips64Xor) \ 42 V(Mips64Xor32) \ 43 V(Mips64Clz) \ 44 V(Mips64Lsa) \ 45 V(Mips64Dlsa) \ 46 V(Mips64Shl) \ 47 V(Mips64Shr) \ 48 V(Mips64Sar) \ 49 V(Mips64Ext) \ 50 V(Mips64Ins) \ 51 V(Mips64Dext) \ 52 V(Mips64Dins) \ 53 V(Mips64Dclz) \ 54 V(Mips64Ctz) \ 55 V(Mips64Dctz) \ 56 V(Mips64Popcnt) \ 57 V(Mips64Dpopcnt) \ 58 V(Mips64Dshl) \ 59 V(Mips64Dshr) \ 60 V(Mips64Dsar) \ 61 V(Mips64Ror) \ 62 V(Mips64Dror) \ 63 V(Mips64Mov) \ 64 V(Mips64Tst) \ 65 V(Mips64Cmp) \ 66 V(Mips64CmpS) \ 67 V(Mips64AddS) \ 68 V(Mips64SubS) \ 69 V(Mips64MulS) \ 70 V(Mips64DivS) \ 71 V(Mips64ModS) \ 72 V(Mips64AbsS) \ 73 V(Mips64NegS) \ 74 V(Mips64SqrtS) \ 75 V(Mips64MaxS) \ 76 V(Mips64MinS) \ 77 V(Mips64CmpD) \ 78 V(Mips64AddD) \ 79 V(Mips64SubD) \ 80 V(Mips64MulD) \ 81 V(Mips64DivD) \ 82 V(Mips64ModD) \ 83 V(Mips64AbsD) \ 84 V(Mips64NegD) \ 85 V(Mips64SqrtD) \ 86 V(Mips64MaxD) \ 87 V(Mips64MinD) \ 88 V(Mips64MaddS) \ 89 V(Mips64MaddD) \ 90 V(Mips64MaddfS) \ 91 V(Mips64MaddfD) \ 92 V(Mips64MsubS) \ 93 V(Mips64MsubD) \ 94 V(Mips64MsubfS) \ 95 V(Mips64MsubfD) \ 96 V(Mips64Float64RoundDown) \ 97 V(Mips64Float64RoundTruncate) \ 98 V(Mips64Float64RoundUp) \ 99 V(Mips64Float64RoundTiesEven) \ 100 V(Mips64Float32RoundDown) \ 101 V(Mips64Float32RoundTruncate) \ 102 V(Mips64Float32RoundUp) \ 103 V(Mips64Float32RoundTiesEven) \ 104 V(Mips64CvtSD) \ 105 V(Mips64CvtDS) \ 106 V(Mips64TruncWD) \ 107 V(Mips64RoundWD) \ 108 V(Mips64FloorWD) \ 109 V(Mips64CeilWD) \ 110 V(Mips64TruncWS) \ 111 V(Mips64RoundWS) \ 112 V(Mips64FloorWS) \ 113 V(Mips64CeilWS) \ 114 V(Mips64TruncLS) \ 115 V(Mips64TruncLD) \ 116 V(Mips64TruncUwD) \ 117 V(Mips64TruncUwS) \ 118 V(Mips64TruncUlS) \ 119 V(Mips64TruncUlD) \ 120 V(Mips64CvtDW) \ 121 V(Mips64CvtSL) \ 122 V(Mips64CvtSW) \ 123 V(Mips64CvtSUw) \ 124 V(Mips64CvtSUl) \ 125 V(Mips64CvtDL) \ 126 V(Mips64CvtDUw) \ 127 V(Mips64CvtDUl) \ 128 V(Mips64Lb) \ 129 V(Mips64Lbu) \ 130 V(Mips64Sb) \ 131 V(Mips64Lh) \ 132 V(Mips64Ulh) \ 133 V(Mips64Lhu) \ 134 V(Mips64Ulhu) \ 135 V(Mips64Sh) \ 136 V(Mips64Ush) \ 137 V(Mips64Ld) \ 138 V(Mips64Uld) \ 139 V(Mips64Lw) \ 140 V(Mips64Ulw) \ 141 V(Mips64Lwu) \ 142 V(Mips64Ulwu) \ 143 V(Mips64Sw) \ 144 V(Mips64Usw) \ 145 V(Mips64Sd) \ 146 V(Mips64Usd) \ 147 V(Mips64Lwc1) \ 148 V(Mips64Ulwc1) \ 149 V(Mips64Swc1) \ 150 V(Mips64Uswc1) \ 151 V(Mips64Ldc1) \ 152 V(Mips64Uldc1) \ 153 V(Mips64Sdc1) \ 154 V(Mips64Usdc1) \ 155 V(Mips64BitcastDL) \ 156 V(Mips64BitcastLD) \ 157 V(Mips64Float64ExtractLowWord32) \ 158 V(Mips64Float64ExtractHighWord32) \ 159 V(Mips64Float64InsertLowWord32) \ 160 V(Mips64Float64InsertHighWord32) \ 161 V(Mips64Float32Max) \ 162 V(Mips64Float64Max) \ 163 V(Mips64Float32Min) \ 164 V(Mips64Float64Min) \ 165 V(Mips64Float64SilenceNaN) \ 166 V(Mips64Push) \ 167 V(Mips64StoreToStackSlot) \ 168 V(Mips64ByteSwap64) \ 169 V(Mips64ByteSwap32) \ 170 V(Mips64StackClaim) \ 171 V(Mips64Seb) \ 172 V(Mips64Seh) \ 173 V(Mips64AssertEqual) 174 175 // Addressing modes represent the "shape" of inputs to an instruction. 176 // Many instructions support multiple addressing modes. Addressing modes 177 // are encoded into the InstructionCode of the instruction and tell the 178 // code generator after register allocation which assembler method to call. 179 // 180 // We use the following local notation for addressing modes: 181 // 182 // R = register 183 // O = register or stack slot 184 // D = double register 185 // I = immediate (handle, external, int32) 186 // MRI = [register + immediate] 187 // MRR = [register + register] 188 // TODO(plind): Add the new r6 address modes. 189 #define TARGET_ADDRESSING_MODE_LIST(V) \ 190 V(MRI) /* [%r0 + K] */ \ 191 V(MRR) /* [%r0 + %r1] */ 192 193 194 } // namespace compiler 195 } // namespace internal 196 } // namespace v8 197 198 #endif // V8_COMPILER_MIPS_INSTRUCTION_CODES_MIPS_H_ 199