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 #include "platform/assert.h" | 5 #include "platform/assert.h" |
6 #include "vm/globals.h" | 6 #include "vm/globals.h" |
7 #if defined(TARGET_ARCH_ARM64) | 7 #if defined(TARGET_ARCH_ARM64) |
8 | 8 |
9 #include "vm/assembler.h" | 9 #include "vm/assembler.h" |
10 #include "vm/object.h" | 10 #include "vm/object.h" |
11 #include "vm/unit_test.h" | 11 #include "vm/unit_test.h" |
12 | 12 |
13 namespace dart { | 13 namespace dart { |
14 | 14 |
15 #define __ assembler-> | 15 #define __ assembler-> |
16 | 16 |
17 // Generate a simple dart code sequence. | 17 // Generate a simple dart code sequence. |
18 // This is used to test Code and Instruction object creation. | 18 // This is used to test Code and Instruction object creation. |
19 void GenerateIncrement(Assembler* assembler) { | 19 void GenerateIncrement(Assembler* assembler) { |
20 __ mov(SP, CSP); | 20 __ EnterFrame(1 * kWordSize); |
21 __ movz(R0, Immediate(0), 0); | 21 __ movz(R0, Immediate(0), 0); |
22 __ Push(R0); | 22 __ Push(R0); |
23 __ add(R0, R0, Operand(1)); | 23 __ add(R0, R0, Operand(1)); |
24 __ str(R0, Address(SP)); | 24 __ str(R0, Address(SP)); |
25 __ ldr(R1, Address(SP)); | 25 __ ldr(R1, Address(SP)); |
26 __ add(R1, R1, Operand(1)); | 26 __ add(R1, R1, Operand(1)); |
27 __ Pop(R0); | 27 __ Pop(R0); |
28 __ mov(R0, R1); | 28 __ mov(R0, R1); |
| 29 __ LeaveFrame(); |
29 __ ret(); | 30 __ ret(); |
30 } | 31 } |
31 | 32 |
32 | 33 |
33 // Generate a dart code sequence that embeds a string object in it. | 34 // Generate a dart code sequence that embeds a string object in it. |
34 // This is used to test Embedded String objects in the instructions. | 35 // This is used to test Embedded String objects in the instructions. |
35 void GenerateEmbedStringInCode(Assembler* assembler, const char* str) { | 36 void GenerateEmbedStringInCode(Assembler* assembler, const char* str) { |
36 const String& string_object = | 37 const String& string_object = |
37 String::ZoneHandle(String::New(str, Heap::kOld)); | 38 String::ZoneHandle(String::New(str, Heap::kOld)); |
38 __ EnterStubFrame(); | 39 __ EnterStubFrame(); |
39 __ LoadObject(R0, string_object); | 40 __ LoadObject(R0, string_object); |
40 __ LeaveStubFrame(); | 41 __ LeaveStubFrame(); |
41 __ ret(); | 42 __ ret(); |
42 } | 43 } |
43 | 44 |
44 | 45 |
45 // Generate a dart code sequence that embeds a smi object in it. | 46 // Generate a dart code sequence that embeds a smi object in it. |
46 // This is used to test Embedded Smi objects in the instructions. | 47 // This is used to test Embedded Smi objects in the instructions. |
47 void GenerateEmbedSmiInCode(Assembler* assembler, intptr_t value) { | 48 void GenerateEmbedSmiInCode(Assembler* assembler, intptr_t value) { |
48 const Smi& smi_object = Smi::ZoneHandle(Smi::New(value)); | 49 const Smi& smi_object = Smi::ZoneHandle(Smi::New(value)); |
49 const int64_t val = reinterpret_cast<int64_t>(smi_object.raw()); | 50 const int64_t val = reinterpret_cast<int64_t>(smi_object.raw()); |
50 __ LoadImmediate(R0, val); | 51 __ LoadImmediate(R0, val); |
51 __ ret(); | 52 __ ret(); |
52 } | 53 } |
53 | 54 |
54 } // namespace dart | 55 } // namespace dart |
55 | 56 |
56 #endif // defined TARGET_ARCH_ARM64 | 57 #endif // defined TARGET_ARCH_ARM64 |
OLD | NEW |