| 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 155 matching lines...) Expand 10 before | Expand all | Expand 10 after 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); |
| 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 |