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

Adding support for MMTk (non-moving immix) #56288

Merged
merged 2 commits into from
Jan 7, 2025

Conversation

udesou
Copy link
Contributor

@udesou udesou commented Oct 22, 2024

This PR adds the possibility of building/running Julia using MMTk, running non-moving immix.
The binding code (Rust) associated with it is in https://github.com/mmtk/mmtk-julia/tree/upstream-ready/immix. Instructions on how to build/run Julia with MMTk are described in the README file inside the binding repo.

@udesou udesou changed the title Adding non-moving immix Adding support for MMTk (non-moving immix) Oct 22, 2024
src/gc-mmtk.c Outdated Show resolved Hide resolved
@nsajko nsajko added the GC Garbage collector label Oct 22, 2024
src/llvm-late-gc-lowering.cpp Outdated Show resolved Hide resolved
src/llvm-late-gc-lowering.cpp Outdated Show resolved Hide resolved
@udesou udesou force-pushed the upstream-ready/immix branch 4 times, most recently from 5257d4a to 4621e5c Compare October 25, 2024 03:42
@udesou udesou marked this pull request as ready for review October 25, 2024 03:46
Copy link
Member

@d-netto d-netto left a comment

Choose a reason for hiding this comment

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

First review pass.

Will follow-up with more comments soon.

src/Makefile Outdated Show resolved Hide resolved
src/builtins.c Outdated Show resolved Hide resolved
src/gc-mmtk.h Outdated Show resolved Hide resolved
src/gc-mmtk.h Outdated Show resolved Hide resolved
src/gc-tls.h Outdated Show resolved Hide resolved
src/llvm-gc-interface-passes.h Outdated Show resolved Hide resolved
@udesou udesou force-pushed the upstream-ready/immix branch 4 times, most recently from 3e68f3c to 6a01c26 Compare December 2, 2024 04:53
@udesou udesou force-pushed the upstream-ready/immix branch from 6a01c26 to bc08a9b Compare December 3, 2024 09:13
src/gc-interface.h Outdated Show resolved Hide resolved
src/gc-interface.h Show resolved Hide resolved
src/gc-stock.c Show resolved Hide resolved
src/gc-stock.c Show resolved Hide resolved
src/gc-stock.c Outdated Show resolved Hide resolved
src/threading.c Outdated Show resolved Hide resolved
src/gc-mmtk.c Outdated Show resolved Hide resolved
stdlib/REPL/src/REPL.jl Outdated Show resolved Hide resolved
src/gc-common.c Show resolved Hide resolved
src/gc-common.h Outdated Show resolved Hide resolved
src/gc-stock.c Outdated Show resolved Hide resolved
src/gc-mmtk.c Outdated Show resolved Hide resolved
src/gc-stock.c Show resolved Hide resolved
@udesou udesou force-pushed the upstream-ready/immix branch 7 times, most recently from 167c10f to c6fd2d9 Compare December 10, 2024 02:21
src/gc-mmtk.c Outdated Show resolved Hide resolved
base/timing.jl Outdated Show resolved Hide resolved
contrib/refresh_checksums.mk Outdated Show resolved Hide resolved
src/gc-common.h Outdated Show resolved Hide resolved
src/gc-mmtk.c Outdated Show resolved Hide resolved
src/gc-mmtk.c Outdated Show resolved Hide resolved
@udesou udesou requested a review from d-netto December 17, 2024 22:46
@oscardssmith
Copy link
Member

yes, and it also needs the back ticks
@nanosoldier runtests(["EarlyStopping", "BPGates", "IMFData", "NCEI", "OptimizationPRIMA", "JUDI", "TaylorIntegration", "KolmogorovArnold", "DynamicalSystemsBase", "DiffEqDevTools", "MicroCanonicalHMC", "CellMLToolkit", "FlightSims", "SpiDy", "QuantumAnnealing", "Modia", "MRIgeneralizedBloch", "SideKicks"])

@nanosoldier
Copy link
Collaborator

The package evaluation job you requested has completed - no new issues were detected.
The full report is available.

@udesou udesou force-pushed the upstream-ready/immix branch from 8edf616 to 27c5480 Compare December 18, 2024 19:18
@udesou
Copy link
Contributor Author

udesou commented Dec 18, 2024

It seems like PkgEval ran successfully with the stock GC. Given that @d-netto is on holidays, I’m not sure he’ll have time to look into this. @gbaraldi if you’re happy with the makefile changes, this should be ready to merge, I believe.

@oscardssmith
Copy link
Member

PkgEval came back fully clean.

@nanosoldier
Copy link
Collaborator

The package evaluation job you requested has completed - no new issues were detected.
The full report is available.

@udesou udesou force-pushed the upstream-ready/immix branch 3 times, most recently from 5644e19 to 4b415c4 Compare December 23, 2024 02:11
@udesou udesou force-pushed the upstream-ready/immix branch 6 times, most recently from dc9c9c9 to 6eb18d0 Compare January 1, 2025 10:01
@gbaraldi
Copy link
Member

gbaraldi commented Jan 2, 2025

LGTM. We should do the MMTK build with Yggy now and open a PR to run a pkgeval on it.

@udesou udesou force-pushed the upstream-ready/immix branch 5 times, most recently from 578e930 to 85d509e Compare January 6, 2025 23:48
@udesou
Copy link
Contributor Author

udesou commented Jan 6, 2025

@oscardssmith I've made the changes to the binding, adding the license files and updated the version here. The PR should be ready to merge 👍

udesou added 2 commits January 7, 2025 16:05
* Adding makefile support for building with mmtk
@udesou udesou force-pushed the upstream-ready/immix branch from 85d509e to ecabd17 Compare January 7, 2025 05:05
@oscardssmith oscardssmith merged commit 22134ca into JuliaLang:master Jan 7, 2025
4 of 7 checks passed
Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment
Labels
GC Garbage collector
Projects
None yet
Development

Successfully merging this pull request may close these issues.

10 participants