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

Side by Side Diff: runtime/vm/object_test.cc

Issue 1128183007: Delta encode pc descriptors, and combine pc kind and try index into single field. (Closed) Base URL: https://dart.googlecode.com/svn/branches/bleeding_edge/dart
Patch Set: Created 5 years, 7 months 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 | Annotate | Revision Log
« no previous file with comments | « runtime/vm/object.cc ('k') | runtime/vm/raw_object.h » ('j') | no next file with comments »
Toggle Intra-line Diffs ('i') | Expand Comments ('e') | Collapse Comments ('c') | Show Comments Hide Comments ('s')
OLDNEW
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 "platform/globals.h" 5 #include "platform/globals.h"
6 6
7 #include "vm/assembler.h" 7 #include "vm/assembler.h"
8 #include "vm/class_finalizer.h" 8 #include "vm/class_finalizer.h"
9 #include "vm/dart_api_impl.h" 9 #include "vm/dart_api_impl.h"
10 #include "vm/dart_entry.h" 10 #include "vm/dart_entry.h"
11 #include "vm/debugger.h" 11 #include "vm/debugger.h"
12 #include "vm/isolate.h" 12 #include "vm/isolate.h"
13 #include "vm/object.h" 13 #include "vm/object.h"
14 #include "vm/object_store.h" 14 #include "vm/object_store.h"
15 #include "vm/simulator.h" 15 #include "vm/simulator.h"
16 #include "vm/symbols.h" 16 #include "vm/symbols.h"
17 #include "vm/unit_test.h" 17 #include "vm/unit_test.h"
18 #include "vm/code_descriptors.h"
18 19
19 namespace dart { 20 namespace dart {
20 21
21 DECLARE_FLAG(bool, write_protect_code); 22 DECLARE_FLAG(bool, write_protect_code);
22 23
23 static RawLibrary* CreateDummyLibrary(const String& library_name) { 24 static RawLibrary* CreateDummyLibrary(const String& library_name) {
24 return Library::New(library_name); 25 return Library::New(library_name);
25 } 26 }
26 27
27 28
(...skipping 2830 matching lines...) Expand 10 before | Expand all | Expand 10 after
2858 EXPECT(!handlers.HasCatchAll(0)); 2859 EXPECT(!handlers.HasCatchAll(0));
2859 EXPECT_EQ(20u, info.handler_pc_offset); 2860 EXPECT_EQ(20u, info.handler_pc_offset);
2860 EXPECT_EQ(1, handlers.OuterTryIndex(3)); 2861 EXPECT_EQ(1, handlers.OuterTryIndex(3));
2861 EXPECT_EQ(150u, handlers.HandlerPCOffset(3)); 2862 EXPECT_EQ(150u, handlers.HandlerPCOffset(3));
2862 EXPECT(!handlers.NeedsStacktrace(3)); 2863 EXPECT(!handlers.NeedsStacktrace(3));
2863 EXPECT(handlers.HasCatchAll(3)); 2864 EXPECT(handlers.HasCatchAll(3));
2864 } 2865 }
2865 2866
2866 2867
2867 TEST_CASE(PcDescriptors) { 2868 TEST_CASE(PcDescriptors) {
2868 const int kNumEntries = 6; 2869 DescriptorList* builder = new DescriptorList(0);
2869 // Add PcDescriptors to the code. 2870
2871 // kind, pc_offset, deopt_id, token_pos, try_index
2872 builder->AddDescriptor(RawPcDescriptors::kOther, 10, 1, 20, 1);
2873 builder->AddDescriptor(RawPcDescriptors::kDeopt, 20, 2, 30, 0);
2874 builder->AddDescriptor(RawPcDescriptors::kOther, 30, 3, 40, 1);
2875 builder->AddDescriptor(RawPcDescriptors::kOther, 10, 4, 40, 2);
2876 builder->AddDescriptor(RawPcDescriptors::kOther, 10, 5, 80, 3);
2877 builder->AddDescriptor(RawPcDescriptors::kOther, 80, 6, 150, 3);
2878
2870 PcDescriptors& descriptors = PcDescriptors::Handle(); 2879 PcDescriptors& descriptors = PcDescriptors::Handle();
2871 descriptors ^= PcDescriptors::New(kNumEntries, true); 2880 descriptors ^= builder->FinalizePcDescriptors(0);
2872 descriptors.AddDescriptor(0, 10, RawPcDescriptors::kOther, 1, 20, 1);
2873 descriptors.AddDescriptor(1, 20, RawPcDescriptors::kDeopt, 2, 30, 0);
2874 descriptors.AddDescriptor(2, 30, RawPcDescriptors::kOther, 3, 40, 1);
2875 descriptors.AddDescriptor(3, 10, RawPcDescriptors::kOther, 4, 40, 2);
2876 descriptors.AddDescriptor(4, 10, RawPcDescriptors::kOther, 5, 80, 3);
2877 descriptors.AddDescriptor(5, 80, RawPcDescriptors::kOther, 6, 150, 3);
2878 2881
2879 extern void GenerateIncrement(Assembler* assembler); 2882 extern void GenerateIncrement(Assembler* assembler);
2880 Assembler _assembler_; 2883 Assembler _assembler_;
2881 GenerateIncrement(&_assembler_); 2884 GenerateIncrement(&_assembler_);
2882 Code& code = Code::Handle(Code::FinalizeCode( 2885 Code& code = Code::Handle(Code::FinalizeCode(
2883 *CreateFunction("Test_Code"), &_assembler_)); 2886 *CreateFunction("Test_Code"), &_assembler_));
2884 code.set_pc_descriptors(descriptors); 2887 code.set_pc_descriptors(descriptors);
2885 2888
2886 // Verify the PcDescriptor entries by accessing them. 2889 // Verify the PcDescriptor entries by accessing them.
2887 const PcDescriptors& pc_descs = PcDescriptors::Handle(code.pc_descriptors()); 2890 const PcDescriptors& pc_descs = PcDescriptors::Handle(code.pc_descriptors());
(...skipping 24 matching lines...) Expand all
2912 2915
2913 EXPECT_EQ(3, iter.TryIndex()); 2916 EXPECT_EQ(3, iter.TryIndex());
2914 EXPECT_EQ(static_cast<uword>(80), iter.PcOffset()); 2917 EXPECT_EQ(static_cast<uword>(80), iter.PcOffset());
2915 EXPECT_EQ(150, iter.TokenPos()); 2918 EXPECT_EQ(150, iter.TokenPos());
2916 EXPECT_EQ(RawPcDescriptors::kOther, iter.Kind()); 2919 EXPECT_EQ(RawPcDescriptors::kOther, iter.Kind());
2917 2920
2918 EXPECT_EQ(false, iter.MoveNext()); 2921 EXPECT_EQ(false, iter.MoveNext());
2919 } 2922 }
2920 2923
2921 2924
2922 TEST_CASE(PcDescriptorsCompressed) { 2925 TEST_CASE(PcDescriptorsLargeDeltas) {
2923 const int kNumEntries = 6; 2926 DescriptorList* builder = new DescriptorList(0);
2924 // Add PcDescriptors to the code. 2927
2928 // kind, pc_offset, deopt_id, token_pos, try_index
2929 builder->AddDescriptor(RawPcDescriptors::kOther, 100, 1, 200, 1);
2930 builder->AddDescriptor(RawPcDescriptors::kDeopt, 200, 2, 300, 0);
2931 builder->AddDescriptor(RawPcDescriptors::kOther, 300, 3, 400, 1);
2932 builder->AddDescriptor(RawPcDescriptors::kOther, 100, 4, 0, 2);
2933 builder->AddDescriptor(RawPcDescriptors::kOther, 100, 5, 800, 3);
2934 builder->AddDescriptor(RawPcDescriptors::kOther, 800, 6, 150, 3);
2935
2925 PcDescriptors& descriptors = PcDescriptors::Handle(); 2936 PcDescriptors& descriptors = PcDescriptors::Handle();
2926 // PcDescriptors have no try-index. 2937 descriptors ^= builder->FinalizePcDescriptors(0);
2927 descriptors ^= PcDescriptors::New(kNumEntries, false);
2928 descriptors.AddDescriptor(0, 10, RawPcDescriptors::kOther, 1, 20, -1);
2929 descriptors.AddDescriptor(1, 20, RawPcDescriptors::kDeopt, 2, 30, -1);
2930 descriptors.AddDescriptor(2, 30, RawPcDescriptors::kOther, 3, 40, -1);
2931 descriptors.AddDescriptor(3, 10, RawPcDescriptors::kOther, 4, 40, -1);
2932 descriptors.AddDescriptor(4, 10, RawPcDescriptors::kOther, 5, 80, -1);
2933 descriptors.AddDescriptor(5, 80, RawPcDescriptors::kOther, 6, 150, -1);
2934 2938
2935 extern void GenerateIncrement(Assembler* assembler); 2939 extern void GenerateIncrement(Assembler* assembler);
2936 Assembler _assembler_; 2940 Assembler _assembler_;
2937 GenerateIncrement(&_assembler_); 2941 GenerateIncrement(&_assembler_);
2938 Code& code = Code::Handle(Code::FinalizeCode( 2942 Code& code = Code::Handle(Code::FinalizeCode(
2939 *CreateFunction("Test_Code"), &_assembler_)); 2943 *CreateFunction("Test_Code"), &_assembler_));
2940 code.set_pc_descriptors(descriptors); 2944 code.set_pc_descriptors(descriptors);
2941 2945
2942 // Verify the PcDescriptor entries by accessing them. 2946 // Verify the PcDescriptor entries by accessing them.
2943 const PcDescriptors& pc_descs = PcDescriptors::Handle(code.pc_descriptors()); 2947 const PcDescriptors& pc_descs = PcDescriptors::Handle(code.pc_descriptors());
2944 PcDescriptors::Iterator iter(pc_descs, RawPcDescriptors::kAnyKind); 2948 PcDescriptors::Iterator iter(pc_descs, RawPcDescriptors::kAnyKind);
2945 2949
2946 EXPECT_EQ(true, iter.MoveNext()); 2950 EXPECT_EQ(true, iter.MoveNext());
2947 EXPECT_EQ(static_cast<uword>(10), iter.PcOffset()); 2951 EXPECT_EQ(200, iter.TokenPos());
2948 EXPECT_EQ(-1, iter.TryIndex()); 2952 EXPECT_EQ(1, iter.TryIndex());
2953 EXPECT_EQ(static_cast<uword>(100), iter.PcOffset());
2949 EXPECT_EQ(1, iter.DeoptId()); 2954 EXPECT_EQ(1, iter.DeoptId());
2950 EXPECT_EQ(20, iter.TokenPos()); 2955 EXPECT_EQ(RawPcDescriptors::kOther, iter.Kind());
2951 2956
2952 EXPECT_EQ(true, iter.MoveNext()); 2957 EXPECT_EQ(true, iter.MoveNext());
2958 EXPECT_EQ(300, iter.TokenPos());
2959 EXPECT_EQ(RawPcDescriptors::kDeopt, iter.Kind());
2960
2953 EXPECT_EQ(true, iter.MoveNext()); 2961 EXPECT_EQ(true, iter.MoveNext());
2962 EXPECT_EQ(400, iter.TokenPos());
2963
2954 EXPECT_EQ(true, iter.MoveNext()); 2964 EXPECT_EQ(true, iter.MoveNext());
2965 EXPECT_EQ(0, iter.TokenPos());
2966
2955 EXPECT_EQ(true, iter.MoveNext()); 2967 EXPECT_EQ(true, iter.MoveNext());
2968 EXPECT_EQ(800, iter.TokenPos());
2969
2956 EXPECT_EQ(true, iter.MoveNext()); 2970 EXPECT_EQ(true, iter.MoveNext());
2971 EXPECT_EQ(150, iter.TokenPos());
2957 2972
2958 EXPECT_EQ(-1, iter.TryIndex()); 2973 EXPECT_EQ(3, iter.TryIndex());
2959 EXPECT_EQ(static_cast<uword>(80), iter.PcOffset()); 2974 EXPECT_EQ(static_cast<uword>(800), iter.PcOffset());
2960 EXPECT_EQ(150, iter.TokenPos()); 2975 EXPECT_EQ(150, iter.TokenPos());
2976 EXPECT_EQ(RawPcDescriptors::kOther, iter.Kind());
2961 2977
2962 EXPECT_EQ(false, iter.MoveNext()); 2978 EXPECT_EQ(false, iter.MoveNext());
2963 } 2979 }
2964 2980
2965 2981
2966
2967 static RawClass* CreateTestClass(const char* name) { 2982 static RawClass* CreateTestClass(const char* name) {
2968 const String& class_name = String::Handle(Symbols::New(name)); 2983 const String& class_name = String::Handle(Symbols::New(name));
2969 const Class& cls = Class::Handle( 2984 const Class& cls = Class::Handle(
2970 CreateDummyClass(class_name, Script::Handle())); 2985 CreateDummyClass(class_name, Script::Handle()));
2971 return cls.raw(); 2986 return cls.raw();
2972 } 2987 }
2973 2988
2974 2989
2975 static RawField* CreateTestField(const char* name) { 2990 static RawField* CreateTestField(const char* name) {
2976 const Class& cls = Class::Handle(CreateTestClass("global:")); 2991 const Class& cls = Class::Handle(CreateTestClass("global:"));
(...skipping 1601 matching lines...) Expand 10 before | Expand all | Expand 10 after
4578 EXPECT_VALID(h_result); 4593 EXPECT_VALID(h_result);
4579 Integer& result = Integer::Handle(); 4594 Integer& result = Integer::Handle();
4580 result ^= Api::UnwrapHandle(h_result); 4595 result ^= Api::UnwrapHandle(h_result);
4581 String& foo = String::Handle(String::New("foo")); 4596 String& foo = String::Handle(String::New("foo"));
4582 Integer& expected = Integer::Handle(); 4597 Integer& expected = Integer::Handle();
4583 expected ^= foo.HashCode(); 4598 expected ^= foo.HashCode();
4584 EXPECT(result.IsIdenticalTo(expected)); 4599 EXPECT(result.IsIdenticalTo(expected));
4585 } 4600 }
4586 4601
4587 } // namespace dart 4602 } // namespace dart
OLDNEW
« no previous file with comments | « runtime/vm/object.cc ('k') | runtime/vm/raw_object.h » ('j') | no next file with comments »

Powered by Google App Engine
This is Rietveld 408576698