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:
jochen 2016-01-25 05:09:27 -08:00 committed by Commit bot
parent 5259af606b
commit 85f32f1fc8
2 changed files with 20 additions and 3 deletions

View File

@ -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:

View File

@ -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);
}