Skip to content
This repository has been archived by the owner on Aug 22, 2024. It is now read-only.

Commit

Permalink
Make cargo mirai set the toolchain required for MIRAI. (#1114)
Browse files Browse the repository at this point in the history
  • Loading branch information
Herman Venter authored Dec 21, 2021
1 parent 96a55fe commit dbef703
Show file tree
Hide file tree
Showing 3 changed files with 9 additions and 29 deletions.
7 changes: 0 additions & 7 deletions README.md
Original file line number Diff line number Diff line change
Expand Up @@ -23,13 +23,6 @@ become security problems (denial of service, undefined behavior).
You'll need to install MIRAI as described here for [MacOS and Windows](https://github.com/facebookexperimental/MIRAI/blob/main/documentation/InstallationGuide.md)
and here for [Linux](https://github.com/facebookexperimental/MIRAI/blob/main/documentation/Linux.md).

To run MIRAI, first use `rustup override set $TOOLCHAIN`, where `$TOOLCHAIN` contains the value of
[rust-toolchain](https://github.com/facebookexperimental/MIRAI/blob/main/rust-toolchain), so that Cargo uses the same
nightly version of rustc as MIRAI does. TODO: can cargo-mirai figure out the tool-chain business?

If you forget to do the override or use the wrong version, you'll see an error message complaining about a dynamic
load library not being found.

Then use `cargo mirai` to run MIRAI over your current package. This works much like `cargo check` but uses MIRAI rather
than rustc to analyze the targets of your current package.

Expand Down
5 changes: 5 additions & 0 deletions checker/src/cargo_mirai.rs
Original file line number Diff line number Diff line change
Expand Up @@ -153,6 +153,11 @@ fn call_cargo_on_target(target: &Target, kind: &str) {
// the RUSTC_WRAPPER setting.
cmd.env("MIRAI_KIND", kind);

// Set the tool chain to be compatible with mirai
if let Some(toolchain) = option_env!("RUSTUP_TOOLCHAIN") {
cmd.env("RUSTUP_TOOLCHAIN", toolchain);
}

// Execute cmd
let exit_status = cmd
.spawn()
Expand Down
26 changes: 4 additions & 22 deletions documentation/Overview.md
Original file line number Diff line number Diff line change
Expand Up @@ -45,33 +45,15 @@ MIRAI project is inspired by and the problem space that it finds itself in.

## Current status of MIRAI

Verification tools are hard to build (even when they are not novel) and require highly specialized and hard to
find developers, so MIRAI is still in development. The initial focus of MIRAI is the Diem code base. So far MIRAI has
not found any crashing bugs of note (and hopefully never will).

Since there is a strong disinclination among developers to spend time poring over false positives and adding explicit
annotations, much of the time of the MIRAI team (Herman Venter and interns) is spent on reducing the number of false
positives, even if that means creating false negatives. As far as possible, things should work without annotations.

In order to be this precise, MIRAI needs to have an in depth understanding of what happens in the standard libraries
and other dependencies of the Diem code base, including unsafe code. There is just too much of this code for the MIRAI
team to summarize by hand, so MIRAI needs to be able to analyze and summarize it without human help. This requires MIRAI
to resolve all functions calls, including those made via traits and function parameters. Fortunately, the rust compiler
has extensive support for this, so it is possible to do this. Unfortunately, the rust compiler prefers to panic whenever
a plug-in issues a query that is not quite right, so MIRAI is still quite likely to crash when you run it over a crate
that is not part of Diem. There are also performance problems that arise from inherently exponential nature of automated
code analysis.

If you would like to use MIRAI to analyze your code, you should not expect things to work perfectly out of the box.
Try out MIRAI anyway, and let the MIRAI team know how things went and if they can help you in some way.
MIRAI v1.1.* is a stable release and is expected to work in most cases. Any issues reported on Github will be
investigated and fixed as appropriate. There are currently no plans for a v2.

## How to use MIRAI

You'll need to build and install MIRAI as described [here](https://github.com/facebookexperimental/MIRAI#using-mirai).
That done, you just build your project as normal (but start clean and set `RUSTFLAGS="-Z always_encode_mir"`) and then
touch the lib.rs file of your project and build again while also setting `RUSTC_WRAPPER=mirai`.
That done, just run `cargo mirai` in the root directory of your project.

Using the MIRAI wrapper rather than just plain old Rustc will statically analyze all the code reachable from entry
When run this way, MIRAI, will statically analyze all the code reachable from entry
points in your project. If any of these code paths can lead to an abrupt termination, you'll see Rustc-like diagnostics.

## Entry points
Expand Down

0 comments on commit dbef703

Please sign in to comment.