0

我正在尝试加载我用 clang+llvm 6.0.1 创建的 SPIR 二进制文件。

创建了几个不同的文件:

clang -target spir-unknown-unknown -cl-std=CL1.2 -c -emit-llvm -Xclang -finclude-default-header OCLkernel.cl  
clang -target amdgcn-amd-amdhsa -cl-std=CL1.2 -c -emit-llvm -Xclang -finclude-default-header OCLkernel.cl  
clang -cc1 -emit-llvm-bc -triple spir-unknown-unknown -cl-std=CL1.2 -include "include\opencl-c.h" OCLkernel.cl

这一切都发生在 Windows 上,安装了 AMD APP SDK 3 和 Adrenalin 18.6.1 驱动程序。

在此之后,我尝试从二进制文件创建一个程序:

clCreateProgramWithBinary(context, 1, &device, &programSrcSize, (const unsigned char**)&programSrc, 0 , &status)

这一切都很好,我在这里没有任何错误,但是我在之后尝试构建它时会这样做:

clBuildProgram(program, 1, &device, " –x spir -spir-std=1.2", NULL, NULL);

我得到的错误是:

调用 clBuildProgram 时出现错误 CL_INVALID_COMPILER_OPTIONS

我也试过没有“-x spir ...”的东西,但后来我得到了:

错误:无效值(生产者:'LLVM6.0.1' 读者:'LLVM 3.9.0svn')

编辑:

CL_DEVICE_NAME: gfx900
CL_DEVICE_VERSION: OpenCL 2.0 AMD-APP (2580.6)
CL_DEVICE_OPENCL_C_VERSION: OpenCL C 2.0
CL_DRIVER_VERSION: 2580.6 (PAL,HSAIL)
CL_DEVICE_SPIR_VERSIONS: 1.2

运行clCreateProgramWithBinary后,我使用 clGetProgramBuildInfo 查询设备并得到:CL_PROGRAM_BINARY_TYPE
= [CL_PROGRAM_BINARY_TYPE_INTERMEDIATE]

所以这应该意味着二进制文件正在被识别,否则我猜它会返回 CL_PROGRAM_BINARY_TYPE_NONE

编辑2:

我认为 clang 并没有创建一个“好的”二进制文件,但是如何创建它呢?

感谢你的帮助!

4

1 回答 1

1

不幸的是,对 SPIR 的支持已从 AMD 驱动程序中默默删除,请参阅 AMD 社区论坛的此线程中的 dipak 答案:

https://community.amd.com/thread/232093

关于您的第二个问题:通用 clang+LLVM(不是 AMD 调整并包含在其专有驱动程序中的秘密版本)仍然无法生成与通用 Windows AMD 驱动程序兼容的二进制文件,但是对于 Linux 是可能的:所有新的 AMD 的 ROCm,AMD涵盖了 PAL 和 Mesa 3D 运行时

为什么 LLVM AMDGPU 后端开发人员不优先考虑为 Windows 驱动程序生成二进制文件的任务对我来说是个谜,因为有几个 GCN 汇编程序项目通过 Windows OpenCL 接口提供这样的功能,仅举几例:CLRadeonExtenderASM4GCN , HepPas等。此外,我知道一个未记录的 clang+LLVM 分支(如其作者所述)产生这样的 OpenCL 二进制文件!“天地间有更多的东西,霍拉旭,比你的哲学所梦想的还要多。”

于 2019-04-06T09:25:37.080 回答