rustc_driversrustc_privateThe rustc_private feature allows external crates to use compiler internals.
rustc_private with official toolchainsWhen using the rustc_private feature with official Rust toolchains distributed via rustup, you need to install two additional components:
rustc-dev: Provides compiler librariesllvm-tools: Provides LLVM libraries required for linkingInstall both components using rustup:
rustup component add rustc-dev llvm-tools
Without the llvm-tools component, you'll encounter linking errors like:
error: linking with `cc` failed: exit status: 1 | = note: rust-lld: error: unable to find library -lLLVM-{version}
rustc-private with Custom ToolchainsFor custom-built toolchains or environments not using rustup, additional configuration is typically required:
export LD_LIBRARY_PATH=/path/to/llvm/lib:$LD_LIBRARY_PATH
rust-analyzer for out-of-tree projectsWhen developing out-of-tree projects that use rustc_private crates, you can configure rust-analyzer to recognize these crates.
Configure rust-analyzer.rustc.source to "discover" in your editor settings.
For VS Code, add to rust_analyzer_settings.json:
{ "rust-analyzer.rustc.source": "discover" }
Add the following to the Cargo.toml of every crate that uses rustc_private:
[package.metadata.rust-analyzer] rustc_private = true
This configuration allows rust-analyzer to properly recognize and provide IDE support for rustc_private crates in out-of-tree projects.
rustc_privateFor the latest nightly, you can install the rustc-docs component and open it directly in your browser:
rustup component add rustc-docs rustup doc --rustc-docs
Note: The
rustc-docscomponent is only available for recent nightly toolchains and may not be present for every nightly date. It was first introduced in PR #75560 (August 2020).
If you depend on compiler internals from an older nightly, you may want to refer to the internal documentation from that particular nightly. The only way to do this is to generate the documentation locally. For example, to get documentation for nightly-2025-11-08:
Get the Git commit hash for that nightly:
rustup toolchain install nightly-2025-11-08 rustc +nightly-2025-11-08 --version --verbose
The output will include a commit-hash line identifying the exact source revision. Check out rust-lang/rust at that commit, then follow the steps in compiler documentation.
rustc_private linker failures often occur because llvm-tools is not installed