From e117dc8c235b544cd9a348189c3c82ea0cf17ed8 Mon Sep 17 00:00:00 2001 From: "O.S. of Smecta" Date: Thu, 26 Dec 2024 20:37:35 +0700 Subject: [PATCH] Improve instruction for RISC-V * Improve instruction for RISC-V --- .../compiling/compiling_for_linuxbsd.rst | 23 ++++++++++++++----- 1 file changed, 17 insertions(+), 6 deletions(-) diff --git a/contributing/development/compiling/compiling_for_linuxbsd.rst b/contributing/development/compiling/compiling_for_linuxbsd.rst index 0cadc515541..96f8655b33d 100644 --- a/contributing/development/compiling/compiling_for_linuxbsd.rst +++ b/contributing/development/compiling/compiling_for_linuxbsd.rst @@ -403,12 +403,6 @@ To cross-compile Godot for RISC-V devices, we need to setup the following items: If in doubt, `use this version `__, and download ``riscv64-glibc-ubuntu-18.04-nightly-2021.12.22-nightly.tar.gz``. Extract it somewhere and remember its path. -- Clang. RISC-V GCC has - `bugs with its atomic operations `__ - which prevent it from compiling Godot correctly. Any version of Clang from 16.0.0 upwards - will suffice. Download it from the package manager of your distro, and make sure that - it *can* compile to RISC-V. You can verify by executing this command ``clang -print-targets``, - make sure you see ``riscv64`` on the list of targets. - `mold `__. This fast linker, is the only one that correctly links the resulting binary. Download it, extract it, and make sure to add its ``bin`` folder to your PATH. Run @@ -431,10 +425,27 @@ Go to the root of the source code, and execute the following build command: :: + PATH="$RISCV_TOOLCHAIN_PATH/bin:$PATH" \ scons arch=rv64 use_llvm=yes linker=mold lto=none target=editor \ ccflags="--sysroot=$RISCV_TOOLCHAIN_PATH/sysroot --gcc-toolchain=$RISCV_TOOLCHAIN_PATH -target riscv64-unknown-linux-gnu" \ linkflags="--sysroot=$RISCV_TOOLCHAIN_PATH/sysroot --gcc-toolchain=$RISCV_TOOLCHAIN_PATH -target riscv64-unknown-linux-gnu" +.. note:: + + RISC-V GCC has `bugs with its atomic operations `__ + which prevent it from compiling Godot correctly. That's why Clang is used instead. Make sure that + it *can* compile to RISC-V. You can verify by executing this command ``clang -print-targets``, + make sure you see ``riscv64`` on the list of targets. + +.. warning:: The code above includes adding ``$RISCV_TOOLCHAIN_PATH/bin`` to the PATH, + but only for the following ``scons`` command. Since riscv-gnu-toolchain uses + its own Clang located in the ``bin`` folder, adding ``$RISCV_TOOLCHAIN_PATH/bin`` + to your user's PATH environment variable may block you from accessing another + version of Clang if one is installed. For this reason it's not recommended to make + adding the bin folder permanent. You can also omit the ``PATH="$RISCV_TOOLCHAIN_PATH/bin:$PATH"`` line + if you want to use scons with self-installed version of Clang, but it may have + compatibility issues with riscv-gnu-toolchain. + The command is similar in nature, but with some key changes. ``ccflags`` and ``linkflags`` append additional flags to the build. ``--sysroot`` points to a folder simulating a Linux system, it contains all the headers, libraries,