| 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/builtin.h" | 7 #include "bin/builtin.h" |
| 8 #include "bin/file.h" | 8 #include "bin/file.h" |
| 9 | 9 |
| 10 #include "platform/assert.h" | 10 #include "platform/assert.h" |
| (...skipping 209 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... |
| 220 } | 220 } |
| 221 | 221 |
| 222 | 222 |
| 223 // | 223 // |
| 224 // Measure compile of all dart2js(compiler) functions. | 224 // Measure compile of all dart2js(compiler) functions. |
| 225 // | 225 // |
| 226 static char* ComputeDart2JSPath(const char* arg) { | 226 static char* ComputeDart2JSPath(const char* arg) { |
| 227 char buffer[2048]; | 227 char buffer[2048]; |
| 228 char* dart2js_path = strdup(File::GetCanonicalPath(arg)); | 228 char* dart2js_path = strdup(File::GetCanonicalPath(arg)); |
| 229 const char* compiler_path = | 229 const char* compiler_path = |
| 230 "%s%ssdk%slib%s_internal%scompiler%scompiler.dart"; | 230 "%s%spkg%scompiler%slib%scompiler.dart"; |
| 231 const char* path_separator = File::PathSeparator(); | 231 const char* path_separator = File::PathSeparator(); |
| 232 ASSERT(path_separator != NULL && strlen(path_separator) == 1); | 232 ASSERT(path_separator != NULL && strlen(path_separator) == 1); |
| 233 char* ptr = strrchr(dart2js_path, *path_separator); | 233 char* ptr = strrchr(dart2js_path, *path_separator); |
| 234 while (ptr != NULL) { | 234 while (ptr != NULL) { |
| 235 *ptr = '\0'; | 235 *ptr = '\0'; |
| 236 OS::SNPrint(buffer, 2048, compiler_path, | 236 OS::SNPrint(buffer, 2048, compiler_path, |
| 237 dart2js_path, | 237 dart2js_path, |
| 238 path_separator, | 238 path_separator, |
| 239 path_separator, | 239 path_separator, |
| 240 path_separator, | 240 path_separator, |
| (...skipping 17 matching lines...) Expand all Loading... |
| 258 | 258 |
| 259 | 259 |
| 260 static Dart_NativeFunction NativeResolver(Dart_Handle name, | 260 static Dart_NativeFunction NativeResolver(Dart_Handle name, |
| 261 int arg_count, | 261 int arg_count, |
| 262 bool* auto_setup_scope) { | 262 bool* auto_setup_scope) { |
| 263 ASSERT(auto_setup_scope != NULL); | 263 ASSERT(auto_setup_scope != NULL); |
| 264 *auto_setup_scope = false; | 264 *auto_setup_scope = false; |
| 265 return &func; | 265 return &func; |
| 266 } | 266 } |
| 267 | 267 |
| 268 static void SetupDart2JSPackagePath() { |
| 269 Dart_Handle builtin_lib = |
| 270 bin::Builtin::LoadAndCheckLibrary(bin::Builtin::kBuiltinLibrary); |
| 271 DART_CHECK_VALID(builtin_lib); |
| 272 |
| 273 bool worked = bin::DartUtils::SetOriginalWorkingDirectory(); |
| 274 EXPECT(worked); |
| 275 char buffer[2048]; |
| 276 char* executable_path = |
| 277 strdup(File::GetCanonicalPath(Benchmark::Executable())); |
| 278 const char* packages_path = "%s%s..%spackages"; |
| 279 const char* path_separator = File::PathSeparator(); |
| 280 OS::SNPrint(buffer, 2048, packages_path, |
| 281 executable_path, path_separator, path_separator); |
| 282 bin::DartUtils::PrepareForScriptLoading(buffer, builtin_lib); |
| 283 } |
| 268 | 284 |
| 269 BENCHMARK(Dart2JSCompileAll) { | 285 BENCHMARK(Dart2JSCompileAll) { |
| 270 bin::Builtin::SetNativeResolver(bin::Builtin::kBuiltinLibrary); | 286 bin::Builtin::SetNativeResolver(bin::Builtin::kBuiltinLibrary); |
| 271 bin::Builtin::SetNativeResolver(bin::Builtin::kIOLibrary); | 287 bin::Builtin::SetNativeResolver(bin::Builtin::kIOLibrary); |
| 288 SetupDart2JSPackagePath(); |
| 272 char* dart_root = ComputeDart2JSPath(Benchmark::Executable()); | 289 char* dart_root = ComputeDart2JSPath(Benchmark::Executable()); |
| 273 char* script = NULL; | 290 char* script = NULL; |
| 274 if (dart_root != NULL) { | 291 if (dart_root != NULL) { |
| 275 Isolate* isolate = Isolate::Current(); | 292 Isolate* isolate = Isolate::Current(); |
| 276 HANDLESCOPE(isolate); | 293 HANDLESCOPE(isolate); |
| 277 const char* kFormatStr = | 294 const char* kFormatStr = |
| 278 "import '%s/sdk/lib/_internal/compiler/compiler.dart';"; | 295 "import '%s/pkg/compiler/lib/compiler.dart';"; |
| 279 intptr_t len = OS::SNPrint(NULL, 0, kFormatStr, dart_root) + 1; | 296 intptr_t len = OS::SNPrint(NULL, 0, kFormatStr, dart_root) + 1; |
| 280 script = reinterpret_cast<char*>(malloc(len)); | 297 script = reinterpret_cast<char*>(malloc(len)); |
| 281 EXPECT(script != NULL); | 298 EXPECT(script != NULL); |
| 282 OS::SNPrint(script, len, kFormatStr, dart_root); | 299 OS::SNPrint(script, len, kFormatStr, dart_root); |
| 283 Dart_Handle lib = TestCase::LoadTestScript( | 300 Dart_Handle lib = TestCase::LoadTestScript( |
| 284 script, | 301 script, |
| 285 reinterpret_cast<Dart_NativeEntryResolver>(NativeResolver)); | 302 reinterpret_cast<Dart_NativeEntryResolver>(NativeResolver)); |
| 286 EXPECT_VALID(lib); | 303 EXPECT_VALID(lib); |
| 287 } else { | 304 } else { |
| 288 Dart_Handle lib = TestCase::LoadTestScript( | 305 Dart_Handle lib = TestCase::LoadTestScript( |
| 289 "import 'sdk/lib/_internal/compiler/compiler.dart';", | 306 "import 'pkg/compiler/lib/compiler.dart';", |
| 290 reinterpret_cast<Dart_NativeEntryResolver>(NativeResolver)); | 307 reinterpret_cast<Dart_NativeEntryResolver>(NativeResolver)); |
| 291 EXPECT_VALID(lib); | 308 EXPECT_VALID(lib); |
| 292 } | 309 } |
| 293 Timer timer(true, "Compile all of dart2js benchmark"); | 310 Timer timer(true, "Compile all of dart2js benchmark"); |
| 294 timer.Start(); | 311 timer.Start(); |
| 295 Dart_Handle result = Dart_CompileAll(); | 312 Dart_Handle result = Dart_CompileAll(); |
| 296 EXPECT_VALID(result); | 313 EXPECT_VALID(result); |
| 297 timer.Stop(); | 314 timer.Stop(); |
| 298 int64_t elapsed_time = timer.TotalElapsedTime(); | 315 int64_t elapsed_time = timer.TotalElapsedTime(); |
| 299 benchmark->set_score(elapsed_time); | 316 benchmark->set_score(elapsed_time); |
| (...skipping 268 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... |
| 568 SnapshotReader reader(buffer, buffer_len, Snapshot::kMessage, isolate); | 585 SnapshotReader reader(buffer, buffer_len, Snapshot::kMessage, isolate); |
| 569 reader.ReadObject(); | 586 reader.ReadObject(); |
| 570 free(buffer); | 587 free(buffer); |
| 571 } | 588 } |
| 572 timer.Stop(); | 589 timer.Stop(); |
| 573 int64_t elapsed_time = timer.TotalElapsedTime(); | 590 int64_t elapsed_time = timer.TotalElapsedTime(); |
| 574 benchmark->set_score(elapsed_time); | 591 benchmark->set_score(elapsed_time); |
| 575 } | 592 } |
| 576 | 593 |
| 577 } // namespace dart | 594 } // namespace dart |
| OLD | NEW |