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

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

Issue 10832150: Get rid of ast node ids. (Closed) Base URL: http://dart.googlecode.com/svn/branches/bleeding_edge/dart/
Patch Set: Created 8 years, 4 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/code_descriptors.h ('k') | runtime/vm/code_generator.cc » ('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 "vm/code_descriptors.h" 5 #include "vm/code_descriptors.h"
6 6
7 namespace dart { 7 namespace dart {
8 8
9 void DescriptorList::AddDescriptor(PcDescriptors::Kind kind, 9 void DescriptorList::AddDescriptor(PcDescriptors::Kind kind,
10 intptr_t pc_offset, 10 intptr_t pc_offset,
11 intptr_t node_id, 11 intptr_t deopt_id,
12 intptr_t token_index, 12 intptr_t token_index,
13 intptr_t try_index) { 13 intptr_t try_index) {
14 struct PcDesc data; 14 struct PcDesc data;
15 data.pc_offset = pc_offset; 15 data.pc_offset = pc_offset;
16 data.kind = kind; 16 data.kind = kind;
17 data.node_id = node_id; 17 data.deopt_id = deopt_id;
18 data.token_index = token_index; 18 data.token_index = token_index;
19 data.try_index = try_index; 19 data.try_index = try_index;
20 list_.Add(data); 20 list_.Add(data);
21 } 21 }
22 22
23 23
24 void DescriptorList::AddDeoptInfo(intptr_t pc_offset, 24 void DescriptorList::AddDeoptInfo(intptr_t pc_offset,
25 intptr_t node_id, 25 intptr_t deopt_id,
26 intptr_t token_index, 26 intptr_t token_index,
27 intptr_t deopt_array_index) { 27 intptr_t deopt_array_index) {
28 struct PcDesc data; 28 struct PcDesc data;
29 data.pc_offset = pc_offset; 29 data.pc_offset = pc_offset;
30 data.kind = PcDescriptors::kDeoptIndex; 30 data.kind = PcDescriptors::kDeoptIndex;
31 data.node_id = node_id; 31 data.deopt_id = deopt_id;
32 data.token_index = token_index; 32 data.token_index = token_index;
33 // Try_index is reused for deopt_array_index. 33 // Try_index is reused for deopt_array_index.
34 data.try_index = deopt_array_index; 34 data.try_index = deopt_array_index;
35 list_.Add(data); 35 list_.Add(data);
36 } 36 }
37 37
38 38
39 RawPcDescriptors* DescriptorList::FinalizePcDescriptors(uword entry_point) { 39 RawPcDescriptors* DescriptorList::FinalizePcDescriptors(uword entry_point) {
40 intptr_t num_descriptors = Length(); 40 intptr_t num_descriptors = Length();
41 const PcDescriptors& descriptors = 41 const PcDescriptors& descriptors =
42 PcDescriptors::Handle(PcDescriptors::New(num_descriptors)); 42 PcDescriptors::Handle(PcDescriptors::New(num_descriptors));
43 for (intptr_t i = 0; i < num_descriptors; i++) { 43 for (intptr_t i = 0; i < num_descriptors; i++) {
44 descriptors.AddDescriptor(i, 44 descriptors.AddDescriptor(i,
45 (entry_point + PcOffset(i)), 45 (entry_point + PcOffset(i)),
46 Kind(i), 46 Kind(i),
47 NodeId(i), 47 DeoptId(i),
48 TokenIndex(i), 48 TokenPos(i),
49 TryIndex(i)); 49 TryIndex(i));
50 } 50 }
51 return descriptors.raw(); 51 return descriptors.raw();
52 } 52 }
53 53
54 54
55 void StackmapTableBuilder::AddEntry(intptr_t pc_offset, 55 void StackmapTableBuilder::AddEntry(intptr_t pc_offset,
56 BitmapBuilder* bitmap) { 56 BitmapBuilder* bitmap) {
57 stack_map_ = Stackmap::New(pc_offset, bitmap); 57 stack_map_ = Stackmap::New(pc_offset, bitmap);
58 list_.Add(stack_map_); 58 list_.Add(stack_map_);
(...skipping 32 matching lines...) Expand 10 before | Expand all | Expand 10 after
91 } 91 }
92 92
93 93
94 RawStackmap* StackmapTableBuilder::Map(int index) const { 94 RawStackmap* StackmapTableBuilder::Map(int index) const {
95 Stackmap& map = Stackmap::Handle(); 95 Stackmap& map = Stackmap::Handle();
96 map ^= list_.At(index); 96 map ^= list_.At(index);
97 return map.raw(); 97 return map.raw();
98 } 98 }
99 99
100 } // namespace dart 100 } // namespace dart
OLDNEW
« no previous file with comments | « runtime/vm/code_descriptors.h ('k') | runtime/vm/code_generator.cc » ('j') | no next file with comments »

Powered by Google App Engine
This is Rietveld 408576698