Skip to content

Conversation

@mmarchini
Copy link
Contributor

Original commit message:

[objects] Compact and shrink script_list So far creating scripts always grew the script_list without ever reusing cleared slots or shrinking. While this is probably not a problem with script_list in practice, this is still a memory leak. Fix this leak by using WeakArrayList::Append instead of AddToEnd. Append adds to the end of the array, but potentially compacts and shrinks the list as well. Other WeakArrayLists can use this method as well, as long as they are not using indices into this array. Bug: v8:10031 Change-Id: If743c4cc3f8d67ab735522f0ded038b2fb43e437 Reviewed-on: https://chromium-review.googlesource.com/c/v8/v8/+/1967385 Commit-Queue: Dominik Inführ <[email protected]> Reviewed-by: Ulan Degenbaev <[email protected]> Cr-Commit-Position: refs/heads/master@{#65640} 

Refs: v8/v8@fb26d0b

Checklist
  • make -j4 test (UNIX), or vcbuild test (Windows) passes
  • tests and/or benchmarks are included
  • documentation is changed or added
  • commit message follows commit guidelines

@nodejs-github-botnodejs-github-bot added build Issues and PRs related to build files or the CI. v12.x v8 engine Issues and PRs related to the V8 dependency. labels May 26, 2020
Copy link
Member

@addaleaxaddaleax left a comment

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

RSLGTM

@nodejs-github-bot
Copy link
Collaborator

nodejs-github-bot commented May 26, 2020

@BridgeARBridgeAR changed the title deps: V8: backport fb26d0bb1835[v12.x] deps: V8: backport fb26d0bb1835May 27, 2020
Copy link
Member

@BridgeARBridgeAR left a comment

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

RSLGTM

@BridgeARBridgeAR added the author ready PRs that have at least one approval, no pending requests for changes, and a CI started. label May 27, 2020
@mmarchini
Copy link
ContributorAuthor

@targos would it be better if V8 fixed this on 7.8, or should we just keep this as a floating patch? The patch is not that big (without tests), and since it's unlikely we bump to 7.9 before October anyway the patch shouldn't bring any headaches.

(also cc @codebytere, as I'm not sure how floating patches impact Electron)

@targos
Copy link
Member

I'm not sure what you mean? This V8 branch is no longer supported upstream

@mmarchini
Copy link
ContributorAuthor

I see. In the issue it sounded like they were open to fixing it on 7.8, but maybe they meant if it is absolutely necessary.

@codebytere
Copy link
Member

@mmarchini it should be fine on our end!

@ex1stex1st mentioned this pull request Jun 9, 2020
@codebytere
Copy link
Member

@mmarchini this needs to be rebased against latest v12.x-staging and then i can get it into the next RC for 12.x!

@mmarchini
Copy link
ContributorAuthor

I missed the notification :(

We'll need to wait until the July release now, correct?

@mmarchinimmarchiniforce-pushed the v12.x-backport-gc-fix branch from 72d8e76 to e86be5cCompareJune 17, 2020 19:26
@nodejs-github-bot
Copy link
Collaborator

nodejs-github-bot commented Jun 17, 2020

Original commit message: [objects] Compact and shrink script_list So far creating scripts always grew the script_list without ever reusing cleared slots or shrinking. While this is probably not a problem with script_list in practice, this is still a memory leak. Fix this leak by using WeakArrayList::Append instead of AddToEnd. Append adds to the end of the array, but potentially compacts and shrinks the list as well. Other WeakArrayLists can use this method as well, as long as they are not using indices into this array. Bug: v8:10031 Change-Id: If743c4cc3f8d67ab735522f0ded038b2fb43e437 Reviewed-on: https://chromium-review.googlesource.com/c/v8/v8/+/1967385 Commit-Queue: Dominik Inführ <[email protected]> Reviewed-by: Ulan Degenbaev <[email protected]> Cr-Commit-Position: refs/heads/master@{#65640} Refs: v8/v8@fb26d0b
@mmarchinimmarchiniforce-pushed the v12.x-backport-gc-fix branch from e86be5c to 1f9566bCompareJune 17, 2020 19:31
@mmarchini
Copy link
ContributorAuthor

@codebytere rebased :)

Did you get a conflict when using the release tools, or test errors? It rebased cleanly here, just had to bump the embedder string.

@nodejs-github-bot

This comment has been minimized.

@nodejs-github-bot
Copy link
Collaborator

@nodejs-github-bot
Copy link
Collaborator

nodejs-github-bot commented Jun 26, 2020

CI: https://ci.nodejs.org/job/node-test-pull-request/32109/ (Resume due to socket hang up on arm) ✅

BethGriggs pushed a commit that referenced this pull request Jun 26, 2020
Original commit message: [objects] Compact and shrink script_list So far creating scripts always grew the script_list without ever reusing cleared slots or shrinking. While this is probably not a problem with script_list in practice, this is still a memory leak. Fix this leak by using WeakArrayList::Append instead of AddToEnd. Append adds to the end of the array, but potentially compacts and shrinks the list as well. Other WeakArrayLists can use this method as well, as long as they are not using indices into this array. Bug: v8:10031 Change-Id: If743c4cc3f8d67ab735522f0ded038b2fb43e437 Reviewed-on: https://chromium-review.googlesource.com/c/v8/v8/+/1967385 Commit-Queue: Dominik Inführ <[email protected]> Reviewed-by: Ulan Degenbaev <[email protected]> Cr-Commit-Position: refs/heads/master@{#65640} Refs: v8/v8@fb26d0b PR-URL: #33573 Reviewed-By: Anna Henningsen <[email protected]> Reviewed-By: Ruben Bridgewater <[email protected]> Reviewed-By: Shelley Vohr <[email protected]> Reviewed-By: Beth Griggs <[email protected]>
@BethGriggs
Copy link
Member

Landed in 97a3f7b (v12.x-staging)

BethGriggs added a commit that referenced this pull request Jun 26, 2020
Notable changes: - deps: V8: backport fb26d0bb1835 (Matheus Marchini) [#33573](#33573) - src: use symbol to store `AsyncWrap` resource (Anna Henningsen) [#31745](#31745) PR-URL: TBD
@BethGriggsBethGriggs mentioned this pull request Jun 26, 2020
BethGriggs added a commit that referenced this pull request Jun 26, 2020
Notable changes: - deps: V8: backport fb26d0bb1835 (Matheus Marchini) [#33573](#33573) - src: use symbol to store `AsyncWrap` resource (Anna Henningsen) [#31745](#31745) PR-URL: #34077
BethGriggs added a commit that referenced this pull request Jun 30, 2020
Notable changes: - deps: V8: backport fb26d0bb1835 (Matheus Marchini) [#33573](#33573) - src: use symbol to store `AsyncWrap` resource (Anna Henningsen) [#31745](#31745) PR-URL: #34077
Sign up for freeto join this conversation on GitHub. Already have an account? Sign in to comment

Labels

author readyPRs that have at least one approval, no pending requests for changes, and a CI started.buildIssues and PRs related to build files or the CI.v8 engineIssues and PRs related to the V8 dependency.

Projects

None yet

Development

Successfully merging this pull request may close these issues.

Node v12.16.2 memory issues after upgrade from v8 (<--- Last few GCs --->)

7 participants

@mmarchini@nodejs-github-bot@targos@codebytere@BethGriggs@addaleax@BridgeAR