2019-09-20 09:54:23 +02:00
# WIP Cranelift codegen backend for rust
2018-07-18 11:55:32 +02:00
2020-03-12 11:20:36 +01:00
> ⚠⚠⚠ Certain kinds of FFI don't work yet. ⚠⚠⚠
2018-07-18 11:55:32 +02:00
## Building
```bash
2018-07-18 13:35:03 +02:00
$ git clone https://github.com/bjorn3/rustc_codegen_cranelift.git
2018-07-18 11:55:32 +02:00
$ cd rustc_codegen_cranelift
2019-04-14 10:49:07 +02:00
$ ./prepare.sh # download and patch sysroot src and install hyperfine for benchmarking
2020-01-15 11:53:24 +01:00
$ ./test.sh --release
2018-07-18 11:55:32 +02:00
```
## Usage
2020-05-05 12:06:15 +02:00
`$cg_clif_dir` is the directory you cloned this repo into in the following instructions.
2019-01-26 17:03:35 +01:00
2019-09-12 20:27:10 +02:00
### Cargo
2019-01-26 17:03:35 +01:00
2018-07-18 11:55:32 +02:00
```bash
2020-01-15 11:53:24 +01:00
$ CHANNEL="release" $cg_clif_dir/cargo.sh run
2018-07-18 11:55:32 +02:00
```
2020-04-08 12:44:10 +02:00
If you compiled cg_clif in debug mode (aka you didn't pass `--release` to `./test.sh` ) you should use `CHANNEL="debug"` instead or omit `CHANNEL="release"` completely.
2020-01-15 11:53:24 +01:00
2019-09-12 20:27:10 +02:00
### Rustc
2018-07-18 13:35:03 +02:00
2020-04-08 12:32:00 +02:00
> You should prefer using the Cargo method.
2018-07-18 13:35:03 +02:00
```bash
2020-04-08 12:32:00 +02:00
$ rustc +$(cat $cg_clif_dir/rust-toolchain) -Cpanic=abort -Zcodegen-backend=$cg_clif_dir/target/release/librustc_codegen_cranelift.so --sysroot $cg_clif_dir/build_sysroot/sysroot my_crate.rs
2018-07-18 13:35:03 +02:00
```
2020-05-05 12:06:15 +02:00
### Shell
These are a few functions that allow you to easily run rust code from the shell using cg_clif as jit.
```bash
function jit_naked() {
echo "$@" | CG_CLIF_JIT=1 rustc -Zcodegen-backend=$cg_clif_dir/target/release/librustc_codegen_cranelift.so --sysroot $cg_clif_dir/build_sysroot/sysroot - -Cprefer-dynamic
}
function jit() {
jit_naked "fn main() { $@ }"
}
function jit_calc() {
jit 'println!("0x{:x}", ' $@ ');';
}
```
2020-03-12 11:17:19 +01:00
## Env vars
< dl >
< dt > CG_CLIF_JIT< / dt >
< dd > Enable JIT mode to immediately run a program instead of writing an executable file.< / dd >
< dt > CG_CLIF_JIT_ARGS< / dt >
< dd > When JIT mode is enable pass these arguments to the program.< / dd >
2020-03-12 11:25:35 +01:00
< dt > CG_CLIF_INCR_CACHE_DISABLED< / dt >
2020-03-12 11:17:19 +01:00
< dd > Don't cache object files in the incremental cache. Useful during development of cg_clif
to make it possible to use incremental mode for all analyses performed by rustc without caching
object files when their content should have been changed by a change to cg_clif.< / dd >
< dt > CG_CLIF_DISPLAY_CG_TIME< / dt >
< dd > Display the time it took to perform codegen for a crate< / dd >
< / dl >
2019-09-12 20:27:10 +02:00
2018-07-18 11:55:32 +02:00
## Not yet supported
2019-09-12 20:27:10 +02:00
* Good non-rust abi support ([several problems](https://github.com/bjorn3/rustc_codegen_cranelift/issues/10))
2020-03-14 20:52:20 +01:00
* Checked binops ([some missing instructions in cranelift](https://github.com/bytecodealliance/wasmtime/issues/1044))
* Inline assembly ([no cranelift support](https://github.com/bytecodealliance/wasmtime/issues/1041), not coming soon)
2019-07-30 14:51:05 +02:00
* SIMD ([tracked here](https://github.com/bjorn3/rustc_codegen_cranelift/issues/171), some basic things work)