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 |