OLD | NEW |
---|---|
1 // Copyright (c) 2012, the Dart project authors. Please see the AUTHORS file | 1 // Copyright (c) 2012, 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/benchmark_test.h" | 5 #include "vm/benchmark_test.h" |
6 | 6 |
7 #include "bin/file.h" | 7 #include "bin/file.h" |
8 | 8 |
9 #include "platform/assert.h" | 9 #include "platform/assert.h" |
10 | 10 |
(...skipping 123 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... | |
134 EXPECT_EQ(7, value2); | 134 EXPECT_EQ(7, value2); |
135 | 135 |
136 // Return param + receiver.field. | 136 // Return param + receiver.field. |
137 Dart_SetReturnValue(args, Dart_NewInteger(value1 * value2)); | 137 Dart_SetReturnValue(args, Dart_NewInteger(value1 * value2)); |
138 Dart_ExitScope(); | 138 Dart_ExitScope(); |
139 } | 139 } |
140 | 140 |
141 | 141 |
142 static Dart_NativeFunction bm_uda_lookup(Dart_Handle name, int argument_count) { | 142 static Dart_NativeFunction bm_uda_lookup(Dart_Handle name, int argument_count) { |
143 const char* cstr = NULL; | 143 const char* cstr = NULL; |
144 Dart_Handle result = Dart_StringToCString(name, &cstr); | 144 Dart_Handle result = Dart_StringAsCString(name, &cstr); |
145 EXPECT_VALID(result); | 145 EXPECT_VALID(result); |
146 if (strcmp(cstr, "init") == 0) { | 146 if (strcmp(cstr, "init") == 0) { |
147 return InitNativeFields; | 147 return InitNativeFields; |
148 } else { | 148 } else { |
149 return UseDartApi; | 149 return UseDartApi; |
150 } | 150 } |
151 } | 151 } |
152 | 152 |
153 | 153 |
154 BENCHMARK(UseDartApi) { | 154 BENCHMARK(UseDartApi) { |
(...skipping 11 matching lines...) Expand all Loading... | |
166 " c.method(i,7);\n" | 166 " c.method(i,7);\n" |
167 " }\n" | 167 " }\n" |
168 "}\n"; | 168 "}\n"; |
169 | 169 |
170 Dart_Handle lib = TestCase::LoadTestScript( | 170 Dart_Handle lib = TestCase::LoadTestScript( |
171 kScriptChars, | 171 kScriptChars, |
172 reinterpret_cast<Dart_NativeEntryResolver>(bm_uda_lookup)); | 172 reinterpret_cast<Dart_NativeEntryResolver>(bm_uda_lookup)); |
173 | 173 |
174 // Create a native wrapper class with native fields. | 174 // Create a native wrapper class with native fields. |
175 Dart_Handle result = Dart_CreateNativeWrapperClass( | 175 Dart_Handle result = Dart_CreateNativeWrapperClass( |
176 lib, | 176 lib, NewString("NativeFieldsWrapper"), 1); |
177 Dart_NewString("NativeFieldsWrapper"), | |
178 1); | |
179 EXPECT_VALID(result); | 177 EXPECT_VALID(result); |
180 | 178 |
181 Dart_Handle args[1]; | 179 Dart_Handle args[1]; |
182 args[0] = Dart_NewInteger(kNumIterations); | 180 args[0] = Dart_NewInteger(kNumIterations); |
183 | 181 |
184 // Warmup first to avoid compilation jitters. | 182 // Warmup first to avoid compilation jitters. |
185 Dart_Invoke(lib, | 183 Dart_Invoke(lib, NewString("benchmark"), 1, args); |
cshapiro
2012/10/24 23:52:29
Replace this with the macro expansion?
siva
2012/10/26 21:38:29
NewString is now a method.
On 2012/10/24 23:52:29
| |
186 Dart_NewString("benchmark"), | |
187 1, | |
188 args); | |
189 | 184 |
190 Timer timer(true, "UseDartApi benchmark"); | 185 Timer timer(true, "UseDartApi benchmark"); |
191 timer.Start(); | 186 timer.Start(); |
192 Dart_Invoke(lib, | 187 Dart_Invoke(lib, NewString("benchmark"), 1, args); |
193 Dart_NewString("benchmark"), | |
194 1, | |
195 args); | |
196 timer.Stop(); | 188 timer.Stop(); |
197 int64_t elapsed_time = timer.TotalElapsedTime(); | 189 int64_t elapsed_time = timer.TotalElapsedTime(); |
198 benchmark->set_score(elapsed_time); | 190 benchmark->set_score(elapsed_time); |
199 } | 191 } |
200 | 192 |
201 | 193 |
202 // | 194 // |
203 // Measure time accessing internal and external strings. | 195 // Measure time accessing internal and external strings. |
204 // | 196 // |
205 BENCHMARK(DartStringAccess) { | 197 BENCHMARK(DartStringAccess) { |
206 const int kNumIterations = 10000000; | 198 const int kNumIterations = 10000000; |
207 Timer timer(true, "DartStringAccess benchmark"); | 199 Timer timer(true, "DartStringAccess benchmark"); |
208 timer.Start(); | 200 timer.Start(); |
209 Dart_EnterScope(); | 201 Dart_EnterScope(); |
210 | 202 |
211 // Create strings. | 203 // Create strings. |
212 uint8_t data8[] = { 'o', 'n', 'e', 0xFF }; | 204 uint8_t data8[] = { 'o', 'n', 'e', 0xFF }; |
213 int external_peer_data = 123; | 205 int external_peer_data = 123; |
214 Dart_Handle external_string = Dart_NewExternalString8(data8, | 206 Dart_Handle external_string = Dart_NewExternalUTF8String(data8, |
215 ARRAY_SIZE(data8), | 207 ARRAY_SIZE(data8), |
216 &external_peer_data, | 208 &external_peer_data, |
217 NULL); | 209 NULL); |
218 Dart_Handle internal_string = Dart_NewString("two"); | 210 Dart_Handle internal_string = NewString("two"); |
219 | 211 |
220 // Run benchmark. | 212 // Run benchmark. |
221 for (int64_t i = 0; i < kNumIterations; i++) { | 213 for (int64_t i = 0; i < kNumIterations; i++) { |
222 EXPECT(Dart_IsString(internal_string)); | 214 EXPECT(Dart_IsString(internal_string)); |
223 EXPECT(Dart_IsString8(internal_string)); | |
224 EXPECT(Dart_IsString16(internal_string)); | |
225 EXPECT(!Dart_IsExternalString(internal_string)); | 215 EXPECT(!Dart_IsExternalString(internal_string)); |
226 EXPECT_VALID(external_string); | 216 EXPECT_VALID(external_string); |
227 EXPECT(Dart_IsExternalString(external_string)); | 217 EXPECT(Dart_IsExternalString(external_string)); |
228 void* external_peer = NULL; | 218 void* external_peer = NULL; |
229 EXPECT_VALID(Dart_ExternalStringGetPeer(external_string, &external_peer)); | 219 EXPECT_VALID(Dart_ExternalStringGetPeer(external_string, &external_peer)); |
230 EXPECT_EQ(&external_peer_data, external_peer); | 220 EXPECT_EQ(&external_peer_data, external_peer); |
231 } | 221 } |
232 | 222 |
233 Dart_ExitScope(); | 223 Dart_ExitScope(); |
234 timer.Stop(); | 224 timer.Stop(); |
(...skipping 145 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... | |
380 "}" | 370 "}" |
381 "class StackFrameTest {" | 371 "class StackFrameTest {" |
382 " static int testMain() {" | 372 " static int testMain() {" |
383 " First obj = new First();" | 373 " First obj = new First();" |
384 " return obj.method1(1);" | 374 " return obj.method1(1);" |
385 " }" | 375 " }" |
386 "}"; | 376 "}"; |
387 Dart_Handle lib = TestCase::LoadTestScript( | 377 Dart_Handle lib = TestCase::LoadTestScript( |
388 kScriptChars, | 378 kScriptChars, |
389 reinterpret_cast<Dart_NativeEntryResolver>(StackFrameNativeResolver)); | 379 reinterpret_cast<Dart_NativeEntryResolver>(StackFrameNativeResolver)); |
390 Dart_Handle cls = Dart_GetClass(lib, Dart_NewString("StackFrameTest")); | 380 Dart_Handle cls = Dart_GetClass(lib, NewString("StackFrameTest")); |
391 Dart_Handle result = Dart_Invoke(cls, Dart_NewString("testMain"), 0, NULL); | 381 Dart_Handle result = Dart_Invoke(cls, NewString("testMain"), 0, NULL); |
392 EXPECT_VALID(result); | 382 EXPECT_VALID(result); |
393 int64_t elapsed_time = 0; | 383 int64_t elapsed_time = 0; |
394 result = Dart_IntegerToInt64(result, &elapsed_time); | 384 result = Dart_IntegerToInt64(result, &elapsed_time); |
395 EXPECT_VALID(result); | 385 EXPECT_VALID(result); |
396 benchmark->set_score(elapsed_time); | 386 benchmark->set_score(elapsed_time); |
397 } | 387 } |
398 | 388 |
399 } // namespace dart | 389 } // namespace dart |
OLD | NEW |