Move runtime helper for JSWeakCollection onto objects.

R=rossberg@chromium.org

Review URL: https://codereview.chromium.org/1314053003

Cr-Commit-Position: refs/heads/master@{#30385}
This commit is contained in:
mstarzinger 2015-08-26 06:18:46 -07:00 committed by Commit bot
parent 68dfaf78d8
commit 3a8099c750
7 changed files with 67 additions and 78 deletions

View File

@ -2525,7 +2525,7 @@ Local<NativeWeakMap> NativeWeakMap::New(Isolate* v8_isolate) {
i::Isolate* isolate = reinterpret_cast<i::Isolate*>(v8_isolate); i::Isolate* isolate = reinterpret_cast<i::Isolate*>(v8_isolate);
ENTER_V8(isolate); ENTER_V8(isolate);
i::Handle<i::JSWeakMap> weakmap = isolate->factory()->NewJSWeakMap(); i::Handle<i::JSWeakMap> weakmap = isolate->factory()->NewJSWeakMap();
i::Runtime::WeakCollectionInitialize(isolate, weakmap); i::JSWeakCollection::Initialize(weakmap, isolate);
return Utils::NativeWeakMapToLocal(weakmap); return Utils::NativeWeakMapToLocal(weakmap);
} }
@ -2548,7 +2548,7 @@ void NativeWeakMap::Set(Local<Value> v8_key, Local<Value> v8_value) {
return; return;
} }
int32_t hash = i::Object::GetOrCreateHash(isolate, key)->value(); int32_t hash = i::Object::GetOrCreateHash(isolate, key)->value();
i::Runtime::WeakCollectionSet(weak_collection, key, value, hash); i::JSWeakCollection::Set(weak_collection, key, value, hash);
} }
@ -2611,7 +2611,8 @@ bool NativeWeakMap::Delete(Local<Value> v8_key) {
DCHECK(false); DCHECK(false);
return false; return false;
} }
return i::Runtime::WeakCollectionDelete(weak_collection, key); int32_t hash = i::Object::GetOrCreateHash(isolate, key)->value();
return i::JSWeakCollection::Delete(weak_collection, key, hash);
} }

View File

