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
|
|
|
|
|
2019-01-26 17:03:35 +01:00
|
|
|
`$cg_clif_dir` is the directory you cloned this repo into in the following instruction.
|
|
|
|
|
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-01-15 11:53:24 +01:00
|
|
|
If you compiled cg_clif in debug mode you should use `CHANNEL="debug"` instead or omit `CHANNEL="release"` completely.
|
|
|
|
|
2019-09-12 20:27:10 +02:00
|
|
|
### Rustc
|
2018-07-18 13:35:03 +02:00
|
|
|
|
|
|
|
```bash
|
2020-01-15 11:53:24 +01:00
|
|
|
$ rustc -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-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))
|
2018-11-16 17:05:59 +01:00
|
|
|
* Checked binops ([some missing instructions in cranelift](https://github.com/CraneStation/cranelift/issues/460))
|
2019-09-12 20:27:10 +02:00
|
|
|
* Inline assembly ([no cranelift support](https://github.com/CraneStation/cranelift/issues/444), 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)
|