rustc_codegen_gcc: Progress Report #32
What is rustc_codegen_gcc?
rustc_codegen_gcc is a GCC ahead-of-time codegen for rustc, meaning that it can be loaded by the existing rustc frontend, but benefits from GCC by having more architectures supported and having access to GCC’s optimizations. It is not to be confused with gccrs, which is a GCC frontend for Rust.
GCC patches status
This month, only one patch was sent to the mailing list:
-
Add rvalue::get_name method (thanks to GuillaumeGomez!)
We also implemented added a few features that are yet to be sent to the mailing list:
-
[PATCH] Allow gcc_jit_type_get_size to work with pointers (thanks to GuillaumeGomez!)
-
Add Float16 and Float128 support for jit (thanks to zedar!)
-
Target Info extended with supported types (limited to Float16|32|64|128) (thanks to zedar!)
-
add git_jit_type_is_float() (thanks to zedar!)
-
Fix wrong reinitialization of target_builtins (thanks to GuillaumeGomez!)
-
Make is_same_type_as() supporting floating point types. Improve type coparison (thanks to zedar!)
We’re still waiting for the reviews of the other patches that were sent before.
State of rustc_codegen_gcc
Here’s what has been done during the past month:
-
Regen intrinsics conversions (thanks to GuillaumeGomez!)
-
Updating readme instructions (thanks to Gerson2102!)
-
updated build system script commands (thanks to g4titanx!)
-
Fix passing custom CG_RUSTFLAGS when building sysroot (thanks to darcagn!)
-
Modify build_system’s prepare stage to allow for custom sysroot source path (thanks to darcagn!)
-
Download artifacts from rust-lang/gcc instead of old antoyo/gcc (thanks to GuillaumeGomez!)
-
Stop swallowing signals in build_system when running sub-commands (thanks to GuillaumeGomez!)
-
Add fmt command (thanks to GuillaumeGomez!)
This month, we fixed a few ICEs (Internal Compiler Error) that we had, we improved the support for Aarch64 and made progress on the support for the new types f16
and f128
(thanks to zedar!) among other things.
We’re still progressing in doing the sync with the Rust repo which is harder than usual, but after it’s done, we’ll be back on working on rustup
support.
Next month, we’ll continue towards our goal of distributing this project through rustup
, which should hopefully happens in a couple of months.
Here’s a rough summary of what has been implemented:
Feature | Last month completion | Completion | Delta |
---|---|---|---|
Unwinding. |
80% |
80% |
|
LTO. |
80% |
80% |
|
More function and variable attributes. |
20% |
20% |
|
Target features (to detect what is supported in an architecture, like SIMD). |
80% |
82% |
+2% |
Debug info. |
20% |
||
Thin LTO. |
0% |
||
Rustup distribution. |
0% |
||
SIMD for other architectures than x86-64. |
0% |
||
Support for new architectures in libraries (libc, object, …) and rustc. |
0% |
||
Endianness support for non-native 128-bit integers. |
Done |
||
SIMD (x86-64). |
Done |
||
Basic and aggregate types. |
Done |
||
Operations, local and global variables, constants, functions, basic blocks. |
Done |
||
Atomics. |
Done |
||
Thread-local storage. |
Done |
||
Inline assembly. |
Done |
||
Many intrinsics. |
Done |
||
Metadata. |
Done |
||
Setting optimization level. |
Done |
||
Packed structures. |
Done |
||
Alignment, symbol visibility, attributes. |
Done |
||
128-bit integers. |
Done |
UI tests progress
Here are the results of running the UI tests in the CI:
-
https://github.com/rust-lang/rustc_codegen_gcc/actions/runs/8938693692/job/24553335006#step:15:4472
-
https://github.com/rust-lang/rustc_codegen_gcc/actions/runs/8938693692/job/24553334727#step:15:4449
-
https://github.com/rust-lang/rustc_codegen_gcc/actions/runs/8930722686#summary-24531397699 (failures)
Category | Last Month | This Month | Delta |
---|---|---|---|
Passed |
5647 |
5664 |
+17 |
Failed |
70 |
71 |
+1 |
(I removed the LTO tests from the failed row because those tests pass in the CI job where LTO is enabled.)
How to contribute
rustc_codegen_gcc
If you want to help on the project itself, please do the following:
-
Run the tests locally.
-
Choose a test that fails.
-
Investigate why it fails.
-
Fix the problem.
Even if you can’t fix the problem, your investigation could help, so if you enjoy staring at assembly code, have fun!
Crates and rustc
If you would like to contribute on adding support for Rust on
currently unsupported platforms, you can help by adding the support
for those platforms in some crates like libc
and object
and also
in the rust compiler itself.
Test this project
Otherwise, you can test this project on new platforms and also compare the assembly with LLVM to see if some optimization is missing.
To do so, follow these instructions to build the project and run a program via the cargo
command of our script.
If you find a bug, please open an issue.
Good first issue
Finally, another good way to help is to look at good first issues. Those are issues that should be easier to start with.
Thanks for your support!
I wanted to personally thank all the people that sponsor this project: your support is very much appreciated.
A special thanks to the following sponsors:
-
Futurewei
-
saethlin
-
embark-studios
-
Shnatsel
-
Rust Foundation
-
opensrcsec
A big thank you to bjorn3 for his help, contributions and reviews. And a big thank you to lqd and GuillaumeGomez for answering my questions about rustc’s internals. Another big thank you to Commeownist for his contributions.
Also, a big thank you to the rest of my sponsors:
-
kpp
-
0x7CFE
-
oleid
-
acshi
-
joshtriplett
-
djc
-
sdroege
-
pcn
-
alanfalloon
-
davidlattimore
-
colelawrence
-
zmanian
-
alexkirsz
-
berkus
-
belzael
-
yvt
-
Shoeboxam
-
yerke
-
bes
-
srijs
-
kkysen
-
riking
-
Lemmih
-
memoryruins
-
senden9
-
robjtede
-
Jonas Platte
-
Sam Harrington
-
Jonas
-
Eugene Bulkin
-
Joseph Garvin
-
MarcoFalke
-
athre0z
-
Sebastian Zivota
-
Oskar Nehlin
-
Nicolas Barbier
-
Daniel
-
Justin Ossevoort
-
kiyoshigawa
-
Daniel Sheehan
-
Marvin Löbel
-
nacaclanga
-
0x0177b11f
-
L.apz
-
JockeTF
-
davidcornu
-
stuhood
-
Mauve
-
icewind1991
-
nicholasbishop
-
David Vasak
-
Eric Driggers
-
Olaf Leidinger
-
UtherII
-
simonlindholm
-
lemmih
-
Eddddddd
-
rrbutani
-
Mateusz K
-
thk1
-
0xdeafbeef
-
teh
-
KirilMihaylov
-
Vladislav Sukhmel
-
CohenArthur
-
ximou
-
Kate Kiesel
and a few others who preferred to stay anonymous.
Former sponsors/patreons:
-
igrr
-
Traverse-Research
-
finfet
-
Alovchin91
-
wezm
-
mexus
-
raymanfx
-
ghost
-
gilescope
-
olanod
-
Denis Zaletaev
-
Chai T. Rex
-
Paul Ellenbogen
-
Dakota Brink
-
Botlabs
-
Cass
-
Oliver Marshall
-
pthariensflame
-
tedbyron
-
sstadick
-
Absolucy
-
rafaelcaricio
-
dandxy89
-
luizirber
-
regiontog
-
vincentdephily
-
zebp
-
Hofer-Julian
-
messense
-
fanquake
-
jam1garner
-
sbstp
-
evanrichter
-
Nehliin
-
nevi-me
-
TimNN
-
steven-joruk
-
seanpianka
-
spike grobstein
-
Jeff Muizelaar
-
robinmoussu
-
Chris Butler
-
sierrafiveseven
-
icewind
-
Thomas Colliers
-
Tommy Thorn
-
Bálint Horváth
-
Matthew Conolly
-
Lapz
-
Myrik Lord
-
T
-
Emily A. Bellows
-
Chris
-
repi