3.1 KiB
Tips
The following shows how to do different random small things we encountered and thought could be useful.
How to send arguments to the GCC linker
CG_RUSTFLAGS="-Clink-args=-save-temps -v" ../y.sh cargo build
How to see the personality functions in the asm dump
CG_RUSTFLAGS="-Clink-arg=-save-temps -v -Clink-arg=-dA" ../y.sh cargo build
How to see the LLVM IR for a sysroot crate
cargo build -v --target x86_64-unknown-linux-gnu -Zbuild-std
# Take the command from the output and add --emit=llvm-ir
To prevent the linker from unmangling symbols
Run with:
COLLECT_NO_DEMANGLE=1
How to use a custom-build rustc
- Build the stage2 compiler (
rustup toolchain link debug-current build/x86_64-unknown-linux-gnu/stage2
). - Clean and rebuild the codegen with
debug-current
in the filerust-toolchain
.
How to use a custom sysroot source path
If you wish to build a custom sysroot, pass the path of your sysroot source to --sysroot-source
during the prepare
step, like so:
./y.sh prepare --sysroot-source /path/to/custom/source
How to use mem-trace
rustc
needs to be built without jemalloc
so that mem-trace
can overload malloc
since jemalloc
is linked statically, so a LD_PRELOAD
-ed library won't a chance to intercept the calls to malloc
.
How to generate GIMPLE
If you need to check what gccjit is generating (GIMPLE), then take a look at how to generate it in gimple.md.
How to build a cross-compiling libgccjit
Building libgccjit
- Follow the instructions on this repo.
Configuring rustc_codegen_gcc
- Run
./y.sh prepare --cross
so that the sysroot is patched for the cross-compiling case. - Set the path to the cross-compiling libgccjit in
gcc-path
(inconfig.toml
). - Make sure you have the linker for your target (for instance
m68k-unknown-linux-gnu-gcc
) in your$PATH
. Currently, the linker name is hardcoded as being$TARGET-gcc
. Specify the target when building the sysroot:./y.sh build --sysroot --target-triple m68k-unknown-linux-gnu
. - Build your project by specifying the target:
OVERWRITE_TARGET_TRIPLE=m68k-unknown-linux-gnu ../y.sh cargo build --target m68k-unknown-linux-gnu
.
If the target is not yet supported by the Rust compiler, create a target specification file (note that the arch
specified in this file must be supported by the rust compiler).
Then, you can use it the following way:
- Add the target specification file using
--target
as an absolute path to build the sysroot:./y.sh build --sysroot --target-triple m68k-unknown-linux-gnu --target $(pwd)/m68k-unknown-linux-gnu.json
- Build your project by specifying the target specification file:
OVERWRITE_TARGET_TRIPLE=m68k-unknown-linux-gnu ../y.sh cargo build --target path/to/m68k-unknown-linux-gnu.json
.
If you get the following error:
/usr/bin/ld: unrecognised emulation mode: m68kelf
Make sure you set gcc-path
(in config.toml
) to the install directory.