Warning Runtime rvv detection (using
hwcap
) requires linux kernel 6.5 or newer.When running on older kernels, we fall back to compile-time detection, potentially this can cause crashes if rvv is enabled at compile but not supported by the target cpu. Therefore if older kernel support is needed, rvv should be disabled if the target cpu does not support it.
If you don't have prebuilt clang and riscv64 qemu, you can refer to the script to get the source. Copy the script to the zlib-ng root directory, and run it to download the source and build them. Modify the content according to your conditions (e.g., toolchain version).
./prepare_riscv_toolchain_qemu.sh
After running script, clang & qemu are built in build-toolchain-qemu/riscv-clang/
& build-toolchain-qemu/riscv-qemu/
.
build-toolchain-qemu/riscv-clang/
is your TOOLCHAIN_PATH
.
build-toolchain-qemu/riscv-qemu/bin/qemu-riscv64
is your QEMU_PATH
.
You can also download the prebuilt toolchain & qemu from the release page, and enjoy using them.
cmake -G Ninja -B ./build-riscv \
-D CMAKE_TOOLCHAIN_FILE=./cmake/toolchain-riscv.cmake \
-D CMAKE_INSTALL_PREFIX=./build-riscv/install \
-D TOOLCHAIN_PATH={TOOLCHAIN_PATH} \
-D QEMU_PATH={QEMU_PATH} \
.
cmake --build ./build-riscv
Disable the option if there is no RVV support:
-D WITH_RVV=OFF
cd ./build-riscv && ctest --verbose