diff --git a/Documentation/process/changes.rst b/Documentation/process/changes.rst index 7a1d2837d2c3d1..7654a7105dcf50 100644 --- a/Documentation/process/changes.rst +++ b/Documentation/process/changes.rst @@ -26,12 +26,17 @@ running a Linux kernel. Also, not all tools are necessary on all systems; obviously, if you don't have any PC Card hardware, for example, you probably needn't concern yourself with pcmciautils. +Furthermore, note that newer versions of the Rust toolchain may or may not work +because, for the moment, we depend on some unstable features. Thus, unless you +know what you are doing, use the exact version listed here. Please see +:ref:`Documentation/rust/quick-start.rst ` for details. + ====================== =============== ======================================== Program Minimal version Command to check the version ====================== =============== ======================================== GNU C 4.9 gcc --version Clang/LLVM (optional) 10.0.1 clang --version -rustc (optional) nightly rustc --version +rustc (optional) 1.54.0-beta.1 rustc --version bindgen (optional) 0.56.0 bindgen --version GNU make 3.81 make --version binutils 2.23 ld -v @@ -57,7 +62,6 @@ iptables 1.4.2 iptables -V openssl & libcrypto 1.0.0 openssl version bc 1.06.95 bc --version Sphinx\ [#f1]_ 1.3 sphinx-build --version -rustdoc (optional) nightly rustdoc --version ====================== =============== ======================================== .. [#f1] Sphinx is needed only to build the Kernel documentation diff --git a/Documentation/rust/quick-start.rst b/Documentation/rust/quick-start.rst index 4a99317ecf3510..23333625076e9c 100644 --- a/Documentation/rust/quick-start.rst +++ b/Documentation/rust/quick-start.rst @@ -23,13 +23,13 @@ at the time of writing, they are likely to not be recent enough. rustc ***** -A recent *nightly* Rust toolchain (with, at least, ``rustc``) is required, -e.g. ``nightly-2021-05-29``. Our goal is to use a stable toolchain as soon -as possible, but for the moment we depend on a handful of nightly features. +A particular version (`1.54.0-beta.1`) of the Rust compiler is required. +Newer versions may or may not work because, for the moment, we depend on +some unstable Rust features. If you are using ``rustup``, run:: - rustup default nightly-2021-05-29 + rustup default beta-2021-06-23 Otherwise, fetch a standalone installer or install ``rustup`` from: @@ -125,16 +125,30 @@ the component manually:: The standalone installers also come with ``clippy``. +cargo +***** + +``cargo`` is the Rust native build system. It is currently required to run +the tests (``rusttest`` target) since we use it to build a custom standard +library that contains the facilities provided by our custom ``alloc``. + +If you are using ``rustup``, all the profiles already install the tool, +so you should be good to go. The standalone installers also include ``cargo``. + + rustdoc ******* -If you install the ``rustdoc`` tool, then you will be able to generate pretty -HTML documentation for Rust code, including for the libraries (crates) inside -``rust/`` that are used by the rest of the kernel (for details, please see -:ref:`Documentation/rust/docs.rst `). +``rustdoc`` is the documentation tool for Rust. It generates pretty HTML +documentation for Rust code (for details, please see +:ref:`Documentation/rust/docs.rst `. + +``rustdoc`` is also able to test the examples provided in documented Rust code +(called doctests or documentation tests). We use this feature, thus ``rustdoc`` +is required to run the tests (``rusttest`` target). If you are using ``rustup``, all the profiles already install the tool, -so you should be good to go. The standalone installers also come with ``rustdoc``. +so you should be good to go. The standalone installers also include ``rustdoc``. rust-analyzer