OLD | NEW |
1 // Copyright (c) 2013, the Dart project authors. Please see the AUTHORS file | 1 // Copyright (c) 2013, 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 "vm/globals.h" | 5 #include "vm/globals.h" |
6 #if defined(TARGET_ARCH_MIPS) | 6 #if defined(TARGET_ARCH_MIPS) |
7 | 7 |
8 #include "vm/assembler.h" | 8 #include "vm/assembler.h" |
9 #include "vm/instructions.h" | 9 #include "vm/instructions.h" |
10 #include "vm/stub_code.h" | 10 #include "vm/stub_code.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 ASSEMBLER_TEST_GENERATE(Call, assembler) { | 17 ASSEMBLER_TEST_GENERATE(Call, assembler) { |
18 __ BranchLinkPatchable(*StubCode::InvokeDartCode_entry()); | 18 __ BranchLinkPatchable(*StubCode::InvokeDartCode_entry()); |
19 __ Ret(); | 19 __ Ret(); |
20 } | 20 } |
21 | 21 |
22 | 22 |
23 ASSEMBLER_TEST_RUN(Call, test) { | 23 ASSEMBLER_TEST_RUN(Call, test) { |
24 // The return address, which must be the address of an instruction contained | 24 // The return address, which must be the address of an instruction contained |
25 // in the code, points to the Ret instruction above, i.e. two instructions | 25 // in the code, points to the Ret instruction above, i.e. two instructions |
26 // before the end of the code buffer, including the delay slot for the | 26 // before the end of the code buffer, including the delay slot for the |
27 // return jump. | 27 // return jump. |
28 CallPattern call(test->entry() + test->code().Size() - (2*Instr::kInstrSize), | 28 CallPattern call(test->entry() + test->code().Size() - (2*Instr::kInstrSize), |
29 test->code()); | 29 test->code()); |
30 EXPECT_EQ(StubCode::InvokeDartCode_entry()->label().address(), | 30 EXPECT_EQ(StubCode::InvokeDartCode_entry()->code(), call.TargetCode()); |
31 call.TargetAddress()); | |
32 } | 31 } |
33 | 32 |
34 | 33 |
35 ASSEMBLER_TEST_GENERATE(Jump, assembler) { | |
36 __ BranchPatchable(*StubCode::InvokeDartCode_entry()); | |
37 __ BranchPatchable(*StubCode::AllocateArray_entry()); | |
38 } | |
39 | |
40 | |
41 ASSEMBLER_TEST_RUN(Jump, test) { | |
42 const Code& code = test->code(); | |
43 const Instructions& instrs = Instructions::Handle(code.instructions()); | |
44 bool status = | |
45 VirtualMemory::Protect(reinterpret_cast<void*>(instrs.EntryPoint()), | |
46 instrs.size(), | |
47 VirtualMemory::kReadWrite); | |
48 EXPECT(status); | |
49 JumpPattern jump1(test->entry(), test->code()); | |
50 EXPECT_EQ(StubCode::InvokeDartCode_entry()->label().address(), | |
51 jump1.TargetAddress()); | |
52 JumpPattern jump2(test->entry() + jump1.pattern_length_in_bytes(), | |
53 test->code()); | |
54 const Code& array_stub = | |
55 Code::Handle(StubCode::AllocateArray_entry()->code()); | |
56 EXPECT_EQ(array_stub.EntryPoint(), jump2.TargetAddress()); | |
57 uword target1 = jump1.TargetAddress(); | |
58 uword target2 = jump2.TargetAddress(); | |
59 jump1.SetTargetAddress(target2); | |
60 jump2.SetTargetAddress(target1); | |
61 EXPECT_EQ(array_stub.EntryPoint(), jump1.TargetAddress()); | |
62 EXPECT_EQ(StubCode::InvokeDartCode_entry()->label().address(), | |
63 jump2.TargetAddress()); | |
64 } | |
65 | |
66 } // namespace dart | 34 } // namespace dart |
67 | 35 |
68 #endif // defined TARGET_ARCH_MIPS | 36 #endif // defined TARGET_ARCH_MIPS |
OLD | NEW |