From 5cb6209de5379411a28d94ebea3fe1abaac3d26b Mon Sep 17 00:00:00 2001 From: lhl Date: Mon, 16 Dec 2024 16:44:57 +0900 Subject: [PATCH] Fixes for building SYCL backend for AMD GPUs - cmake has a hardcoded `onemkl` that will cause linker failure for AMD path and needs to be changed - docfix: oneMKL compile needs `-DHIP_TARGETS` not `-DHIPTARGETS` - docfix: modified cmake build parameters to pass in more linker flags, otherwise linking will fail (might be slight overkill, but without adding `-DCMAKE_SHARED_LINKER_FLAGS` it fails --- docs/backend/SYCL.md | 12 +++++++----- ggml/src/ggml-sycl/CMakeLists.txt | 2 +- 2 files changed, 8 insertions(+), 6 deletions(-) diff --git a/docs/backend/SYCL.md b/docs/backend/SYCL.md index 8d8312e91..b0d500466 100644 --- a/docs/backend/SYCL.md +++ b/docs/backend/SYCL.md @@ -237,7 +237,7 @@ cmake --build buildWithCublas --config Release git clone https://github.com/oneapi-src/oneMKL cd oneMKL # Find your HIPTARGET with rocminfo, under the key 'Name:' -cmake -B buildWithrocBLAS -DCMAKE_CXX_COMPILER=icpx -DCMAKE_C_COMPILER=icx -DENABLE_MKLGPU_BACKEND=OFF -DENABLE_MKLCPU_BACKEND=OFF -DENABLE_ROCBLAS_BACKEND=ON -DHIPTARGETS=${HIPTARGET} -DTARGET_DOMAINS=blas +cmake -B buildWithrocBLAS -DCMAKE_CXX_COMPILER=icpx -DCMAKE_C_COMPILER=icx -DENABLE_MKLGPU_BACKEND=OFF -DENABLE_MKLCPU_BACKEND=OFF -DENABLE_ROCBLAS_BACKEND=ON -DHIP_TARGETS=${HIPTARGET} -DTARGET_DOMAINS=blas cmake --build buildWithrocBLAS --config Release ``` @@ -330,9 +330,10 @@ cmake --build build --config Release -j -v ```sh # Export relevant ENV variables -export LD_LIBRARY_PATH=/path/to/oneMKL/buildWithrocBLAS/lib:$LD_LIBRARY_PATH -export LIBRARY_PATH=/path/to/oneMKL/buildWithrocBLAS/lib:$LIBRARY_PATH -export CPLUS_INCLUDE_DIR=/path/to/oneMKL/buildWithrocBLAS/include:$CPLUS_INCLUDE_DIR +export MKL_ROCBLAS=/path/to/oneMKL/buildWithrocmBLAS/lib +export LD_LIBRARY_PATH=$MKL_ROCBLAS:$LD_LIBRARY_PATH +export LIBRARY_PATH=$MKL_ROCBLAS:$LIBRARY_PATH +export CPLUS_INCLUDE_DIR=$MKL_ROCBLAS:$CPLUS_INCLUDE_DIR # Build LLAMA with rocBLAS acceleration through SYCL @@ -340,7 +341,8 @@ export CPLUS_INCLUDE_DIR=/path/to/oneMKL/buildWithrocBLAS/include:$CPLUS_INCLUDE # Use FP32, FP16 is not supported # Find your GGML_SYCL_DEVICE_ARCH with rocminfo, under the key 'Name:' GGML_SYCL_DEVICE_ARCH=gfx90a # Example architecture -cmake -B build -DGGML_SYCL=ON -DGGML_SYCL_TARGET=AMD -DGGML_SYCL_DEVICE_ARCH=${GGML_SYCL_DEVICE_ARCH} -DCMAKE_C_COMPILER=icx -DCMAKE_CXX_COMPILER=icpx +cmake -B build -DGGML_SYCL=ON -DGGML_SYCL_TARGET=AMD -DGGML_SYCL_DEVICE_ARCH=${GGML_SYCL_DEVICE_ARCH} -DCMAKE_C_COMPILER=icx -DCMAKE_CXX_COMPILER=icpx -DCMAKE_SHARED_LINKER_FLAGS="-L$MKL_ROCBLAS -L/opt/intel/oneapi/mkl/latest/lib/intel64 -lonemath_blas_rocblas -Wl,--no-as-needed -lmkl_sycl -lmkl_intel_ilp64 -lmkl_sequential -lmkl_core" + # build all binary cmake --build build --config Release -j -v diff --git a/ggml/src/ggml-sycl/CMakeLists.txt b/ggml/src/ggml-sycl/CMakeLists.txt index 3579a311a..d7490372e 100644 --- a/ggml/src/ggml-sycl/CMakeLists.txt +++ b/ggml/src/ggml-sycl/CMakeLists.txt @@ -75,7 +75,7 @@ else() message(ERROR "Can't enable SYCL hip backend, GGML_SYCL_DEVICE_ARCH has not been set.") endif() set(CMAKE_CXX_FLAGS "${CMAKE_CXX_FLAGS} -fsycl-targets=amdgcn-amd-amdhsa") - target_link_libraries(ggml-sycl PRIVATE sycl pthread m dl onemkl) + target_link_libraries(ggml-sycl PRIVATE sycl pthread m dl onemath_blas_rocblas) endif() if (GGML_SYCL_DEVICE_ARCH)