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 516 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... |
527 uint8_t* buffer; | 527 uint8_t* buffer; |
528 Timer timer(true, "Serialize Null"); | 528 Timer timer(true, "Serialize Null"); |
529 timer.Start(); | 529 timer.Start(); |
530 for (intptr_t i = 0; i < kLoopCount; i++) { | 530 for (intptr_t i = 0; i < kLoopCount; i++) { |
531 StackZone zone(isolate); | 531 StackZone zone(isolate); |
532 MessageWriter writer(&buffer, &message_allocator, true); | 532 MessageWriter writer(&buffer, &message_allocator, true); |
533 writer.WriteMessage(null_object); | 533 writer.WriteMessage(null_object); |
534 intptr_t buffer_len = writer.BytesWritten(); | 534 intptr_t buffer_len = writer.BytesWritten(); |
535 | 535 |
536 // Read object back from the snapshot. | 536 // Read object back from the snapshot. |
537 SnapshotReader reader(buffer, buffer_len, Snapshot::kMessage, isolate); | 537 SnapshotReader reader(buffer, buffer_len, Snapshot::kMessage, isolate, |
| 538 zone.GetZone()); |
538 reader.ReadObject(); | 539 reader.ReadObject(); |
539 } | 540 } |
540 timer.Stop(); | 541 timer.Stop(); |
541 int64_t elapsed_time = timer.TotalElapsedTime(); | 542 int64_t elapsed_time = timer.TotalElapsedTime(); |
542 benchmark->set_score(elapsed_time); | 543 benchmark->set_score(elapsed_time); |
543 } | 544 } |
544 | 545 |
545 | 546 |
546 BENCHMARK(SerializeSmi) { | 547 BENCHMARK(SerializeSmi) { |
547 const Integer& smi_object = Integer::Handle(Smi::New(42)); | 548 const Integer& smi_object = Integer::Handle(Smi::New(42)); |
548 const intptr_t kLoopCount = 1000000; | 549 const intptr_t kLoopCount = 1000000; |
549 Isolate* isolate = Isolate::Current(); | 550 Isolate* isolate = Isolate::Current(); |
550 uint8_t* buffer; | 551 uint8_t* buffer; |
551 Timer timer(true, "Serialize Smi"); | 552 Timer timer(true, "Serialize Smi"); |
552 timer.Start(); | 553 timer.Start(); |
553 for (intptr_t i = 0; i < kLoopCount; i++) { | 554 for (intptr_t i = 0; i < kLoopCount; i++) { |
554 StackZone zone(isolate); | 555 StackZone zone(isolate); |
555 MessageWriter writer(&buffer, &message_allocator, true); | 556 MessageWriter writer(&buffer, &message_allocator, true); |
556 writer.WriteMessage(smi_object); | 557 writer.WriteMessage(smi_object); |
557 intptr_t buffer_len = writer.BytesWritten(); | 558 intptr_t buffer_len = writer.BytesWritten(); |
558 | 559 |
559 // Read object back from the snapshot. | 560 // Read object back from the snapshot. |
560 SnapshotReader reader(buffer, buffer_len, Snapshot::kMessage, isolate); | 561 SnapshotReader reader(buffer, buffer_len, Snapshot::kMessage, isolate, |
| 562 zone.GetZone()); |
561 reader.ReadObject(); | 563 reader.ReadObject(); |
562 } | 564 } |
563 timer.Stop(); | 565 timer.Stop(); |
564 int64_t elapsed_time = timer.TotalElapsedTime(); | 566 int64_t elapsed_time = timer.TotalElapsedTime(); |
565 benchmark->set_score(elapsed_time); | 567 benchmark->set_score(elapsed_time); |
566 } | 568 } |
567 | 569 |
568 | 570 |
569 BENCHMARK(SimpleMessage) { | 571 BENCHMARK(SimpleMessage) { |
570 const Array& array_object = Array::Handle(Array::New(2)); | 572 const Array& array_object = Array::Handle(Array::New(2)); |
571 array_object.SetAt(0, Integer::Handle(Smi::New(42))); | 573 array_object.SetAt(0, Integer::Handle(Smi::New(42))); |
572 array_object.SetAt(1, Object::Handle()); | 574 array_object.SetAt(1, Object::Handle()); |
573 const intptr_t kLoopCount = 1000000; | 575 const intptr_t kLoopCount = 1000000; |
574 Isolate* isolate = Isolate::Current(); | 576 Isolate* isolate = Isolate::Current(); |
575 uint8_t* buffer; | 577 uint8_t* buffer; |
576 Timer timer(true, "Simple Message"); | 578 Timer timer(true, "Simple Message"); |
577 timer.Start(); | 579 timer.Start(); |
578 for (intptr_t i = 0; i < kLoopCount; i++) { | 580 for (intptr_t i = 0; i < kLoopCount; i++) { |
579 StackZone zone(isolate); | 581 StackZone zone(isolate); |
580 MessageWriter writer(&buffer, &malloc_allocator, true); | 582 MessageWriter writer(&buffer, &malloc_allocator, true); |
581 writer.WriteMessage(array_object); | 583 writer.WriteMessage(array_object); |
582 intptr_t buffer_len = writer.BytesWritten(); | 584 intptr_t buffer_len = writer.BytesWritten(); |
583 | 585 |
584 // Read object back from the snapshot. | 586 // Read object back from the snapshot. |
585 SnapshotReader reader(buffer, buffer_len, Snapshot::kMessage, isolate); | 587 SnapshotReader reader(buffer, buffer_len, Snapshot::kMessage, isolate, |
| 588 zone.GetZone()); |
586 reader.ReadObject(); | 589 reader.ReadObject(); |
587 free(buffer); | 590 free(buffer); |
588 } | 591 } |
589 timer.Stop(); | 592 timer.Stop(); |
590 int64_t elapsed_time = timer.TotalElapsedTime(); | 593 int64_t elapsed_time = timer.TotalElapsedTime(); |
591 benchmark->set_score(elapsed_time); | 594 benchmark->set_score(elapsed_time); |
592 } | 595 } |
593 | 596 |
594 } // namespace dart | 597 } // namespace dart |
OLD | NEW |