最近在接触intel/llvm项目的过程中,发现sycl工具链在编译代码的过程中会出现-Wsycl-target等不必要的警告信息,这无疑会给本来就所剩不多控制台展示上增加额外展示有用信息的负担。但是,完全忽略掉warning信息又可能会导致错过其他重要的警告信息,那么如何才能“屏蔽”掉我们已知的“无用”警告信息呢?
这里举个sycl示例代码的例子,或者其他示例也可以(可以去掉sycl代码就是一个普通示例)
#include <sycl/sycl.hpp>
#include <iostream>
#include <vector>
using namespace sycl;
int main(){
std::cout<<"hello sycl"<<std::endl;
const int N = 4;
const int MAGIC_NUM = 42;
std::vector<int> vec_num = {3,4,5,6,7,8,9};
std::cout<<vec_num[0]<<std::endl;
queue q;
auto dev = q.get_device();
std::cout<<"default queue select device info : "<<&dev<<std::endl;
std::cout<<"default queue select device vendor id : "<<dev.get_info<sycl::info::device::vendor_id>()<<std::endl;
std::cout<<"default queue select device vendor name : "<<dev.get_info<sycl::info::device::name>()<<std::endl;
return 0;
}
拿上面代码来说,我们这里使用了无用变量,N,MAGIC_NUM,这导致编译的时候会提示 [-Wunused-variable],以及sycl编译工具链有关sycl-target的提示以及相关链接提示。
我这里采用sycl的clang++工具链进行编译,这里给出CMakeLists.txt,使用gcc/clang的小伙伴可以替换为指定的编译器,并修改链接信息
CMakeLists.txt
cmake_minimum_required(VERSION 2.8.12)
set(CMAKE_C_COMPILER "/home/wzy/sycl_workspace/build-cuda-2022-09-debug/bin/clang")
set(CMAKE_CXX_COMPILER "/home/wzy/sycl_workspace/build-cuda-2022-09-debug/bin/clang++")
set(CMAKE_CXX_STANDARD 17)
project(hello-sycl)
set(DPCPP_HOME "/home/wzy/sycl_workspace")
set(DPCPP_SYCL_HOME "${DPCPP_HOME}/build-cuda-2022-09-debug")
include_directories("${DPCPP_SYCL_HOME}/include/sycl")
include_directories("${DPCPP_SYCL_HOME}/include")
message(STATUS "dpcpp_home : ${DPCPP_HOME}")
message(STATUS "dpcpp_cuda_sycl_home : ${DPCPP_SYCL_HOME}")
message(STATUS "find library path : ${DPCPP_SYCL_HOME}/lib")
set(CMAKE_BUILD_RPATH "${DPCPP_SYCL_HOME}/lib;${CMAKE_BUILD_RPATH}")
message(STATUS "cmake build rpath : ${CMAKE_BUILD_RPATH}")
set(CMAKE_BUILD_TYPE "Debug")
set(CMAKE_CXX_FLAGS "-fsycl -fsycl-targets=nvptx64-nvidia-cuda")
# 忽略所有警告 -w
set(CMAKE_CXX_FLAGS_DEBUG "$ENV{CXXFLAGS} -O0 -Wall -g -ggdb -std=c++17 -w")
set(CMAKE_CXX_FLAGS_DEBUG "$ENV{CXXFLAGS} -O0 -Wall -g -ggdb -std=c++17 -Wno-sycl-target -v")
# set(CMAKE_CXX_FLAGS_RELEASE "$ENV{CXXFLAGS} -O3 -Wall -std=c++17")
link_directories("${DPCPP_SYCL_HOME}/lib")
aux_source_directory(. DIR_SRCS)
add_executable(hello-sycl ${DIR_SRCS})
target_include_directories(hello-sycl PRIVATE "${DPCPP_SYCL_HOME}/include/sycl")
target_include_directories(hello-sycl PRIVATE "${DPCPP_SYCL_HOME}/include")
target_link_libraries(hello-sycl PRIVATE sycl)
可以看到CMAKE_CXX_FLAGS_DEBUG变量设置了通过设置忽略-Wno-sycl-target 忽略了sycl-target提示的警告,还可以加上-Wno-unused-variable 忽略 未用变量的警告。讲到这里,可以看出忽略指定警告的写法为,通过警告提示中写明的警告类型,例如:-Wunused-variable。我们只需要在W后面加上no即可屏蔽盖警告。
这里补充一点,默认CMAKE_CXX_FLAGS_DEBUG中添加 -w 是忽略所有的警告。
CMAKE_CXX_FLAGS_DEBUG里面的-v参数是为了打印出更详细的编译日志信息。以下是未添加-Wno-linker-warnings 以及 -Wno-unused-variable 打印出的编译信息。
sycl代码忽略特定工具链warning警告通过添加如下配置
set(CMAKE_BUILD_TYPE "Debug")
set(CMAKE_CXX_FLAGS "-fsycl -fsycl-targets=nvptx64-nvidia-cuda")
set(CMAKE_CXX_FLAGS_DEBUG "$ENV{CXXFLAGS} -O0 -Wall -g -ggdb -std=c++17 -Wno-sycl-target -Wno-linker-warnings")
最终sycl忽略掉sycl-target以及linker-waring的警告效果如下: