| 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 681 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... |
| 692 | 692 |
| 693 // Push four registers. Pushes leftmost register first (to highest address). | 693 // Push four registers. Pushes leftmost register first (to highest address). |
| 694 void Push(Register src1, Register src2, Register src3, Register src4) { | 694 void Push(Register src1, Register src2, Register src3, Register src4) { |
| 695 Dsubu(sp, sp, Operand(4 * kPointerSize)); | 695 Dsubu(sp, sp, Operand(4 * kPointerSize)); |
| 696 sd(src1, MemOperand(sp, 3 * kPointerSize)); | 696 sd(src1, MemOperand(sp, 3 * kPointerSize)); |
| 697 sd(src2, MemOperand(sp, 2 * kPointerSize)); | 697 sd(src2, MemOperand(sp, 2 * kPointerSize)); |
| 698 sd(src3, MemOperand(sp, 1 * kPointerSize)); | 698 sd(src3, MemOperand(sp, 1 * kPointerSize)); |
| 699 sd(src4, MemOperand(sp, 0 * kPointerSize)); | 699 sd(src4, MemOperand(sp, 0 * kPointerSize)); |
| 700 } | 700 } |
| 701 | 701 |
| 702 // Push five registers. Pushes leftmost register first (to highest address). |
| 703 void Push(Register src1, Register src2, Register src3, Register src4, |
| 704 Register src5) { |
| 705 Dsubu(sp, sp, Operand(5 * kPointerSize)); |
| 706 sd(src1, MemOperand(sp, 4 * kPointerSize)); |
| 707 sd(src2, MemOperand(sp, 3 * kPointerSize)); |
| 708 sd(src3, MemOperand(sp, 2 * kPointerSize)); |
| 709 sd(src4, MemOperand(sp, 1 * kPointerSize)); |
| 710 sd(src5, MemOperand(sp, 0 * kPointerSize)); |
| 711 } |
| 712 |
| 702 void Push(Register src, Condition cond, Register tst1, Register tst2) { | 713 void Push(Register src, Condition cond, Register tst1, Register tst2) { |
| 703 // Since we don't have conditional execution we use a Branch. | 714 // Since we don't have conditional execution we use a Branch. |
| 704 Branch(3, cond, tst1, Operand(tst2)); | 715 Branch(3, cond, tst1, Operand(tst2)); |
| 705 Dsubu(sp, sp, Operand(kPointerSize)); | 716 Dsubu(sp, sp, Operand(kPointerSize)); |
| 706 sd(src, MemOperand(sp, 0)); | 717 sd(src, MemOperand(sp, 0)); |
| 707 } | 718 } |
| 708 | 719 |
| 709 void PushRegisterAsTwoSmis(Register src, Register scratch = at); | 720 void PushRegisterAsTwoSmis(Register src, Register scratch = at); |
| 710 void PopRegisterAsTwoSmis(Register dst, Register scratch = at); | 721 void PopRegisterAsTwoSmis(Register dst, Register scratch = at); |
| 711 | 722 |
| (...skipping 1106 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... |
| 1818 #define CODE_COVERAGE_TOSTRING(x) CODE_COVERAGE_STRINGIFY(x) | 1829 #define CODE_COVERAGE_TOSTRING(x) CODE_COVERAGE_STRINGIFY(x) |
| 1819 #define __FILE_LINE__ __FILE__ ":" CODE_COVERAGE_TOSTRING(__LINE__) | 1830 #define __FILE_LINE__ __FILE__ ":" CODE_COVERAGE_TOSTRING(__LINE__) |
| 1820 #define ACCESS_MASM(masm) masm->stop(__FILE_LINE__); masm-> | 1831 #define ACCESS_MASM(masm) masm->stop(__FILE_LINE__); masm-> |
| 1821 #else | 1832 #else |
| 1822 #define ACCESS_MASM(masm) masm-> | 1833 #define ACCESS_MASM(masm) masm-> |
| 1823 #endif | 1834 #endif |
| 1824 | 1835 |
| 1825 } } // namespace v8::internal | 1836 } } // namespace v8::internal |
| 1826 | 1837 |
| 1827 #endif // V8_MIPS_MACRO_ASSEMBLER_MIPS_H_ | 1838 #endif // V8_MIPS_MACRO_ASSEMBLER_MIPS_H_ |
| OLD | NEW |