Skip to content
New issue

Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.

By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.

Already on GitHub? Sign in to your account

Non recursive gc trace #3508

Merged
merged 3 commits into from
Dec 7, 2023
Merged

Non recursive gc trace #3508

merged 3 commits into from
Dec 7, 2023

Conversation

HalidOdat
Copy link
Member

@HalidOdat HalidOdat commented Dec 6, 2023

This Pull Request fixes/closes #1848 .

It changes the following:

  • Unify GcBoxHeader and EphemeronBoxHeader into GcHeader (duplicate code).
  • Use a work queue to traverse the gc ojects.

The reproducible code in the issue has been made into a test for both boa_gc and boa_engine (reduced the chain object from 100_000_000 to 1_000_000, takes too long to finish).

Note: Marking it as a draft. There are still some things that need to be sorted out. like the vtable extraction and construction without rust-lang/rust#81513 will be much harder to do.

Reason for moving vtable to Gc object: Because we have <T: Trace + ?Sized> Trace for Gc<T> we cannot get a NonNull<GcBox<dyn Trace>> from Gc<dyn Trace> so we can enque it (we can implement a special case for Gc<dyn Trace> but types like Gc<VTableObject<dyn Trace>> cannot be done), because it would require us to have double DST, which is not possible. Moving the vtable to the GcBox<T> allow us to construct a GcBox<dyn Trait> at any time. This also has the advantage of reducing by half the NonNull<GcBox<dyn Trace>> pointers in the gc strong vec, also while gc collecting and tracing queue. Could also have some interesting other optimization, since we could have a ThinGc<dyn Trace> that is pointer width while being erased.

Solved by create a custom VTable with all the required function, and other metadata like size. Being able to put pretty much anything in the vtable, this approach may be more flexible than working with rust-lang/rust#81513.
The tests run fine with strict provenance under miri.

Once the warnings, documentation, some code clean up is done, will mark it ready for review.

@HalidOdat HalidOdat added bug Something isn't working gc Issue related to garbage collection labels Dec 6, 2023
Copy link

github-actions bot commented Dec 6, 2023

Test262 conformance changes

Test result main count PR count difference
Total 95,960 95,960 0
Passed 76,534 76,534 0
Ignored 18,477 18,477 0
Failed 949 949 0
Panics 0 0 0
Conformance 79.76% 79.76% 0.00%

Copy link

codecov bot commented Dec 6, 2023

Codecov Report

Attention: 66 lines in your changes are missing coverage. Please review.

Comparison is base (47351ef) 49.01% compared to head (0b56b10) 48.88%.
Report is 2 commits behind head on main.

Files Patch % Lines
core/macros/src/lib.rs 0.00% 26 Missing ⚠️
core/gc/src/trace.rs 75.00% 10 Missing ⚠️
core/gc/src/internals/gc_header.rs 82.35% 6 Missing ⚠️
core/gc/src/lib.rs 87.80% 5 Missing ⚠️
core/engine/src/error.rs 0.00% 4 Missing ⚠️
core/engine/src/builtins/promise/mod.rs 0.00% 3 Missing ⚠️
core/engine/src/module/source.rs 0.00% 2 Missing ⚠️
core/engine/src/builtins/function/mod.rs 0.00% 1 Missing ⚠️
core/engine/src/builtins/generator/mod.rs 0.00% 1 Missing ⚠️
core/engine/src/builtins/intl/collator/mod.rs 0.00% 1 Missing ⚠️
... and 7 more
Additional details and impacted files
@@            Coverage Diff             @@
##             main    #3508      +/-   ##
==========================================
- Coverage   49.01%   48.88%   -0.13%     
==========================================
  Files         469      471       +2     
  Lines       48186    48492     +306     
==========================================
+ Hits        23618    23705      +87     
- Misses      24568    24787     +219     

☔ View full report in Codecov by Sentry.
📢 Have feedback on the report? Share it here.

