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

Side by Side Diff: src/heap/objects-visiting.cc

Issue 1448313002: Prepare to enable in-object properties in subclasses on a case by case basis. (Closed) Base URL: https://chromium.googlesource.com/v8/v8.git@bytecode-array-sizeof-fix
Patch Set: Fix Created 5 years, 1 month 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
« no previous file with comments | « no previous file | src/objects.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 2011 the V8 project authors. All rights reserved. 1 // Copyright 2011 the V8 project authors. All rights reserved.
2 // Use of this source code is governed by a BSD-style license that can be 2 // Use of this source code is governed by a BSD-style license that can be
3 // found in the LICENSE file. 3 // found in the LICENSE file.
4 4
5 #include "src/heap/objects-visiting.h" 5 #include "src/heap/objects-visiting.h"
6 6
7 #include "src/heap/mark-compact-inl.h" 7 #include "src/heap/mark-compact-inl.h"
8 #include "src/heap/objects-visiting-inl.h" 8 #include "src/heap/objects-visiting-inl.h"
9 9
10 namespace v8 { 10 namespace v8 {
(...skipping 61 matching lines...) Expand 10 before | Expand all | Expand 10 after
72 72
73 case CELL_TYPE: 73 case CELL_TYPE:
74 return kVisitCell; 74 return kVisitCell;
75 75
76 case PROPERTY_CELL_TYPE: 76 case PROPERTY_CELL_TYPE:
77 return kVisitPropertyCell; 77 return kVisitPropertyCell;
78 78
79 case WEAK_CELL_TYPE: 79 case WEAK_CELL_TYPE:
80 return kVisitWeakCell; 80 return kVisitWeakCell;
81 81
82 case JS_SET_TYPE:
83 return GetVisitorIdForSize(kVisitStruct, kVisitStructGeneric,
84 JSSet::kSize, has_unboxed_fields);
85
86 case JS_MAP_TYPE:
87 return GetVisitorIdForSize(kVisitStruct, kVisitStructGeneric,
88 JSMap::kSize, has_unboxed_fields);
89
90 case JS_WEAK_MAP_TYPE: 82 case JS_WEAK_MAP_TYPE:
91 case JS_WEAK_SET_TYPE: 83 case JS_WEAK_SET_TYPE:
92 return kVisitJSWeakCollection; 84 return kVisitJSWeakCollection;
93 85
94 case JS_REGEXP_TYPE: 86 case JS_REGEXP_TYPE:
95 return kVisitJSRegExp; 87 return kVisitJSRegExp;
96 88
97 case SHARED_FUNCTION_INFO_TYPE: 89 case SHARED_FUNCTION_INFO_TYPE:
98 return kVisitSharedFunctionInfo; 90 return kVisitSharedFunctionInfo;
99 91
100 case JS_PROXY_TYPE:
101 return GetVisitorIdForSize(kVisitStruct, kVisitStructGeneric,
102 JSProxy::kSize, has_unboxed_fields);
103
104 case JS_FUNCTION_PROXY_TYPE:
105 return GetVisitorIdForSize(kVisitStruct, kVisitStructGeneric,
106 JSFunctionProxy::kSize, has_unboxed_fields);
107
108 case FOREIGN_TYPE:
109 return GetVisitorIdForSize(kVisitDataObject, kVisitDataObjectGeneric,
110 Foreign::kSize, has_unboxed_fields);
111
112 case SYMBOL_TYPE: 92 case SYMBOL_TYPE:
113 return kVisitSymbol; 93 return kVisitSymbol;
114 94
115 case FILLER_TYPE:
116 return kVisitDataObjectGeneric;
117
118 case JS_ARRAY_BUFFER_TYPE: 95 case JS_ARRAY_BUFFER_TYPE:
119 return kVisitJSArrayBuffer; 96 return kVisitJSArrayBuffer;
120 97
121 case JS_TYPED_ARRAY_TYPE: 98 case JS_TYPED_ARRAY_TYPE:
122 return kVisitJSTypedArray; 99 return kVisitJSTypedArray;
123 100
124 case JS_DATA_VIEW_TYPE: 101 case JS_DATA_VIEW_TYPE:
125 return kVisitJSDataView; 102 return kVisitJSDataView;
126 103
127 case JS_OBJECT_TYPE: 104 case JS_OBJECT_TYPE:
128 case JS_CONTEXT_EXTENSION_OBJECT_TYPE: 105 case JS_CONTEXT_EXTENSION_OBJECT_TYPE:
129 case JS_GENERATOR_OBJECT_TYPE: 106 case JS_GENERATOR_OBJECT_TYPE:
130 case JS_MODULE_TYPE: 107 case JS_MODULE_TYPE:
131 case JS_VALUE_TYPE: 108 case JS_VALUE_TYPE:
132 case JS_DATE_TYPE: 109 case JS_DATE_TYPE:
133 case JS_ARRAY_TYPE: 110 case JS_ARRAY_TYPE:
134 case JS_GLOBAL_PROXY_TYPE: 111 case JS_GLOBAL_PROXY_TYPE:
135 case JS_GLOBAL_OBJECT_TYPE: 112 case JS_GLOBAL_OBJECT_TYPE:
136 case JS_MESSAGE_OBJECT_TYPE: 113 case JS_MESSAGE_OBJECT_TYPE:
137 case JS_SET_ITERATOR_TYPE: 114 case JS_SET_ITERATOR_TYPE:
138 case JS_MAP_ITERATOR_TYPE: 115 case JS_MAP_ITERATOR_TYPE:
139 case JS_ITERATOR_RESULT_TYPE: 116 case JS_ITERATOR_RESULT_TYPE:
140 return GetVisitorIdForSize(kVisitJSObject, kVisitJSObjectGeneric, 117 return GetVisitorIdForSize(kVisitJSObject, kVisitJSObjectGeneric,
141 instance_size, has_unboxed_fields); 118 instance_size, has_unboxed_fields);
142 119
143 case JS_FUNCTION_TYPE: 120 case JS_FUNCTION_TYPE:
144 return kVisitJSFunction; 121 return kVisitJSFunction;
145 122
123 case FILLER_TYPE:
124 if (instance_size == kPointerSize) return kVisitDataObjectGeneric;
125 // Fall through.
126 case FOREIGN_TYPE:
146 case HEAP_NUMBER_TYPE: 127 case HEAP_NUMBER_TYPE:
147 case MUTABLE_HEAP_NUMBER_TYPE: 128 case MUTABLE_HEAP_NUMBER_TYPE:
148 case SIMD128_VALUE_TYPE: 129 case SIMD128_VALUE_TYPE:
149 return GetVisitorIdForSize(kVisitDataObject, kVisitDataObjectGeneric, 130 return GetVisitorIdForSize(kVisitDataObject, kVisitDataObjectGeneric,
150 instance_size, has_unboxed_fields); 131 instance_size, has_unboxed_fields);
151 132
152 case FIXED_UINT8_ARRAY_TYPE: 133 case FIXED_UINT8_ARRAY_TYPE:
153 case FIXED_INT8_ARRAY_TYPE: 134 case FIXED_INT8_ARRAY_TYPE:
154 case FIXED_UINT16_ARRAY_TYPE: 135 case FIXED_UINT16_ARRAY_TYPE:
155 case FIXED_INT16_ARRAY_TYPE: 136 case FIXED_INT16_ARRAY_TYPE:
156 case FIXED_UINT32_ARRAY_TYPE: 137 case FIXED_UINT32_ARRAY_TYPE:
157 case FIXED_INT32_ARRAY_TYPE: 138 case FIXED_INT32_ARRAY_TYPE:
158 case FIXED_FLOAT32_ARRAY_TYPE: 139 case FIXED_FLOAT32_ARRAY_TYPE:
159 case FIXED_UINT8_CLAMPED_ARRAY_TYPE: 140 case FIXED_UINT8_CLAMPED_ARRAY_TYPE:
160 return kVisitFixedTypedArray; 141 return kVisitFixedTypedArray;
161 142
162 case FIXED_FLOAT64_ARRAY_TYPE: 143 case FIXED_FLOAT64_ARRAY_TYPE:
163 return kVisitFixedFloat64Array; 144 return kVisitFixedFloat64Array;
164 145
165 #define MAKE_STRUCT_CASE(NAME, Name, name) case NAME##_TYPE: 146 #define MAKE_STRUCT_CASE(NAME, Name, name) case NAME##_TYPE:
166 STRUCT_LIST(MAKE_STRUCT_CASE) 147 STRUCT_LIST(MAKE_STRUCT_CASE)
167 #undef MAKE_STRUCT_CASE 148 #undef MAKE_STRUCT_CASE
168 if (instance_type == ALLOCATION_SITE_TYPE) { 149 if (instance_type == ALLOCATION_SITE_TYPE) {
169 return kVisitAllocationSite; 150 return kVisitAllocationSite;
170 } 151 }
171 152 // Fall through.
Michael Starzinger 2015/11/17 09:35:40 IMHO this fall-through case just makes the code un
Igor Sheludko 2015/11/17 09:54:03 Done.
153 case JS_SET_TYPE:
154 case JS_MAP_TYPE:
155 case JS_PROXY_TYPE:
156 case JS_FUNCTION_PROXY_TYPE:
172 return GetVisitorIdForSize(kVisitStruct, kVisitStructGeneric, 157 return GetVisitorIdForSize(kVisitStruct, kVisitStructGeneric,
173 instance_size, has_unboxed_fields); 158 instance_size, has_unboxed_fields);
174 159
175 default: 160 default:
176 UNREACHABLE(); 161 UNREACHABLE();
177 return kVisitorIdCount; 162 return kVisitorIdCount;
178 } 163 }
179 } 164 }
180 165
181 166
(...skipping 175 matching lines...) Expand 10 before | Expand all | Expand 10 after
357 }; 342 };
358 343
359 344
360 template Object* VisitWeakList<Context>(Heap* heap, Object* list, 345 template Object* VisitWeakList<Context>(Heap* heap, Object* list,
361 WeakObjectRetainer* retainer); 346 WeakObjectRetainer* retainer);
362 347
363 template Object* VisitWeakList<AllocationSite>(Heap* heap, Object* list, 348 template Object* VisitWeakList<AllocationSite>(Heap* heap, Object* list,
364 WeakObjectRetainer* retainer); 349 WeakObjectRetainer* retainer);
365 } // namespace internal 350 } // namespace internal
366 } // namespace v8 351 } // namespace v8
OLDNEW
« no previous file with comments | « no previous file | src/objects.cc » ('j') | no next file with comments »

Powered by Google App Engine
This is Rietveld 408576698