rustc_codegen_gcc: Progress Report #40

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

There wasn’t much progress in the past 2 months on this side, but one patch was merged upstream:

State of rustc_codegen_gcc

Here’s what has been done during the past months:

As you may have seen on Reddit, rustc_codegen_gcc is now distributed on rustup! Thanks a lot to Kobzol, bjorn3, GuillaumeGomez and all others who helped with this. It is to be noted that there are some issues with it (especially proc-macros) since it uses a standard library compiled with a LLVM-based rustc (most likely an ABI issue). I will do a proper announcement blog post after adding some tests of the rustup artifacts: this will allow me to quickly fix any issues that arise there. For now, it is only distributed for Linux x86-64.

I have an idea of what could be the issue here and if it is what I think, it might take a couple months to have a proper fix for this since GCC gives less control over the ABI than LLVM. In the next months, I’ll attempt to fix this or at least provide a temporary workaround to make sure that the version distributed by rustup works as well as the version in the project repository. Also, I’ll get back to my work of building a working rustc for m68k.

Here’s a rough summary of what has been implemented:

Feature Last month completion Completion Delta

Run tests in the Rust CI

60%

60%

Rustup distribution.

40%

100%

+60%

Unwinding.

80%

80%

More function and variable attributes.

22%

22%

Target features (to detect what is supported in an architecture, like SIMD).

82%

82%

Debug info.

20%

20%

Thin LTO.

5%

5%

Support for new architectures in libraries (libc, object, …) and rustc.

2%

2%

SIMD for other architectures than x86-64.

0%

Refactor to rustc_codegen_ssa to make it easier for the GCC codegen

0%

LTO

Done

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

How to contribute

rustc_codegen_gcc

If you want to help on the project itself, please do the following:

  1. Run the tests locally.

  2. Choose a test that fails.

  3. Investigate why it fails.

  4. 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

  • Shnatsel

  • Rust Foundation

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 and to Kobzol and GuillaumeGomez for their contributions. Another big thank you to Commeownist for his contributions.

Also, a big thank you to the rest of my sponsors:

  • kpp

  • 0x7CFE

  • oleid

  • joshtriplett

  • djc

  • sdroege

  • pcn

  • alanfalloon

  • davidlattimore

  • colelawrence

  • zmanian

  • berkus

  • belzael

  • yvt

  • yerke

  • 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

  • teh

  • KirilMihaylov

  • Vladislav Sukhmel

  • ximou

  • Kate Kiesel

  • jplatte

  • VasanthakumarV

  • thesamesam

  • sbstp

  • Laine Taffin Altman

  • LunNova

  • Robin Moussu

and a few others who preferred to stay anonymous.

Former sponsors/patreons:

  • igrr

  • embark-studios

  • saethlin

  • 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

  • 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

  • opensrcsec

  • NobodyXu

  • alexkirsz

  • 0xdeafbeef

  • l-const

  • CohenArthur

  • bes

  • acshi

  • Shoeboxam

  • teohhanhui

  • g4titanx