mirror of
https://chromium.googlesource.com/libyuv/libyuv
synced 2025-12-06 16:56:55 +08:00
1. Add two defined marco LIBYUV_RVV_HAS_TUPLE_TYPE & LIBYUV_RVV_HAS_VXRM_ARG Intrinsic v0.12 introduces - tuple type in segment load & store - vxrm argument in fixed-point intrinsics (e.g vnclip) These two marcos are controled by __riscv_v_intrinsic. 2. Support RVV v0.12 intrinsics in row_rvv.cc & scale_rvv.cc Change-Id: I921f91d9dc8fdda031e7b6647d0e296aa2793c39 Signed-off-by: Bruce Lai <bruce.lai@sifive.com> Reviewed-on: https://chromium-review.googlesource.com/c/libyuv/libyuv/+/4767120 Reviewed-by: Frank Barchard <fbarchard@chromium.org>
57 lines
2.3 KiB
CMake
57 lines
2.3 KiB
CMake
set(CMAKE_CROSSCOMPILING TRUE)
|
|
set(CMAKE_SYSTEM_NAME "Linux")
|
|
set(CMAKE_SYSTEM_PROCESSOR "riscv64")
|
|
|
|
option(USE_RVV "Enable riscv vector or not." ON)
|
|
option(USE_AUTO_VECTORIZER "Enable riscv auto vectorizer or not." OFF)
|
|
|
|
# Avoid to use system path for cross-compile
|
|
set(CMAKE_FIND_USE_CMAKE_SYSTEM_PATH FALSE)
|
|
|
|
set(TOOLCHAIN_PATH "" CACHE STRING "The toolcahin path.")
|
|
if(NOT TOOLCHAIN_PATH)
|
|
set(TOOLCHAIN_PATH ${CMAKE_SOURCE_DIR}/build-toolchain-qemu/riscv-clang)
|
|
endif()
|
|
|
|
set(TOOLCHAIN_PREFIX "riscv64-unknown-linux-gnu-" CACHE STRING "The toolcahin prefix.")
|
|
|
|
# toolchain setting
|
|
set(CMAKE_C_COMPILER "${TOOLCHAIN_PATH}/bin/${TOOLCHAIN_PREFIX}clang")
|
|
set(CMAKE_CXX_COMPILER "${TOOLCHAIN_PATH}/bin/${TOOLCHAIN_PREFIX}clang++")
|
|
|
|
# CMake will just use the host-side tools for the following tools, so we setup them here.
|
|
set(CMAKE_C_COMPILER_AR "${TOOLCHAIN_PATH}/bin/llvm-ar")
|
|
set(CMAKE_CXX_COMPILER_AR "${TOOLCHAIN_PATH}/bin/llvm-ar")
|
|
set(CMAKE_C_COMPILER_RANLIB "${TOOLCHAIN_PATH}/bin/llvm-ranlib")
|
|
set(CMAKE_CXX_COMPILER_RANLIB "${TOOLCHAIN_PATH}/bin/llvm-ranlib")
|
|
set(CMAKE_OBJDUMP "${TOOLCHAIN_PATH}/bin/llvm-objdump")
|
|
set(CMAKE_OBJCOPY "${TOOLCHAIN_PATH}/bin/llvm-objcopy")
|
|
|
|
# compile options
|
|
set(RISCV_COMPILER_FLAGS "" CACHE STRING "Compile flags")
|
|
# if user provides RISCV_COMPILER_FLAGS, appeding compile flags is avoided.
|
|
if(RISCV_COMPILER_FLAGS STREQUAL "")
|
|
message(STATUS "USE_RVV: ${USE_RVV}")
|
|
message(STATUS "USE_AUTO_VECTORIZER: ${USE_AUTO_VECTORIZER}")
|
|
if(USE_RVV)
|
|
list(APPEND RISCV_COMPILER_FLAGS "-march=rv64gcv")
|
|
if(NOT USE_AUTO_VECTORIZER)
|
|
# Disable auto-vectorizer
|
|
add_compile_options(-fno-vectorize -fno-slp-vectorize)
|
|
endif()
|
|
else()
|
|
list(APPEND RISCV_COMPILER_FLAGS "-march=rv64gc")
|
|
endif()
|
|
endif()
|
|
add_compile_options("-Wuninitialized")
|
|
message(STATUS "RISCV_COMPILER_FLAGS: ${RISCV_COMPILER_FLAGS}")
|
|
|
|
set(CMAKE_C_FLAGS "${RISCV_COMPILER_FLAGS} ${CMAKE_C_FLAGS}")
|
|
set(CMAKE_CXX_FLAGS "${RISCV_COMPILER_FLAGS} ${CMAKE_CXX_FLAGS}")
|
|
|
|
set(RISCV_LINKER_FLAGS "-lstdc++ -lpthread -lm -ldl")
|
|
set(RISCV_LINKER_FLAGS_EXE)
|
|
set(CMAKE_SHARED_LINKER_FLAGS "${RISCV_LINKER_FLAGS} ${CMAKE_SHARED_LINKER_FLAGS}")
|
|
set(CMAKE_MODULE_LINKER_FLAGS "${RISCV_LINKER_FLAGS} ${CMAKE_MODULE_LINKER_FLAGS}")
|
|
set(CMAKE_EXE_LINKER_FLAGS "${RISCV_LINKER_FLAGS} ${RISCV_LINKER_FLAGS_EXE} ${CMAKE_EXE_LINKER_FLAGS}")
|