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

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

Issue 1358773002: Load the native call wrapper via Thread. (Closed) Base URL: git@github.com:dart-lang/sdk.git@master
Patch Set: Created 5 years, 3 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
« no previous file with comments | « runtime/vm/assembler.h ('k') | runtime/vm/assembler_arm.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 "vm/assembler.h" 5 #include "vm/assembler.h"
6 6
7 #include "platform/utils.h" 7 #include "platform/utils.h"
8 #include "vm/cpu.h" 8 #include "vm/cpu.h"
9 #include "vm/heap.h" 9 #include "vm/heap.h"
10 #include "vm/memory_region.h" 10 #include "vm/memory_region.h"
(...skipping 247 matching lines...) Expand 10 before | Expand all | Expand 10 after
258 object_pool_.Add(entry); 258 object_pool_.Add(entry);
259 if (patchable == kNotPatchable) { 259 if (patchable == kNotPatchable) {
260 // The object isn't patchable. Record the index for fast lookup. 260 // The object isn't patchable. Record the index for fast lookup.
261 object_pool_index_table_.Insert( 261 object_pool_index_table_.Insert(
262 ObjIndexPair(entry, object_pool_.length() - 1)); 262 ObjIndexPair(entry, object_pool_.length() - 1));
263 } 263 }
264 return object_pool_.length() - 1; 264 return object_pool_.length() - 1;
265 } 265 }
266 266
267 267
268 intptr_t ObjectPoolWrapper::AddExternalLabel(const ExternalLabel* label,
269 Patchability patchable) {
270 return AddObject(ObjectPool::Entry(label->address(),
271 ObjectPool::kExternalLabel),
272 patchable);
273 }
274
275
276 intptr_t ObjectPoolWrapper::FindObject(ObjectPool::Entry entry, 268 intptr_t ObjectPoolWrapper::FindObject(ObjectPool::Entry entry,
277 Patchability patchable) { 269 Patchability patchable) {
278 // If the object is not patchable, check if we've already got it in the 270 // If the object is not patchable, check if we've already got it in the
279 // object pool. 271 // object pool.
280 if (patchable == kNotPatchable) { 272 if (patchable == kNotPatchable) {
281 intptr_t idx = object_pool_index_table_.Lookup(entry); 273 intptr_t idx = object_pool_index_table_.Lookup(entry);
282 if (idx != ObjIndexPair::kNoIndex) { 274 if (idx != ObjIndexPair::kNoIndex) {
283 return idx; 275 return idx;
284 } 276 }
285 } 277 }
286 278
287 return AddObject(entry, patchable); 279 return AddObject(entry, patchable);
288 } 280 }
289 281
290 282
291 intptr_t ObjectPoolWrapper::FindObject(const Object& obj, 283 intptr_t ObjectPoolWrapper::FindObject(const Object& obj,
292 Patchability patchable) { 284 Patchability patchable) {
293 return FindObject(ObjectPool::Entry(&obj), patchable); 285 return FindObject(ObjectPool::Entry(&obj), patchable);
294 } 286 }
295 287
296 288
297 intptr_t ObjectPoolWrapper::FindImmediate(uword imm) { 289 intptr_t ObjectPoolWrapper::FindImmediate(uword imm) {
298 return FindObject(ObjectPool::Entry(imm, ObjectPool::kImmediate), 290 return FindObject(ObjectPool::Entry(imm, ObjectPool::kImmediate),
299 kNotPatchable); 291 kNotPatchable);
300 } 292 }
301 293
302 294
303 intptr_t ObjectPoolWrapper::FindExternalLabel(const ExternalLabel* label,
304 Patchability patchable) {
305 return FindObject(ObjectPool::Entry(label->address(),
306 ObjectPool::kExternalLabel),
307 patchable);
308 }
309
310
311 intptr_t ObjectPoolWrapper::FindNativeEntry(const ExternalLabel* label, 295 intptr_t ObjectPoolWrapper::FindNativeEntry(const ExternalLabel* label,
312 Patchability patchable) { 296 Patchability patchable) {
313 return FindObject(ObjectPool::Entry(label->address(), 297 return FindObject(ObjectPool::Entry(label->address(),
314 ObjectPool::kNativeEntry), 298 ObjectPool::kNativeEntry),
315 patchable); 299 patchable);
316 } 300 }
317 301
318 302
319 RawObjectPool* ObjectPoolWrapper::MakeObjectPool() { 303 RawObjectPool* ObjectPoolWrapper::MakeObjectPool() {
320 intptr_t len = object_pool_.length(); 304 intptr_t len = object_pool_.length();
321 if (len == 0) { 305 if (len == 0) {
322 return Object::empty_object_pool().raw(); 306 return Object::empty_object_pool().raw();
323 } 307 }
324 const ObjectPool& result = ObjectPool::Handle(ObjectPool::New(len)); 308 const ObjectPool& result = ObjectPool::Handle(ObjectPool::New(len));
325 const TypedData& info_array = TypedData::Handle(result.info_array()); 309 const TypedData& info_array = TypedData::Handle(result.info_array());
326 for (intptr_t i = 0; i < len; ++i) { 310 for (intptr_t i = 0; i < len; ++i) {
327 ObjectPool::EntryType info = object_pool_[i].type_; 311 ObjectPool::EntryType info = object_pool_[i].type_;
328 info_array.SetInt8(i, static_cast<int8_t>(info)); 312 info_array.SetInt8(i, static_cast<int8_t>(info));
329 if (info == ObjectPool::kTaggedObject) { 313 if (info == ObjectPool::kTaggedObject) {
330 result.SetObjectAt(i, *object_pool_[i].obj_); 314 result.SetObjectAt(i, *object_pool_[i].obj_);
331 } else { 315 } else {
332 result.SetRawValueAt(i, object_pool_[i].raw_value_); 316 result.SetRawValueAt(i, object_pool_[i].raw_value_);
333 } 317 }
334 } 318 }
335 return result.raw(); 319 return result.raw();
336 } 320 }
337 321
338 322
339 } // namespace dart 323 } // namespace dart
OLDNEW
« no previous file with comments | « runtime/vm/assembler.h ('k') | runtime/vm/assembler_arm.h » ('j') | no next file with comments »

Powered by Google App Engine
This is Rietveld 408576698