Don't NULL-check GlobalHandle::Node::object_
If it's Smi::FromInt(0), the NULL check would trigger. Instead, use the handle-zap value to mean "not set". BUG=v8:3647,chromium:580651 R=vogelheim@chromium.org LOG=y Review URL: https://codereview.chromium.org/1628173002 Cr-Commit-Position: refs/heads/master@{#33492}
This commit is contained in:
parent
5259af606b
commit
85f32f1fc8
@ -78,6 +78,7 @@ class GlobalHandles::Node {
|
|||||||
#endif
|
#endif
|
||||||
|
|
||||||
void Initialize(int index, Node** first_free) {
|
void Initialize(int index, Node** first_free) {
|
||||||
|
object_ = reinterpret_cast<Object*>(kGlobalHandleZapValue);
|
||||||
index_ = static_cast<uint8_t>(index);
|
index_ = static_cast<uint8_t>(index);
|
||||||
DCHECK(static_cast<int>(index_) == index);
|
DCHECK(static_cast<int>(index_) == index);
|
||||||
set_state(FREE);
|
set_state(FREE);
|
||||||
@ -250,9 +251,9 @@ class GlobalHandles::Node {
|
|||||||
}
|
}
|
||||||
|
|
||||||
void MakeWeak(void* parameter, WeakCallback weak_callback) {
|
void MakeWeak(void* parameter, WeakCallback weak_callback) {
|
||||||
DCHECK(weak_callback != NULL);
|
DCHECK(weak_callback != nullptr);
|
||||||
DCHECK(IsInUse());
|
DCHECK(IsInUse());
|
||||||
CHECK(object_ != NULL);
|
CHECK_NE(object_, reinterpret_cast<Object*>(kGlobalHandleZapValue));
|
||||||
set_state(WEAK);
|
set_state(WEAK);
|
||||||
set_weakness_type(NORMAL_WEAK);
|
set_weakness_type(NORMAL_WEAK);
|
||||||
set_parameter(parameter);
|
set_parameter(parameter);
|
||||||
@ -264,7 +265,7 @@ class GlobalHandles::Node {
|
|||||||
v8::WeakCallbackType type) {
|
v8::WeakCallbackType type) {
|
||||||
DCHECK(phantom_callback != nullptr);
|
DCHECK(phantom_callback != nullptr);
|
||||||
DCHECK(IsInUse());
|
DCHECK(IsInUse());
|
||||||
CHECK(object_ != nullptr);
|
CHECK_NE(object_, reinterpret_cast<Object*>(kGlobalHandleZapValue));
|
||||||
set_state(WEAK);
|
set_state(WEAK);
|
||||||
switch (type) {
|
switch (type) {
|
||||||
case v8::WeakCallbackType::kParameter:
|
case v8::WeakCallbackType::kParameter:
|
||||||
|
@ -401,3 +401,19 @@ TEST(PersistentBaseGetLocal) {
|
|||||||
CHECK(o == g.Get(isolate));
|
CHECK(o == g.Get(isolate));
|
||||||
CHECK(v8::Local<v8::Object>::New(isolate, g) == g.Get(isolate));
|
CHECK(v8::Local<v8::Object>::New(isolate, g) == g.Get(isolate));
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
|
void WeakCallback(const v8::WeakCallbackInfo<void>& data) {}
|
||||||
|
|
||||||
|
|
||||||
|
TEST(WeakPersistentSmi) {
|
||||||
|
CcTest::InitializeVM();
|
||||||
|
v8::Isolate* isolate = CcTest::isolate();
|
||||||
|
|
||||||
|
v8::HandleScope scope(isolate);
|
||||||
|
v8::Local<v8::Number> n = v8::Number::New(isolate, 0);
|
||||||
|
v8::Global<v8::Number> g(isolate, n);
|
||||||
|
|
||||||
|
// Should not crash.
|
||||||
|
g.SetWeak<void>(nullptr, &WeakCallback, v8::WeakCallbackType::kParameter);
|
||||||
|
}
|
||||||
|
Loading…
Reference in New Issue
Block a user