2023-01-11 09:32:08 +00:00

2.5 KiB

This directory contains unit tests for the MIR-based dataflow analysis.

These unit tests check the dataflow analysis by embedding calls to a special rustc_peek intrinsic within the code, in tandem with an attribute #[rustc_mir(rustc_peek_maybe_init)] (*). With that attribute in place, rustc_peek calls are a signal to the compiler to lookup the computed dataflow state for the Lvalue corresponding to the argument expression being fed to rustc_peek. If the dataflow state for that Lvalue is a 1-bit at that point in the control flow, then no error is emitted by the compiler at that point; if it is a 0-bit, then that invocation of rustc_peek will emit an error with the message "rustc_peek: bit not set".

(*): Or #[rustc_mir(rustc_peek_maybe_uninit)], and perhaps other variants in the future.

The end effect is that one can write unit tests for MIR dataflow that perform simple-queries of the computed dataflow state, and the tests should be able to be robust in the face of changes to how MIR is represented or constructed.


Sometimes understanding the dataflow results is difficult without looking at the actual MIR control-flow graph being processed with the corresponding GEN and KILL sets.

For a graphviz-rendering with dataflow annotations, add the attribute #[rustc_mir(borrowck_graphviz_postflow="/path/to/suffix.dot")] to the function in question. (You can change the content of "suffix.dot" to control the filenames used for the output). This will generate a separate file for each dataflow analysis, adding a prefix (corresponding to the name of the analysis) to the filename in each generated output path.

  • For example, the above attribute will currently cause two files to be generated: /path/to/maybe_init_suffix.dot and /path/to/maybe_uninit_suffix.dot.

  • The generated .dot file shows both the computed dataflow results on entry to each block, as well as the gen- and kill-sets that were so-called "transfer functions" summarizing the effect of each basic block.

  • (In addition to the borrowck_graphviz_postflow attribute-key noted above, there is also borrowck_graphviz_preflow; it has the same interface and generates the same set of files, but it renders the dataflow state after building the gen- and kill-sets but before running the dataflow analysis itself, so each entry-set is just the initial default state for that dataflow analysis. This is less useful for understanding the error message output in these tests.)