| OLD | NEW | 
|---|
| 1 // Copyright 2012 the V8 project authors. All rights reserved. | 1 // Copyright 2012 the V8 project authors. All rights reserved. | 
| 2 // Use of this source code is governed by a BSD-style license that can be | 2 // Use of this source code is governed by a BSD-style license that can be | 
| 3 // found in the LICENSE file. | 3 // found in the LICENSE file. | 
| 4 | 4 | 
| 5 #ifndef V8_MIPS_MACRO_ASSEMBLER_MIPS_H_ | 5 #ifndef V8_MIPS_MACRO_ASSEMBLER_MIPS_H_ | 
| 6 #define V8_MIPS_MACRO_ASSEMBLER_MIPS_H_ | 6 #define V8_MIPS_MACRO_ASSEMBLER_MIPS_H_ | 
| 7 | 7 | 
| 8 #include "src/assembler.h" | 8 #include "src/assembler.h" | 
| 9 #include "src/globals.h" | 9 #include "src/globals.h" | 
| 10 #include "src/mips64/assembler-mips64.h" | 10 #include "src/mips64/assembler-mips64.h" | 
| (...skipping 1280 matching lines...) Expand 10 before | Expand all | Expand 10 after  Loading... | 
| 1291   // untagged value afterwards. | 1291   // untagged value afterwards. | 
| 1292   void SmiToDoubleFPURegister(Register smi, | 1292   void SmiToDoubleFPURegister(Register smi, | 
| 1293                               FPURegister value, | 1293                               FPURegister value, | 
| 1294                               Register scratch1); | 1294                               Register scratch1); | 
| 1295 | 1295 | 
| 1296   // ------------------------------------------------------------------------- | 1296   // ------------------------------------------------------------------------- | 
| 1297   // Overflow handling functions. | 1297   // Overflow handling functions. | 
| 1298   // Usage: first call the appropriate arithmetic function, then call one of the | 1298   // Usage: first call the appropriate arithmetic function, then call one of the | 
| 1299   // jump functions with the overflow_dst register as the second parameter. | 1299   // jump functions with the overflow_dst register as the second parameter. | 
| 1300 | 1300 | 
| 1301   void AdduAndCheckForOverflow(Register dst, | 1301   inline void AddBranchOvf(Register dst, Register left, const Operand& right, | 
| 1302                                Register left, | 1302                            Label* overflow_label, Register scratch = at) { | 
| 1303                                Register right, | 1303     AddBranchOvf(dst, left, right, overflow_label, nullptr, scratch); | 
| 1304                                Register overflow_dst, | 1304   } | 
| 1305                                Register scratch = at); |  | 
| 1306 | 1305 | 
| 1307   void AdduAndCheckForOverflow(Register dst, Register left, | 1306   inline void AddBranchNoOvf(Register dst, Register left, const Operand& right, | 
| 1308                                const Operand& right, Register overflow_dst, | 1307                              Label* no_overflow_label, Register scratch = at) { | 
| 1309                                Register scratch); | 1308     AddBranchOvf(dst, left, right, nullptr, no_overflow_label, scratch); | 
|  | 1309   } | 
| 1310 | 1310 | 
| 1311   void SubuAndCheckForOverflow(Register dst, | 1311   void AddBranchOvf(Register dst, Register left, const Operand& right, | 
| 1312                                Register left, | 1312                     Label* overflow_label, Label* no_overflow_label, | 
| 1313                                Register right, | 1313                     Register scratch = at); | 
| 1314                                Register overflow_dst, |  | 
| 1315                                Register scratch = at); |  | 
| 1316 | 1314 | 
| 1317   void SubuAndCheckForOverflow(Register dst, Register left, | 1315   void AddBranchOvf(Register dst, Register left, Register right, | 
| 1318                                const Operand& right, Register overflow_dst, | 1316                     Label* overflow_label, Label* no_overflow_label, | 
| 1319                                Register scratch); | 1317                     Register scratch = at); | 
| 1320 | 1318 | 
| 1321   void DadduAndCheckForOverflow(Register dst, Register left, Register right, | 1319   inline void SubBranchOvf(Register dst, Register left, const Operand& right, | 
| 1322                                 Register overflow_dst, Register scratch = at); | 1320                            Label* overflow_label, Register scratch = at) { | 
|  | 1321     SubBranchOvf(dst, left, right, overflow_label, nullptr, scratch); | 
|  | 1322   } | 
| 1323 | 1323 | 
| 1324   void DadduAndCheckForOverflow(Register dst, Register left, | 1324   inline void SubBranchNoOvf(Register dst, Register left, const Operand& right, | 
| 1325                                 const Operand& right, Register overflow_dst, | 1325                              Label* no_overflow_label, Register scratch = at) { | 
| 1326                                 Register scratch); | 1326     SubBranchOvf(dst, left, right, nullptr, no_overflow_label, scratch); | 
|  | 1327   } | 
|  | 1328 | 
|  | 1329   void SubBranchOvf(Register dst, Register left, const Operand& right, | 
|  | 1330                     Label* overflow_label, Label* no_overflow_label, | 
|  | 1331                     Register scratch = at); | 
|  | 1332 | 
|  | 1333   void SubBranchOvf(Register dst, Register left, Register right, | 
|  | 1334                     Label* overflow_label, Label* no_overflow_label, | 
|  | 1335                     Register scratch = at); | 
| 1327 | 1336 | 
| 1328   inline void DaddBranchOvf(Register dst, Register left, const Operand& right, | 1337   inline void DaddBranchOvf(Register dst, Register left, const Operand& right, | 
| 1329                             Label* overflow_label, Register scratch = at) { | 1338                             Label* overflow_label, Register scratch = at) { | 
| 1330     DaddBranchOvf(dst, left, right, overflow_label, nullptr, scratch); | 1339     DaddBranchOvf(dst, left, right, overflow_label, nullptr, scratch); | 
| 1331   } | 1340   } | 
| 1332 | 1341 | 
| 1333   inline void DaddBranchNoOvf(Register dst, Register left, const Operand& right, | 1342   inline void DaddBranchNoOvf(Register dst, Register left, const Operand& right, | 
| 1334                               Label* no_overflow_label, Register scratch = at) { | 1343                               Label* no_overflow_label, Register scratch = at) { | 
| 1335     DaddBranchOvf(dst, left, right, nullptr, no_overflow_label, scratch); | 1344     DaddBranchOvf(dst, left, right, nullptr, no_overflow_label, scratch); | 
| 1336   } | 1345   } | 
| 1337 | 1346 | 
| 1338   void DaddBranchOvf(Register dst, Register left, const Operand& right, | 1347   void DaddBranchOvf(Register dst, Register left, const Operand& right, | 
| 1339                      Label* overflow_label, Label* no_overflow_label, | 1348                      Label* overflow_label, Label* no_overflow_label, | 
| 1340                      Register scratch = at); | 1349                      Register scratch = at); | 
| 1341 | 1350 | 
| 1342   void DaddBranchOvf(Register dst, Register left, Register right, | 1351   void DaddBranchOvf(Register dst, Register left, Register right, | 
| 1343                      Label* overflow_label, Label* no_overflow_label, | 1352                      Label* overflow_label, Label* no_overflow_label, | 
| 1344                      Register scratch = at); | 1353                      Register scratch = at); | 
| 1345 | 1354 | 
| 1346   void DsubuAndCheckForOverflow(Register dst, Register left, Register right, |  | 
| 1347                                 Register overflow_dst, Register scratch = at); |  | 
| 1348 |  | 
| 1349   void DsubuAndCheckForOverflow(Register dst, Register left, |  | 
| 1350                                 const Operand& right, Register overflow_dst, |  | 
| 1351                                 Register scratch); |  | 
| 1352 |  | 
| 1353   inline void DsubBranchOvf(Register dst, Register left, const Operand& right, | 1355   inline void DsubBranchOvf(Register dst, Register left, const Operand& right, | 
| 1354                             Label* overflow_label, Register scratch = at) { | 1356                             Label* overflow_label, Register scratch = at) { | 
| 1355     DsubBranchOvf(dst, left, right, overflow_label, nullptr, scratch); | 1357     DsubBranchOvf(dst, left, right, overflow_label, nullptr, scratch); | 
| 1356   } | 1358   } | 
| 1357 | 1359 | 
| 1358   inline void DsubBranchNoOvf(Register dst, Register left, const Operand& right, | 1360   inline void DsubBranchNoOvf(Register dst, Register left, const Operand& right, | 
| 1359                               Label* no_overflow_label, Register scratch = at) { | 1361                               Label* no_overflow_label, Register scratch = at) { | 
| 1360     DsubBranchOvf(dst, left, right, nullptr, no_overflow_label, scratch); | 1362     DsubBranchOvf(dst, left, right, nullptr, no_overflow_label, scratch); | 
| 1361   } | 1363   } | 
| 1362 | 1364 | 
| (...skipping 621 matching lines...) Expand 10 before | Expand all | Expand 10 after  Loading... | 
| 1984 #define __FILE_LINE__ __FILE__ ":" CODE_COVERAGE_TOSTRING(__LINE__) | 1986 #define __FILE_LINE__ __FILE__ ":" CODE_COVERAGE_TOSTRING(__LINE__) | 
| 1985 #define ACCESS_MASM(masm) masm->stop(__FILE_LINE__); masm-> | 1987 #define ACCESS_MASM(masm) masm->stop(__FILE_LINE__); masm-> | 
| 1986 #else | 1988 #else | 
| 1987 #define ACCESS_MASM(masm) masm-> | 1989 #define ACCESS_MASM(masm) masm-> | 
| 1988 #endif | 1990 #endif | 
| 1989 | 1991 | 
| 1990 }  // namespace internal | 1992 }  // namespace internal | 
| 1991 }  // namespace v8 | 1993 }  // namespace v8 | 
| 1992 | 1994 | 
| 1993 #endif  // V8_MIPS_MACRO_ASSEMBLER_MIPS_H_ | 1995 #endif  // V8_MIPS_MACRO_ASSEMBLER_MIPS_H_ | 
| OLD | NEW | 
|---|