2016-04-13 08:32:32 -05:00
|
|
|
# Miri
|
2016-02-02 04:47:28 -06:00
|
|
|
|
2016-04-13 19:41:37 -05:00
|
|
|
[[slides](https://solson.me/miri-slides.pdf)]
|
|
|
|
[[report](https://solson.me/miri-report.pdf)]
|
|
|
|
|
2016-04-13 08:32:32 -05:00
|
|
|
An experimental interpreter for [Rust][rust]'s [mid-level intermediate
|
2016-04-13 19:47:03 -05:00
|
|
|
representation][mir] (MIR). This project began as part of my work for the
|
|
|
|
undergraduate research course at the [University of Saskatchewan][usask].
|
2016-02-02 04:47:28 -06:00
|
|
|
|
2016-04-13 08:32:32 -05:00
|
|
|
## Download Rust nightly
|
|
|
|
|
|
|
|
I currently recommend that you install [multirust][multirust] and then use it to
|
|
|
|
install the current rustc nightly version that works with Miri:
|
|
|
|
|
|
|
|
```sh
|
2016-04-14 03:21:32 -05:00
|
|
|
multirust update nightly-2016-04-11
|
2016-04-13 08:32:32 -05:00
|
|
|
```
|
|
|
|
|
|
|
|
## Build
|
|
|
|
|
|
|
|
```sh
|
2016-04-14 03:21:32 -05:00
|
|
|
multirust run nightly-2016-04-11 cargo build
|
2016-04-13 08:32:32 -05:00
|
|
|
```
|
|
|
|
|
|
|
|
## Run a test
|
|
|
|
|
|
|
|
```sh
|
2016-04-14 03:21:32 -05:00
|
|
|
multirust run nightly-2016-04-11 cargo run -- \
|
|
|
|
--sysroot $HOME/.multirust/toolchains/nightly-2016-04-11 \
|
2016-04-13 08:32:32 -05:00
|
|
|
test/filename.rs
|
|
|
|
```
|
|
|
|
|
2016-04-14 03:21:32 -05:00
|
|
|
If you are using [rustup][rustup] (the name of the multirust rewrite in Rust),
|
|
|
|
the `sysroot` path will also include your build target (e.g.
|
|
|
|
`$HOME/.multirust/toolchains/nightly-2016-04-11-x86_64-apple-darwin`). You can
|
|
|
|
see the current toolchain's directory by running `rustup which cargo` (ignoring
|
2016-04-15 09:50:47 -05:00
|
|
|
the trailing `/bin/cargo`).
|
2016-04-14 03:21:32 -05:00
|
|
|
|
|
|
|
If you installed without using multirust or rustup, you'll need to adjust the
|
|
|
|
command to run your cargo and set the `sysroot` to the directory where your
|
|
|
|
Rust compiler is installed (`$sysroot/bin/rustc` should be a valid path).
|
2016-02-02 04:47:28 -06:00
|
|
|
|
|
|
|
## License
|
|
|
|
|
|
|
|
Licensed under either of
|
|
|
|
* Apache License, Version 2.0 ([LICENSE-APACHE](LICENSE-APACHE) or
|
|
|
|
http://www.apache.org/licenses/LICENSE-2.0)
|
|
|
|
* MIT license ([LICENSE-MIT](LICENSE-MIT) or
|
|
|
|
http://opensource.org/licenses/MIT) at your option.
|
|
|
|
|
|
|
|
### Contribution
|
|
|
|
|
|
|
|
Unless you explicitly state otherwise, any contribution intentionally submitted
|
|
|
|
for inclusion in the work by you shall be dual licensed as above, without any
|
|
|
|
additional terms or conditions.
|
2016-04-13 08:32:32 -05:00
|
|
|
|
|
|
|
[rust]: https://www.rust-lang.org/
|
|
|
|
[mir]: https://github.com/rust-lang/rfcs/blob/master/text/1211-mir.md
|
|
|
|
[usask]: https://www.usask.ca/
|
|
|
|
[multirust]: https://github.com/brson/multirust
|
2016-04-15 09:50:47 -05:00
|
|
|
[rustup]: https://www.rustup.rs
|