Chromium Code Reviews| 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 "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 Loading... | |
| 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 builder->AddDescriptor(RawPcDescriptors::kOther, 10, 1, 20, 1); | |
| 2872 builder->AddDescriptor(RawPcDescriptors::kDeopt, 20, 2, 30, 0); | |
| 2873 builder->AddDescriptor(RawPcDescriptors::kOther, 30, 3, 40, 1); | |
| 2874 builder->AddDescriptor(RawPcDescriptors::kOther, 10, 4, 40, 2); | |
| 2875 builder->AddDescriptor(RawPcDescriptors::kOther, 10, 5, 80, 3); | |
| 2876 builder->AddDescriptor(RawPcDescriptors::kOther, 80, 6, 150, 3); | |
|
Florian Schneider
2015/05/11 11:10:56
Please add a few test cases with larger deltas is
rmacnak
2015/05/11 20:27:04
Done.
| |
| 2877 | |
| 2870 PcDescriptors& descriptors = PcDescriptors::Handle(); | 2878 PcDescriptors& descriptors = PcDescriptors::Handle(); |
| 2871 descriptors ^= PcDescriptors::New(kNumEntries, true); | 2879 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 | 2880 |
| 2879 extern void GenerateIncrement(Assembler* assembler); | 2881 extern void GenerateIncrement(Assembler* assembler); |
| 2880 Assembler _assembler_; | 2882 Assembler _assembler_; |
| 2881 GenerateIncrement(&_assembler_); | 2883 GenerateIncrement(&_assembler_); |
| 2882 Code& code = Code::Handle(Code::FinalizeCode( | 2884 Code& code = Code::Handle(Code::FinalizeCode( |
| 2883 *CreateFunction("Test_Code"), &_assembler_)); | 2885 *CreateFunction("Test_Code"), &_assembler_)); |
| 2884 code.set_pc_descriptors(descriptors); | 2886 code.set_pc_descriptors(descriptors); |
| 2885 | 2887 |
| 2886 // Verify the PcDescriptor entries by accessing them. | 2888 // Verify the PcDescriptor entries by accessing them. |
| 2887 const PcDescriptors& pc_descs = PcDescriptors::Handle(code.pc_descriptors()); | 2889 const PcDescriptors& pc_descs = PcDescriptors::Handle(code.pc_descriptors()); |
| (...skipping 24 matching lines...) Expand all Loading... | |
| 2912 | 2914 |
| 2913 EXPECT_EQ(3, iter.TryIndex()); | 2915 EXPECT_EQ(3, iter.TryIndex()); |
| 2914 EXPECT_EQ(static_cast<uword>(80), iter.PcOffset()); | 2916 EXPECT_EQ(static_cast<uword>(80), iter.PcOffset()); |
| 2915 EXPECT_EQ(150, iter.TokenPos()); | 2917 EXPECT_EQ(150, iter.TokenPos()); |
| 2916 EXPECT_EQ(RawPcDescriptors::kOther, iter.Kind()); | 2918 EXPECT_EQ(RawPcDescriptors::kOther, iter.Kind()); |
| 2917 | 2919 |
| 2918 EXPECT_EQ(false, iter.MoveNext()); | 2920 EXPECT_EQ(false, iter.MoveNext()); |
| 2919 } | 2921 } |
| 2920 | 2922 |
| 2921 | 2923 |
| 2922 TEST_CASE(PcDescriptorsCompressed) { | |
| 2923 const int kNumEntries = 6; | |
| 2924 // Add PcDescriptors to the code. | |
| 2925 PcDescriptors& descriptors = PcDescriptors::Handle(); | |
| 2926 // PcDescriptors have no try-index. | |
| 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 | |
| 2935 extern void GenerateIncrement(Assembler* assembler); | |
| 2936 Assembler _assembler_; | |
| 2937 GenerateIncrement(&_assembler_); | |
| 2938 Code& code = Code::Handle(Code::FinalizeCode( | |
| 2939 *CreateFunction("Test_Code"), &_assembler_)); | |
| 2940 code.set_pc_descriptors(descriptors); | |
| 2941 | |
| 2942 // Verify the PcDescriptor entries by accessing them. | |
| 2943 const PcDescriptors& pc_descs = PcDescriptors::Handle(code.pc_descriptors()); | |
| 2944 PcDescriptors::Iterator iter(pc_descs, RawPcDescriptors::kAnyKind); | |
| 2945 | |
| 2946 EXPECT_EQ(true, iter.MoveNext()); | |
| 2947 EXPECT_EQ(static_cast<uword>(10), iter.PcOffset()); | |
| 2948 EXPECT_EQ(-1, iter.TryIndex()); | |
| 2949 EXPECT_EQ(1, iter.DeoptId()); | |
| 2950 EXPECT_EQ(20, iter.TokenPos()); | |
| 2951 | |
| 2952 EXPECT_EQ(true, iter.MoveNext()); | |
| 2953 EXPECT_EQ(true, iter.MoveNext()); | |
| 2954 EXPECT_EQ(true, iter.MoveNext()); | |
| 2955 EXPECT_EQ(true, iter.MoveNext()); | |
| 2956 EXPECT_EQ(true, iter.MoveNext()); | |
| 2957 | |
| 2958 EXPECT_EQ(-1, iter.TryIndex()); | |
| 2959 EXPECT_EQ(static_cast<uword>(80), iter.PcOffset()); | |
| 2960 EXPECT_EQ(150, iter.TokenPos()); | |
| 2961 | |
| 2962 EXPECT_EQ(false, iter.MoveNext()); | |
| 2963 } | |
| 2964 | |
| 2965 | |
| 2966 | |
| 2967 static RawClass* CreateTestClass(const char* name) { | 2924 static RawClass* CreateTestClass(const char* name) { |
| 2968 const String& class_name = String::Handle(Symbols::New(name)); | 2925 const String& class_name = String::Handle(Symbols::New(name)); |
| 2969 const Class& cls = Class::Handle( | 2926 const Class& cls = Class::Handle( |
| 2970 CreateDummyClass(class_name, Script::Handle())); | 2927 CreateDummyClass(class_name, Script::Handle())); |
| 2971 return cls.raw(); | 2928 return cls.raw(); |
| 2972 } | 2929 } |
| 2973 | 2930 |
| 2974 | 2931 |
| 2975 static RawField* CreateTestField(const char* name) { | 2932 static RawField* CreateTestField(const char* name) { |
| 2976 const Class& cls = Class::Handle(CreateTestClass("global:")); | 2933 const Class& cls = Class::Handle(CreateTestClass("global:")); |
| (...skipping 1601 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... | |
| 4578 EXPECT_VALID(h_result); | 4535 EXPECT_VALID(h_result); |
| 4579 Integer& result = Integer::Handle(); | 4536 Integer& result = Integer::Handle(); |
| 4580 result ^= Api::UnwrapHandle(h_result); | 4537 result ^= Api::UnwrapHandle(h_result); |
| 4581 String& foo = String::Handle(String::New("foo")); | 4538 String& foo = String::Handle(String::New("foo")); |
| 4582 Integer& expected = Integer::Handle(); | 4539 Integer& expected = Integer::Handle(); |
| 4583 expected ^= foo.HashCode(); | 4540 expected ^= foo.HashCode(); |
| 4584 EXPECT(result.IsIdenticalTo(expected)); | 4541 EXPECT(result.IsIdenticalTo(expected)); |
| 4585 } | 4542 } |
| 4586 | 4543 |
| 4587 } // namespace dart | 4544 } // namespace dart |
| OLD | NEW |