OLD | NEW |
1 // Copyright (c) 2014, the Dart project authors. Please see the AUTHORS file | 1 // Copyright (c) 2014, the Dart project authors. Please see the AUTHORS file |
2 // for details. All rights reserved. Use of this source code is governed by a | 2 // for details. All rights reserved. Use of this source code is governed by a |
3 // BSD-style license that can be found in the LICENSE file. | 3 // BSD-style license that can be found in the LICENSE file. |
4 | 4 |
5 #ifndef RUNTIME_VM_ASSEMBLER_ARM64_H_ | 5 #ifndef RUNTIME_VM_ASSEMBLER_ARM64_H_ |
6 #define RUNTIME_VM_ASSEMBLER_ARM64_H_ | 6 #define RUNTIME_VM_ASSEMBLER_ARM64_H_ |
7 | 7 |
8 #ifndef RUNTIME_VM_ASSEMBLER_H_ | 8 #ifndef RUNTIME_VM_ASSEMBLER_H_ |
9 #error Do not include assembler_arm64.h directly; use assembler.h instead. | 9 #error Do not include assembler_arm64.h directly; use assembler.h instead. |
10 #endif | 10 #endif |
(...skipping 1053 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... |
1064 void negs(Register rd, Register rm) { subs(rd, ZR, Operand(rm)); } | 1064 void negs(Register rd, Register rm) { subs(rd, ZR, Operand(rm)); } |
1065 void mul(Register rd, Register rn, Register rm) { madd(rd, rn, rm, ZR); } | 1065 void mul(Register rd, Register rn, Register rm) { madd(rd, rn, rm, ZR); } |
1066 void Push(Register reg) { | 1066 void Push(Register reg) { |
1067 ASSERT(reg != PP); // Only push PP with TagAndPushPP(). | 1067 ASSERT(reg != PP); // Only push PP with TagAndPushPP(). |
1068 str(reg, Address(SP, -1 * kWordSize, Address::PreIndex)); | 1068 str(reg, Address(SP, -1 * kWordSize, Address::PreIndex)); |
1069 } | 1069 } |
1070 void Pop(Register reg) { | 1070 void Pop(Register reg) { |
1071 ASSERT(reg != PP); // Only pop PP with PopAndUntagPP(). | 1071 ASSERT(reg != PP); // Only pop PP with PopAndUntagPP(). |
1072 ldr(reg, Address(SP, 1 * kWordSize, Address::PostIndex)); | 1072 ldr(reg, Address(SP, 1 * kWordSize, Address::PostIndex)); |
1073 } | 1073 } |
1074 void PushPair(Register first, Register second) { | 1074 void PushPair(Register low, Register high) { |
1075 ASSERT((first != PP) && (second != PP)); | 1075 ASSERT((low != PP) && (high != PP)); |
1076 stp(second, first, Address(SP, -2 * kWordSize, Address::PairPreIndex)); | 1076 stp(low, high, Address(SP, -2 * kWordSize, Address::PairPreIndex)); |
1077 } | 1077 } |
1078 void PopPair(Register first, Register second) { | 1078 void PopPair(Register low, Register high) { |
1079 ASSERT((first != PP) && (second != PP)); | 1079 ASSERT((low != PP) && (high != PP)); |
1080 ldp(second, first, Address(SP, 2 * kWordSize, Address::PairPostIndex)); | 1080 ldp(low, high, Address(SP, 2 * kWordSize, Address::PairPostIndex)); |
1081 } | 1081 } |
1082 void PushFloat(VRegister reg) { | 1082 void PushFloat(VRegister reg) { |
1083 fstrs(reg, Address(SP, -1 * kFloatSize, Address::PreIndex)); | 1083 fstrs(reg, Address(SP, -1 * kFloatSize, Address::PreIndex)); |
1084 } | 1084 } |
1085 void PushDouble(VRegister reg) { | 1085 void PushDouble(VRegister reg) { |
1086 fstrd(reg, Address(SP, -1 * kDoubleSize, Address::PreIndex)); | 1086 fstrd(reg, Address(SP, -1 * kDoubleSize, Address::PreIndex)); |
1087 } | 1087 } |
1088 void PushQuad(VRegister reg) { | 1088 void PushQuad(VRegister reg) { |
1089 fstrq(reg, Address(SP, -1 * kQuadSize, Address::PreIndex)); | 1089 fstrq(reg, Address(SP, -1 * kQuadSize, Address::PreIndex)); |
1090 } | 1090 } |
(...skipping 822 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... |
1913 Register value, | 1913 Register value, |
1914 Label* no_update); | 1914 Label* no_update); |
1915 | 1915 |
1916 DISALLOW_ALLOCATION(); | 1916 DISALLOW_ALLOCATION(); |
1917 DISALLOW_COPY_AND_ASSIGN(Assembler); | 1917 DISALLOW_COPY_AND_ASSIGN(Assembler); |
1918 }; | 1918 }; |
1919 | 1919 |
1920 } // namespace dart | 1920 } // namespace dart |
1921 | 1921 |
1922 #endif // RUNTIME_VM_ASSEMBLER_ARM64_H_ | 1922 #endif // RUNTIME_VM_ASSEMBLER_ARM64_H_ |
OLD | NEW |