fatal error: 'CL/sycl.hpp' file not found
Opened this issue · 9 comments
MKLShim build fails with following error:
$ make -j1 VERBOSE=1
...
[ 25%] Building CXX object src/CMakeFiles/MKLShim.dir/Context.cpp.o
cd /mnt/md1/linehill/ws-mklshim/builds/mklshim/src && /usr/bin/clang++ -DMKLShim_EXPORTS -I/mnt/md1/linehill/ws-mklshim/H4I-MKLShim/include -fsycl -fPIC -std=c++17 -MD -MT src/CMakeFiles/MKLShim.dir/Context.cpp.o -MF CMakeFiles/MKLShim.dir/Context.cpp.o.d -o CMakeFiles/MKLShim.dir/Context.cpp.o -c /mnt/md1/linehill/ws-mklshim/H4I-MKLShim/src/Context.cpp
/mnt/md1/linehill/ws-mklshim/H4I-MKLShim/src/Context.cpp:3:10: fatal error: 'oneapi/mkl.hpp' file not found
#include "oneapi/mkl.hpp"
^~~~~~~~~~~~~~~~
1 error generated.
The project was configured as followed:
mkdir -p builds/mklshim/
cd builds/mklshim/ && . /opt/intel/oneapi/setvars.sh && cmake \
-DCMAKE_INSTALL_PREFIX=/mnt/md1/linehill/ws-mklshim \
-DCMAKE_CXX_COMPILER=clang++ \
/mnt/md1/linehill/ws-mklshim/H4I-MKLShim
:: initializing oneAPI environment ...
dash: SH_VERSION = unknown
args: Using "$@" for setvars.sh arguments:
:: advisor -- latest
:: ccl -- latest
:: compiler -- latest
:: dal -- latest
:: debugger -- latest
:: dev-utilities -- latest
:: dnnl -- latest
:: dpcpp-ct -- latest
:: dpl -- latest
:: ipp -- latest
:: ippcp -- latest
:: ipp -- latest
:: mkl -- latest
:: mpi -- latest
:: tbb -- latest
:: vtune -- latest
:: oneAPI environment initialized ::
-- The CXX compiler identification is Clang 14.0.6
-- Detecting CXX compiler ABI info
-- Detecting CXX compiler ABI info - done
-- Check for working CXX compiler: /usr/bin/clang++ - skipped
-- Detecting CXX compile features
-- Detecting CXX compile features - done
CMake Warning at /opt/intel/oneapi/compiler/2023.1.0/linux/IntelDPCPP/IntelDPCPPConfig.cmake:80 (message):
IntelDPCPP Config will be deprecated soon. Use IntelSYCL config instead!
Call Stack (most recent call first):
CMakeLists.txt:30 (find_package)
-- The SYCL compiler is /usr/bin/clang++
-- The SYCL Flags are -fsycl
-- The SYCL Language Version is 202001
-- Found IntelDPCPP: /usr/lib/llvm-14/include (found version "202001")
-- MKL_ARCH: None, set to ` intel64` by default
-- MKL_LINK: None, set to ` dynamic` by default
-- MKL_INTERFACE_FULL: None, set to ` intel_ilp64` by default
-- MKL_THREADING: sequential
-- MKL_MPI: None, set to ` intelmpi` by default
-- Found MKL: intelmpi
-- Found MKL: /opt/intel/oneapi/mkl/2023.1.0
-- Found MKL: /opt/intel/oneapi/mkl/2023.1.0/lib/intel64/libmkl_sycl.so
-- Found MKL: /usr/lib/x86_64-linux-gnu/libmkl_intel_ilp64.so
-- Found MKL: /usr/lib/x86_64-linux-gnu/libmkl_core.so
-- Found MKL: /usr/lib/x86_64-linux-gnu/libmkl_sequential.so
-- Known MKL Targets: MKL::mkl_sycl;MKL::mkl_intel_ilp64;MKL::mkl_core;MKL::mkl_sequential;MKL::MKL_DPCPP;MKL::MKL
-- Configuring done
-- Generating done
-- Build files have been written to: /mnt/md1/linehill/ws-mklshim/builds/mklshim
I can't reproduce the issue. Please let me know if you still see the issue with latest.
With the latest update the compilation seems to fail later on different thing:
[ 83%] Building CXX object src/CMakeFiles/MKLShim.dir/onemklblas.cpp.o
/mnt/md1/linehill/ws-chip-spv-2/H4I-MKLShim/src/Stream.cpp:3:10: fatal error: 'CL/sycl.hpp' file not found
#include <CL/sycl.hpp>
^~~~~~~~~~~~~
In file included from /mnt/md1/linehill/ws-chip-spv-2/H4I-MKLShim/src/Common.cpp:1:
In file included from /mnt/md1/linehill/ws-chip-spv-2/H4I-MKLShim/include/h4i/mklshim/common.h:4:
In file included from /opt/intel/oneapi/mkl/2023.1.0/include/oneapi/mkl.hpp:26:
/opt/intel/oneapi/mkl/2023.1.0/include/oneapi/mkl/blas.hpp:22:10: fatal error: 'CL/sycl.hpp' file not found
#include <CL/sycl.hpp>
^~~~~~~~~~~~~
(same error repeated...)
A configuration warning before the build is concerning:
...
-- Detecting CXX compile features
-- Detecting CXX compile features - done
CMake Warning at /opt/intel/oneapi/compiler/2023.1.0/linux/IntelDPCPP/IntelDPCPPConfig.cmake:80 (message):
IntelDPCPP Config will be deprecated soon. Use IntelSYCL config instead!
Call Stack (most recent call first):
CMakeLists.txt:30 (find_package)
-- The SYCL compiler is /usr/bin/clang++
...
@linehill, may I know the cmake command that you have used? Also can you confirm if you have oneAPI package(HPC toolkit) installed? Remember you have to run "intel/oneapi/setvars.sh" every time.
may I know the cmake command that you have used?
The command:
cd builds/mklshim/ && logsave configure.log cmake \
-DCMAKE_INSTALL_PREFIX=/mnt/md1/linehill/ws-chip-spv-2/install \
-DCMAKE_CXX_COMPILER=clang++ \
/mnt/md1/linehill/ws-chip-spv-2/H4I-MKLShim
Full configure log:
-- The CXX compiler identification is Clang 14.0.6
-- Detecting CXX compiler ABI info
-- Detecting CXX compiler ABI info - done
-- Check for working CXX compiler: /usr/bin/clang++ - skipped
-- Detecting CXX compile features
-- Detecting CXX compile features - done
CMake Warning at /opt/intel/oneapi/compiler/2023.1.0/linux/IntelDPCPP/IntelDPCPPConfig.cmake:80 (message):
IntelDPCPP Config will be deprecated soon. Use IntelSYCL config instead!
Call Stack (most recent call first):
CMakeLists.txt:30 (find_package)
-- The SYCL compiler is /usr/bin/clang++
-- The SYCL Flags are -fsycl
-- The SYCL Language Version is 202001
-- Found IntelDPCPP: /usr/lib/llvm-14/include (found version "202001")
-- MKL_ARCH: None, set to ` intel64` by default
-- MKL_LINK: None, set to ` dynamic` by default
-- MKL_INTERFACE_FULL: None, set to ` intel_ilp64` by default
-- MKL_THREADING: sequential
-- MKL_MPI: None, set to ` intelmpi` by default
-- Found MKL: intelmpi
-- Found MKL: /opt/intel/oneapi/mkl/2023.1.0
-- Found MKL: /opt/intel/oneapi/mkl/2023.1.0/lib/intel64/libmkl_sycl.so
-- Found MKL: /usr/lib/x86_64-linux-gnu/libmkl_intel_ilp64.so
-- Found MKL: /usr/lib/x86_64-linux-gnu/libmkl_core.so
-- Found MKL: /usr/lib/x86_64-linux-gnu/libmkl_sequential.so
-- Known MKL Targets: MKL::mkl_sycl;MKL::mkl_intel_ilp64;MKL::mkl_core;MKL::mkl_sequential;MKL::MKL_DPCPP;MKL::MKL
-- Configuring done
-- Generating done
-- Build files have been written to: /mnt/md1/linehill/ws-chip-spv-2/builds/mklshim
Also can you confirm if you have oneAPI package(HPC toolkit) installed?
It's installed:
$ sudo apt install intel-hpckit
[sudo] password for linehill:
Reading package lists... Done
Building dependency tree... Done
Reading state information... Done
intel-hpckit is already the newest version (2023.1.0-46346).
0 upgraded, 0 newly installed, 0 to remove and 1 not upgraded.
Remember you have to run "intel/oneapi/setvars.sh" every time.
Have done this.
Shim layer needs Intel compiler not clang, can you try "-DCMAKE_CXX_COMPILER=icpx" and let me know if you still see the issue?
icpx
is not working for me:
cd builds/mklshim/ && logsave configure.log cmake \
-DCMAKE_INSTALL_PREFIX=/mnt/md1/linehill/ws-chip-spv-2/install \
-DCMAKE_CXX_COMPILER=icpx \
/mnt/md1/linehill/ws-chip-spv-2/H4I-MKLShim
-- The CXX compiler identification is IntelLLVM 2023.1.0
-- Detecting CXX compiler ABI info
-- Detecting CXX compiler ABI info - failed
-- Check for working CXX compiler: /opt/intel/oneapi/compiler/2023.1.0/linux/bin/icpx
-- Check for working CXX compiler: /opt/intel/oneapi/compiler/2023.1.0/linux/bin/icpx - broken
CMake Error at /home/linehill/.local/lib/python3.10/site-packages/cmake/data/share/cmake-3.24/Modules/CMakeTestCXXCompiler.cmake:62 (message):
The C++ compiler
"/opt/intel/oneapi/compiler/2023.1.0/linux/bin/icpx"
is not able to compile a simple test program.
It fails with the following output:
Change Dir: /mnt/md1/linehill/ws-chip-spv-2/builds/mklshim/CMakeFiles/CMakeTmp
Run Build Command(s):/usr/bin/gmake -f Makefile cmTC_20305/fast && gmake[1]: Entering directory '/mnt/md1/linehill/ws-chip-spv-2/builds/mklshim/CMakeFiles/CMakeTmp'
/usr/bin/gmake -f CMakeFiles/cmTC_20305.dir/build.make CMakeFiles/cmTC_20305.dir/build
gmake[2]: Entering directory '/mnt/md1/linehill/ws-chip-spv-2/builds/mklshim/CMakeFiles/CMakeTmp'
Building CXX object CMakeFiles/cmTC_20305.dir/testCXXCompiler.cxx.o
/opt/intel/oneapi/compiler/2023.1.0/linux/bin/icpx -MD -MT CMakeFiles/cmTC_20305.dir/testCXXCompiler.cxx.o -MF CMakeFiles/cmTC_20305.dir/testCXXCompiler.cxx.o.d -o CMakeFiles/cmTC_20305.dir/testCXXCompiler.cxx.o -c /mnt/md1/linehill/ws-chip-spv-2/builds/mklshim/CMakeFiles/CMakeTmp/testCXXCompiler.cxx
Linking CXX executable cmTC_20305
/home/linehill/.local/lib/python3.10/site-packages/cmake/data/bin/cmake -E cmake_link_script CMakeFiles/cmTC_20305.dir/link.txt --verbose=1
/opt/intel/oneapi/compiler/2023.1.0/linux/bin/icpx CMakeFiles/cmTC_20305.dir/testCXXCompiler.cxx.o -o cmTC_20305
/usr/bin/ld: cannot find crtbeginS.o: No such file or directory
/usr/bin/ld: cannot find -lstdc++: No such file or directory
icpx: error: linker command failed with exit code 1 (use -v to see invocation)
gmake[2]: *** [CMakeFiles/cmTC_20305.dir/build.make:100: cmTC_20305] Error 1
gmake[2]: Leaving directory '/mnt/md1/linehill/ws-chip-spv-2/builds/mklshim/CMakeFiles/CMakeTmp'
gmake[1]: *** [Makefile:127: cmTC_20305/fast] Error 2
gmake[1]: Leaving directory '/mnt/md1/linehill/ws-chip-spv-2/builds/mklshim/CMakeFiles/CMakeTmp'
CMake will not be able to correctly generate this project.
Call Stack (most recent call first):
CMakeLists.txt:6 (project)
-- Configuring incomplete, errors occurred!
See also "/mnt/md1/linehill/ws-chip-spv-2/builds/mklshim/CMakeFiles/CMakeOutput.log".
See also "/mnt/md1/linehill/ws-chip-spv-2/builds/mklshim/CMakeFiles/CMakeError.log".
cmake exited with status code 1
Makefile:24: recipe for target 'builds/mklshim/configure.stamp' failed
make: *** [builds/mklshim/configure.stamp] Error 1
Did you try using icpx in general? I am trying to understand if this error is specific to this project or icpx compiler in general does not work for you. If icpx/dpcpp compiler does not work for you then I would suggest to fix that.