diff options
| author | bjorn3 <bjorn3@users.noreply.github.com> | 2021-03-06 19:19:29 +0100 |
|---|---|---|
| committer | bjorn3 <bjorn3@users.noreply.github.com> | 2021-03-06 19:19:29 +0100 |
| commit | 76bb1f173f35c4d0fa4de6c7d4651a1367e61bdb (patch) | |
| tree | 83eacbf496a1461125f0e39b001e9b335d55dfdf /docs | |
| parent | d194c707c82198864cd1493a9e104f904d354e16 (diff) | |
| download | rust-76bb1f173f35c4d0fa4de6c7d4651a1367e61bdb.tar.gz rust-76bb1f173f35c4d0fa4de6c7d4651a1367e61bdb.zip | |
Move the more advanced ways to use cg_clif to usage.md
Diffstat (limited to 'docs')
| -rw-r--r-- | docs/usage.md | 66 |
1 files changed, 66 insertions, 0 deletions
diff --git a/docs/usage.md b/docs/usage.md new file mode 100644 index 00000000000..defe16ab3af --- /dev/null +++ b/docs/usage.md @@ -0,0 +1,66 @@ +# Usage + +rustc_codegen_cranelift can be used as a near-drop-in replacement for `cargo build` or `cargo run` for existing projects. + +Assuming `$cg_clif_dir` is the directory you cloned this repo into and you followed the instructions (`prepare.sh` and `build.sh` or `test.sh`). + +## Cargo + +In the directory with your project (where you can do the usual `cargo build`), run: + +```bash +$ $cg_clif_dir/build/cargo.sh build +``` + +This will build and run your project with rustc_codegen_cranelift instead of the usual LLVM backend. + +## Rustc + +> You should prefer using the Cargo method. + +```bash +$ $cg_clif_dir/build/bin/cg_clif my_crate.rs +``` + +## Jit mode + +In jit mode cg_clif will immediately execute your code without creating an executable file. + +> This requires all dependencies to be available as dynamic library. +> The jit mode will probably need cargo integration to make this possible. + +```bash +$ $cg_clif_dir/build/cargo.sh jit +``` + +or + +```bash +$ $cg_clif_dir/build/bin/cg_clif -Cllvm-args=mode=jit -Cprefer-dynamic my_crate.rs +``` + +There is also an experimental lazy jit mode. In this mode functions are only compiled once they are +first called. It currently does not work with multi-threaded programs. When a not yet compiled +function is called from another thread than the main thread, you will get an ICE. + +```bash +$ $cg_clif_dir/build/cargo.sh lazy-jit +``` + +## 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_dir/build/bin/cg_clif - -Cllvm-args=mode=jit -Cprefer-dynamic +} + +function jit() { + jit_naked "fn main() { $@ }" +} + +function jit_calc() { + jit 'println!("0x{:x}", ' $@ ');'; +} +``` |