@HalidOdat HalidOdat force-pushed the non-recursive-gc-trace branch 2 times, most recently from e0c14a2 to 117d950 Compare December 6, 2023 21:59
@HalidOdat HalidOdat marked this pull request as ready for review December 6, 2023 22:01
@HalidOdat HalidOdat requested a review from a team December 6, 2023 22:01
@HalidOdat HalidOdat added this to the v0.18.0 milestone Dec 6, 2023
@HalidOdat
Copy link
Member Author

HalidOdat commented Dec 6, 2023

Ran the benchmarks and the seems to be a slight speed improvement (not sure why, expected the opposite since we need to reach into the object to be able to trace it).

Also just realized that with the queue it would be easier to implement an incremental GC since we can stop at anytime during the tracing and continue afterwards


Main

PROGRESS Richards
RESULT Richards 49.2
PROGRESS DeltaBlue
RESULT DeltaBlue 53.4
PROGRESS Encrypt
PROGRESS Decrypt
RESULT Crypto 54.3
PROGRESS RayTrace
RESULT RayTrace 162
PROGRESS Earley
PROGRESS Boyer
RESULT EarleyBoyer 148
PROGRESS Splay
RESULT Splay 155
PROGRESS NavierStokes
RESULT NavierStokes 103
SCORE 91.8

PR

PROGRESS Richards
RESULT Richards 49.9
PROGRESS DeltaBlue
RESULT DeltaBlue 53.9
PROGRESS Encrypt
PROGRESS Decrypt
RESULT Crypto 53.5
PROGRESS RayTrace
RESULT RayTrace 162
PROGRESS Earley
PROGRESS Boyer
RESULT EarleyBoyer 153
PROGRESS Splay
RESULT Splay 156
PROGRESS NavierStokes
RESULT NavierStokes 103
SCORE 92.3
undefined

@HalidOdat HalidOdat force-pushed the non-recursive-gc-trace branch from 117d950 to 4b3feb4 Compare December 6, 2023 23:30
Copy link
Member

@jedel1043 jedel1043 left a comment

Choose a reason for hiding this comment

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

Really nice fix! And yeah, this could simplify a LOT the implementation of a concurrent GC.
Just have some critical comments about some methods of Trace, and the rest are just nitpicks.

boa_gc/src/internals/vtable.rs Outdated Show resolved Hide resolved
boa_gc/src/pointers/gc.rs Outdated Show resolved Hide resolved
boa_gc/src/trace.rs Outdated Show resolved Hide resolved
@HalidOdat HalidOdat force-pushed the non-recursive-gc-trace branch from 4b3feb4 to c313927 Compare December 6, 2023 23:59
@HalidOdat HalidOdat requested review from jedel1043 and a team December 7, 2023 00:00
core/gc/src/trace.rs Outdated Show resolved Hide resolved
@HalidOdat HalidOdat requested review from jedel1043 and a team December 7, 2023 00:12
Copy link
Member

@jedel1043 jedel1043 left a comment

Choose a reason for hiding this comment

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

Good work!

@jedel1043 jedel1043 requested a review from a team December 7, 2023 00:35
Copy link
Member

@raskad raskad left a comment

Choose a reason for hiding this comment

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

Nice work!

core/gc/src/pointers/gc.rs Outdated Show resolved Hide resolved
core/gc/src/lib.rs Outdated Show resolved Hide resolved
@HalidOdat HalidOdat enabled auto-merge December 7, 2023 09:10
@HalidOdat HalidOdat added this pull request to the merge queue Dec 7, 2023
Merged via the queue into main with commit f923830 Dec 7, 2023
14 checks passed
@HalidOdat HalidOdat deleted the non-recursive-gc-trace branch December 7, 2023 09:29
Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment
Labels
bug Something isn't working gc Issue related to garbage collection
Projects
None yet
Development

Successfully merging this pull request may close these issues.

Long reference "chain" can overflow the stack during GC trace
3 participants