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

Issue 2580813002: [heap] Do not trace through blink after making weak roots strong for finalizers (Closed)

Created:
4 years ago by Michael Lippautz
Modified:
4 years ago
CC:
haraken, Marcel Hlopko, Hannes Payer (out of office), ulan, v8-reviews_googlegroups.com
Target Ref:
refs/pending/heads/master
Project:
v8
Visibility:
Public.

Description

[heap] Do not trace through blink after making weak roots strong for finalizers Similar to object grouping, we cannot trace through blink (and back to V8) after making weak roots strong because phantom callbacks have already been scheduled and the handles been zapped. This is a short-term solution (mimicing what object grouping currently does). It is not correct in general because we should fully process the subgraph that was discovered by making some of the weak roots strong. In long term we need a separate handle type on the API level for traced references that have their handles zapped at a different stage. Reproduction: - Initial marking is done, i.e., both marking deques are empty. - We make weak roots needed for regular finalizers strong. - We collect phantom callback data and zap handles that are not reachable so far. - Through new roots we discover wrappables on the blink side that would also keep objects that were already scheduled for phantom callbacks alive. - Since the handle was already zapped we crash during dereferencing. BUG=chromium:668060, chromium:468240 Review-Url: https://codereview.chromium.org/2580813002 Cr-Commit-Position: refs/heads/master@{#41724} Committed: https://chromium.googlesource.com/v8/v8/+/af6d01a168c8c61f096edf4e54e97add97f36deb

Patch Set 1 #

Patch Set 2 #

Patch Set 3 #

Unified diffs Side-by-side diffs Delta from patch set Stats (+20 lines, -11 lines) Patch
M src/heap/mark-compact.cc View 1 2 1 chunk +20 lines, -11 lines 0 comments Download

Messages

Total messages: 15 (11 generated)
Michael Lippautz
jochen: ptal haraken/hlopko: fyi This fixes the RegisterExternallyReferencedObject crasher by aligning the behavior to object ...
4 years ago (2016-12-15 14:01:46 UTC) #5
jochen (gone - plz use gerrit)
lgtm
4 years ago (2016-12-15 14:15:14 UTC) #8
commit-bot: I haz the power
CQ is trying da patch. Follow status at https://chromium-cq-status.appspot.com/v2/patch-status/codereview.chromium.org/2580813002/40001
4 years ago (2016-12-15 14:38:24 UTC) #12
commit-bot: I haz the power
4 years ago (2016-12-15 14:40:03 UTC) #15
Message was sent while issue was closed.
Committed patchset #3 (id:40001) as
https://chromium.googlesource.com/v8/v8/+/af6d01a168c8c61f096edf4e54e97add97f...

Powered by Google App Engine
This is Rietveld 408576698