Chromium Code Reviews
chromiumcodereview-hr@appspot.gserviceaccount.com (chromiumcodereview-hr) | Please choose your nickname with Settings | Help | Chromium Project | Gerrit Changes | Sign out
(133)

Side by Side Diff: test/cctest/compiler/test-code-stub-assembler.cc

Issue 1475953002: [stubs] A new approach to TF stubs (Closed) Base URL: https://chromium.googlesource.com/v8/v8.git@master
Patch Set: Merge with ToT Created 5 years ago
Use n/p to move between diff chunks; N/P to move between comments. Draft comments are only viewable by you.
Jump to:
View unified diff | Download patch
OLDNEW
(Empty)
1 // Copyright 2015 the V8 project authors. All rights reserved.
2 // Use of this source code is governed by a BSD-style license that can be
3 // found in the LICENSE file.
4
5 #include "src/interface-descriptors.h"
6 #include "src/isolate.h"
7 #include "test/cctest/compiler/function-tester.h"
8
9 namespace v8 {
10 namespace internal {
11 namespace compiler {
12
13
14 static Isolate* GetIsolate() {
Michael Starzinger 2015/12/01 18:06:53 nit: This is similar to what CcTest::InitIsolateOn
danno 2015/12/02 07:00:19 Done.
15 CcTest::InitializeVM();
16 return CcTest::i_isolate();
17 }
18
19 class CodeStubAssemblerTester : public CodeStubAssembler {
20 public:
21 CodeStubAssemblerTester(Isolate* isolate,
22 const CallInterfaceDescriptor& descriptor)
23 : CodeStubAssembler(isolate, isolate->runtime_zone(), descriptor,
24 Code::STUB, "test"),
25 scope_(isolate) {}
26
27 private:
28 HandleScope scope_;
29 LocalContext context_;
30 };
31
32
33 TEST(SimpleSmiReturn) {
34 Isolate* isolate(GetIsolate());
35 VoidDescriptor descriptor(isolate);
36 CodeStubAssemblerTester m(isolate, descriptor);
37 m.Return(m.SmiTag(m.Int32Constant(37)));
38 Handle<Code> code = m.GenerateCode();
39 FunctionTester ft(descriptor, code);
40 MaybeHandle<Object> result = ft.Call();
41 CHECK_EQ(37, Handle<Smi>::cast(result.ToHandleChecked())->value());
42 }
43
44
45 TEST(SimpleIntPtrReturn) {
46 Isolate* isolate(GetIsolate());
47 VoidDescriptor descriptor(isolate);
48 CodeStubAssemblerTester m(isolate, descriptor);
49 int test;
50 m.Return(m.IntPtrConstant(reinterpret_cast<intptr_t>(&test)));
51 Handle<Code> code = m.GenerateCode();
52 FunctionTester ft(descriptor, code);
53 MaybeHandle<Object> result = ft.Call();
54 CHECK_EQ(reinterpret_cast<intptr_t>(&test),
55 reinterpret_cast<intptr_t>(*result.ToHandleChecked()));
56 }
57
58
59 TEST(SimpleDoubleReturn) {
60 Isolate* isolate(GetIsolate());
61 VoidDescriptor descriptor(isolate);
62 CodeStubAssemblerTester m(isolate, descriptor);
63 m.Return(m.NumberConstant(0.5));
64 Handle<Code> code = m.GenerateCode();
65 FunctionTester ft(descriptor, code);
66 MaybeHandle<Object> result = ft.Call();
67 CHECK_EQ(0.5, Handle<HeapNumber>::cast(result.ToHandleChecked())->value());
68 }
69
70
71 TEST(SimpleCallRuntime1Arg) {
72 Isolate* isolate(GetIsolate());
73 VoidDescriptor descriptor(isolate);
74 CodeStubAssemblerTester m(isolate, descriptor);
75 Node* context = m.HeapConstant(Handle<Context>(isolate->native_context()));
76 Node* b = m.SmiTag(m.Int32Constant(256));
77 m.Return(m.CallRuntime(Runtime::kMathSqrt, context, b));
78 Handle<Code> code = m.GenerateCode();
79 FunctionTester ft(descriptor, code);
80 MaybeHandle<Object> result = ft.Call();
81 CHECK_EQ(16, Handle<Smi>::cast(result.ToHandleChecked())->value());
82 }
83
84
85 TEST(SimpleTailCallRuntime1Arg) {
86 Isolate* isolate(GetIsolate());
87 VoidDescriptor descriptor(isolate);
88 CodeStubAssemblerTester m(isolate, descriptor);
89 Node* context = m.HeapConstant(Handle<Context>(isolate->native_context()));
90 Node* b = m.SmiTag(m.Int32Constant(256));
91 m.TailCallRuntime(Runtime::kMathSqrt, context, b);
92 Handle<Code> code = m.GenerateCode();
93 FunctionTester ft(descriptor, code);
94 MaybeHandle<Object> result = ft.Call();
95 CHECK_EQ(16, Handle<Smi>::cast(result.ToHandleChecked())->value());
96 }
97
98
99 TEST(SimpleCallRuntime2Arg) {
100 Isolate* isolate(GetIsolate());
101 VoidDescriptor descriptor(isolate);
102 CodeStubAssemblerTester m(isolate, descriptor);
103 Node* context = m.HeapConstant(Handle<Context>(isolate->native_context()));
104 Node* a = m.SmiTag(m.Int32Constant(2));
105 Node* b = m.SmiTag(m.Int32Constant(4));
106 m.Return(m.CallRuntime(Runtime::kMathPow, context, a, b));
107 Handle<Code> code = m.GenerateCode();
108 FunctionTester ft(descriptor, code);
109 MaybeHandle<Object> result = ft.Call();
110 CHECK_EQ(16, Handle<Smi>::cast(result.ToHandleChecked())->value());
111 }
112
113
114 TEST(SimpleTailCallRuntime2Arg) {
115 Isolate* isolate(GetIsolate());
116 VoidDescriptor descriptor(isolate);
117 CodeStubAssemblerTester m(isolate, descriptor);
118 Node* context = m.HeapConstant(Handle<Context>(isolate->native_context()));
119 Node* a = m.SmiTag(m.Int32Constant(2));
120 Node* b = m.SmiTag(m.Int32Constant(4));
121 m.TailCallRuntime(Runtime::kMathPow, context, a, b);
122 Handle<Code> code = m.GenerateCode();
123 FunctionTester ft(descriptor, code);
124 MaybeHandle<Object> result = ft.Call();
125 CHECK_EQ(16, Handle<Smi>::cast(result.ToHandleChecked())->value());
126 }
127
128 } // namespace compiler
129 } // namespace internal
130 } // namespace v8
OLDNEW

Powered by Google App Engine
This is Rietveld 408576698