@ -15153,6 +15153,49 @@ void JSMap::Clear(Handle<JSMap> map) {
} }
void JSWeakCollection::Initialize(Handle<JSWeakCollection> weak_collection,
Isolate* isolate) {
DCHECK_EQ(0, weak_collection->map()->GetInObjectProperties());
Handle<ObjectHashTable> table = ObjectHashTable::New(isolate, 0);
weak_collection->set_table(*table);
}
void JSWeakCollection::Set(Handle<JSWeakCollection> weak_collection,
Handle<Object> key, Handle<Object> value,
int32_t hash) {
DCHECK(key->IsJSReceiver() || key->IsSymbol());
Handle<ObjectHashTable> table(
ObjectHashTable::cast(weak_collection->table()));
DCHECK(table->IsKey(*key));
Handle<ObjectHashTable> new_table =
ObjectHashTable::Put(table, key, value, hash);
weak_collection->set_table(*new_table);
if (*table != *new_table) {
// Zap the old table since we didn't record slots for its elements.
table->FillWithHoles(0, table->length());
}
}
bool JSWeakCollection::Delete(Handle<JSWeakCollection> weak_collection,
Handle<Object> key, int32_t hash) {
DCHECK(key->IsJSReceiver() || key->IsSymbol());
Handle<ObjectHashTable> table(
ObjectHashTable::cast(weak_collection->table()));
DCHECK(table->IsKey(*key));
bool was_present = false;
Handle<ObjectHashTable> new_table =
ObjectHashTable::Remove(table, key, &was_present, hash);
weak_collection->set_table(*new_table);
if (*table != *new_table) {
// Zap the old table since we didn't record slots for its elements.
table->FillWithHoles(0, table->length());
}
return was_present;
}
// Check if there is a break point at this code position. // Check if there is a break point at this code position.
bool DebugInfo::HasBreakPoint(int code_position) { bool DebugInfo::HasBreakPoint(int code_position) {
// Get the break point info object for this code position. // Get the break point info object for this code position.

View File

@ -9445,6 +9445,12 @@ class JSWeakCollection: public JSObject {
// [next]: linked list of encountered weak maps during GC. // [next]: linked list of encountered weak maps during GC.
DECL_ACCESSORS(next, Object) DECL_ACCESSORS(next, Object)
static void Initialize(Handle<JSWeakCollection> collection, Isolate* isolate);
static void Set(Handle<JSWeakCollection> collection, Handle<Object> key,
Handle<Object> value, int32_t hash);
static bool Delete(Handle<JSWeakCollection> collection, Handle<Object> key,
int32_t hash);
static const int kTableOffset = JSObject::kHeaderSize; static const int kTableOffset = JSObject::kHeaderSize;
static const int kNextOffset = kTableOffset + kPointerSize; static const int kNextOffset = kTableOffset + kPointerSize;
static const int kSize = kNextOffset + kPointerSize; static const int kSize = kNextOffset + kPointerSize;

View File

@ -271,19 +271,11 @@ RUNTIME_FUNCTION(Runtime_MapIteratorNext) {
} }
void Runtime::WeakCollectionInitialize(
Isolate* isolate, Handle<JSWeakCollection> weak_collection) {
DCHECK_EQ(0, weak_collection->map()->GetInObjectProperties());
Handle<ObjectHashTable> table = ObjectHashTable::New(isolate, 0);
weak_collection->set_table(*table);
}
RUNTIME_FUNCTION(Runtime_WeakCollectionInitialize) { RUNTIME_FUNCTION(Runtime_WeakCollectionInitialize) {
HandleScope scope(isolate); HandleScope scope(isolate);
DCHECK(args.length() == 1); DCHECK(args.length() == 1);
CONVERT_ARG_HANDLE_CHECKED(JSWeakCollection, weak_collection, 0); CONVERT_ARG_HANDLE_CHECKED(JSWeakCollection, weak_collection, 0);
Runtime::WeakCollectionInitialize(isolate, weak_collection); JSWeakCollection::Initialize(weak_collection, isolate);
return *weak_collection; return *weak_collection;
} }
@ -318,32 +310,6 @@ RUNTIME_FUNCTION(Runtime_WeakCollectionHas) {
} }
bool Runtime::WeakCollectionDelete(Handle<JSWeakCollection> weak_collection,
Handle<Object> key) {
int32_t hash =
Object::GetOrCreateHash(weak_collection->GetIsolate(), key)->value();
return WeakCollectionDelete(weak_collection, key, hash);
}
bool Runtime::WeakCollectionDelete(Handle<JSWeakCollection> weak_collection,
Handle<Object> key, int32_t hash) {
DCHECK(key->IsJSReceiver() || key->IsSymbol());
Handle<ObjectHashTable> table(
ObjectHashTable::cast(weak_collection->table()));
DCHECK(table->IsKey(*key));
bool was_present = false;
Handle<ObjectHashTable> new_table =
ObjectHashTable::Remove(table, key, &was_present, hash);
weak_collection->set_table(*new_table);
if (*table != *new_table) {
// Zap the old table since we didn't record slots for its elements.
table->FillWithHoles(0, table->length());
}
return was_present;
}
RUNTIME_FUNCTION(Runtime_WeakCollectionDelete) { RUNTIME_FUNCTION(Runtime_WeakCollectionDelete) {
HandleScope scope(isolate); HandleScope scope(isolate);
DCHECK(args.length() == 3); DCHECK(args.length() == 3);
@ -354,28 +320,11 @@ RUNTIME_FUNCTION(Runtime_WeakCollectionDelete) {
Handle<ObjectHashTable> table( Handle<ObjectHashTable> table(
ObjectHashTable::cast(weak_collection->table())); ObjectHashTable::cast(weak_collection->table()));
RUNTIME_ASSERT(table->IsKey(*key)); RUNTIME_ASSERT(table->IsKey(*key));
bool was_present = Runtime::WeakCollectionDelete(weak_collection, key, hash); bool was_present = JSWeakCollection::Delete(weak_collection, key, hash);
return isolate->heap()->ToBoolean(was_present); return isolate->heap()->ToBoolean(was_present);
} }
void Runtime::WeakCollectionSet(Handle<JSWeakCollection> weak_collection,
Handle<Object> key, Handle<Object> value,
int32_t hash) {
DCHECK(key->IsJSReceiver() || key->IsSymbol());
Handle<ObjectHashTable> table(
ObjectHashTable::cast(weak_collection->table()));
DCHECK(table->IsKey(*key));
Handle<ObjectHashTable> new_table =
ObjectHashTable::Put(table, key, value, hash);
weak_collection->set_table(*new_table);
if (*table != *new_table) {
// Zap the old table since we didn't record slots for its elements.
table->FillWithHoles(0, table->length());
}
}
RUNTIME_FUNCTION(Runtime_WeakCollectionSet) { RUNTIME_FUNCTION(Runtime_WeakCollectionSet) {
HandleScope scope(isolate); HandleScope scope(isolate);
DCHECK(args.length() == 4); DCHECK(args.length() == 4);
@ -387,7 +336,7 @@ RUNTIME_FUNCTION(Runtime_WeakCollectionSet) {
Handle<ObjectHashTable> table( Handle<ObjectHashTable> table(
ObjectHashTable::cast(weak_collection->table())); ObjectHashTable::cast(weak_collection->table()));
RUNTIME_ASSERT(table->IsKey(*key)); RUNTIME_ASSERT(table->IsKey(*key));
Runtime::WeakCollectionSet(weak_collection, key, value, hash); JSWeakCollection::Set(weak_collection, key, value, hash);
return *weak_collection; return *weak_collection;
} }
@ -425,7 +374,7 @@ RUNTIME_FUNCTION(Runtime_ObservationWeakMapCreate) {
HandleScope scope(isolate); HandleScope scope(isolate);
DCHECK(args.length() == 0); DCHECK(args.length() == 0);
Handle<JSWeakMap> weakmap = isolate->factory()->NewJSWeakMap(); Handle<JSWeakMap> weakmap = isolate->factory()->NewJSWeakMap();
Runtime::WeakCollectionInitialize(isolate, weakmap); JSWeakCollection::Initialize(weakmap, isolate);
return *weakmap; return *weakmap;
} }
} // namespace internal } // namespace internal

View File

@ -1168,7 +1168,7 @@ class Runtime : public AllStatic {
SharedFlag shared = SharedFlag::kNotShared); SharedFlag shared = SharedFlag::kNotShared);
enum TypedArrayId { enum TypedArrayId {
// arrayIds below should be synchromized with typedarray.js natives. // arrayIds below should be synchronized with typedarray.js natives.
ARRAY_ID_UINT8 = 1, ARRAY_ID_UINT8 = 1,
ARRAY_ID_INT8 = 2, ARRAY_ID_INT8 = 2,
ARRAY_ID_UINT16 = 3, ARRAY_ID_UINT16 = 3,
@ -1191,16 +1191,6 @@ class Runtime : public AllStatic {
Isolate* isolate, Handle<FixedArray> literals, Isolate* isolate, Handle<FixedArray> literals,
Handle<FixedArray> elements, bool is_strong); Handle<FixedArray> elements, bool is_strong);
static void WeakCollectionInitialize(
Isolate* isolate, Handle<JSWeakCollection> weak_collection);
static void WeakCollectionSet(Handle<JSWeakCollection> weak_collection,
Handle<Object> key, Handle<Object> value,
int32_t hash);
static bool WeakCollectionDelete(Handle<JSWeakCollection> weak_collection,
Handle<Object> key);
static bool WeakCollectionDelete(Handle<JSWeakCollection> weak_collection,
Handle<Object> key, int32_t hash);
static MaybeHandle<JSArray> GetInternalProperties(Isolate* isolate, static MaybeHandle<JSArray> GetInternalProperties(Isolate* isolate,
Handle<Object>); Handle<Object>);

View File

@ -89,9 +89,9 @@ TEST(Weakness) {
Handle<JSObject> object = factory->NewJSObjectFromMap(map); Handle<JSObject> object = factory->NewJSObjectFromMap(map);
Handle<Smi> smi(Smi::FromInt(23), isolate); Handle<Smi> smi(Smi::FromInt(23), isolate);
int32_t hash = Object::GetOrCreateHash(isolate, key)->value(); int32_t hash = Object::GetOrCreateHash(isolate, key)->value();
Runtime::WeakCollectionSet(weakmap, key, object, hash); JSWeakCollection::Set(weakmap, key, object, hash);
int32_t object_hash = Object::GetOrCreateHash(isolate, object)->value(); int32_t object_hash = Object::GetOrCreateHash(isolate, object)->value();
Runtime::WeakCollectionSet(weakmap, object, smi, object_hash); JSWeakCollection::Set(weakmap, object, smi, object_hash);
} }
CHECK_EQ(2, ObjectHashTable::cast(weakmap->table())->NumberOfElements()); CHECK_EQ(2, ObjectHashTable::cast(weakmap->table())->NumberOfElements());
@ -147,7 +147,7 @@ TEST(Shrinking) {
Handle<JSObject> object = factory->NewJSObjectFromMap(map); Handle<JSObject> object = factory->NewJSObjectFromMap(map);
Handle<Smi> smi(Smi::FromInt(i), isolate); Handle<Smi> smi(Smi::FromInt(i), isolate);
int32_t object_hash = Object::GetOrCreateHash(isolate, object)->value(); int32_t object_hash = Object::GetOrCreateHash(isolate, object)->value();
Runtime::WeakCollectionSet(weakmap, object, smi, object_hash); JSWeakCollection::Set(weakmap, object, smi, object_hash);
} }
} }
@ -196,7 +196,7 @@ TEST(Regress2060a) {
CHECK(!heap->InNewSpace(object->address())); CHECK(!heap->InNewSpace(object->address()));
CHECK(!first_page->Contains(object->address())); CHECK(!first_page->Contains(object->address()));
int32_t hash = Object::GetOrCreateHash(isolate, key)->value(); int32_t hash = Object::GetOrCreateHash(isolate, key)->value();
Runtime::WeakCollectionSet(weakmap, key, object, hash); JSWeakCollection::Set(weakmap, key, object, hash);
} }
} }
@ -239,7 +239,7 @@ TEST(Regress2060b) {
for (int i = 0; i < 32; i++) { for (int i = 0; i < 32; i++) {
Handle<Smi> smi(Smi::FromInt(i), isolate); Handle<Smi> smi(Smi::FromInt(i), isolate);
int32_t hash = Object::GetOrCreateHash(isolate, keys[i])->value(); int32_t hash = Object::GetOrCreateHash(isolate, keys[i])->value();
Runtime::WeakCollectionSet(weakmap, keys[i], smi, hash); JSWeakCollection::Set(weakmap, keys[i], smi, hash);
} }
// Force compacting garbage collection. The subsequent collections are used // Force compacting garbage collection. The subsequent collections are used

View File

@ -90,7 +90,7 @@ TEST(WeakSet_Weakness) {
HandleScope scope(isolate); HandleScope scope(isolate);
Handle<Smi> smi(Smi::FromInt(23), isolate); Handle<Smi> smi(Smi::FromInt(23), isolate);
int32_t hash = Object::GetOrCreateHash(isolate, key)->value(); int32_t hash = Object::GetOrCreateHash(isolate, key)->value();
Runtime::WeakCollectionSet(weakset, key, smi, hash); JSWeakCollection::Set(weakset, key, smi, hash);
} }
CHECK_EQ(1, ObjectHashTable::cast(weakset->table())->NumberOfElements()); CHECK_EQ(1, ObjectHashTable::cast(weakset->table())->NumberOfElements());
@ -146,7 +146,7 @@ TEST(WeakSet_Shrinking) {
Handle<JSObject> object = factory->NewJSObjectFromMap(map); Handle<JSObject> object = factory->NewJSObjectFromMap(map);
Handle<Smi> smi(Smi::FromInt(i), isolate); Handle<Smi> smi(Smi::FromInt(i), isolate);
int32_t hash = Object::GetOrCreateHash(isolate, object)->value(); int32_t hash = Object::GetOrCreateHash(isolate, object)->value();
Runtime::WeakCollectionSet(weakset, object, smi, hash); JSWeakCollection::Set(weakset, object, smi, hash);
} }
} }
@ -195,7 +195,7 @@ TEST(WeakSet_Regress2060a) {
CHECK(!heap->InNewSpace(object->address())); CHECK(!heap->InNewSpace(object->address()));
CHECK(!first_page->Contains(object->address())); CHECK(!first_page->Contains(object->address()));
int32_t hash = Object::GetOrCreateHash(isolate, key)->value(); int32_t hash = Object::GetOrCreateHash(isolate, key)->value();
Runtime::WeakCollectionSet(weakset, key, object, hash); JSWeakCollection::Set(weakset, key, object, hash);
} }
} }
@ -238,7 +238,7 @@ TEST(WeakSet_Regress2060b) {
for (int i = 0; i < 32; i++) { for (int i = 0; i < 32; i++) {
Handle<Smi> smi(Smi::FromInt(i), isolate); Handle<Smi> smi(Smi::FromInt(i), isolate);
int32_t hash = Object::GetOrCreateHash(isolate, keys[i])->value(); int32_t hash = Object::GetOrCreateHash(isolate, keys[i])->value();
Runtime::WeakCollectionSet(weakset, keys[i], smi, hash); JSWeakCollection::Set(weakset, keys[i], smi, hash);
} }
// Force compacting garbage collection. The subsequent collections are used // Force compacting garbage collection. The subsequent collections are used