得到cl_build_program_failure错误

时间:2015-04-07 09:36:02

标签: c++ opencl

我目前正在开发一个关于OpenCL的项目,当我尝试构建程序时遇到了一些麻烦。所以我有以下代码:

    //Read source file
    std::ifstream sourceFile("calculation_kernel.cl");
    std::string sourceCode(std::istreambuf_iterator<char>(sourceFile), (std::istreambuf_iterator<char>()));
    cl::Program::Sources source(1, std::make_pair(sourceCode.c_str(), sourceCode.length()+1));

    if (sourceFile.is_open()){
        printf("the file is open\n");
    }else{
        printf("error opening file\n");
    }

    // Make program of the source code in the context
    cl::Program program = cl::Program(context, source);

    // Build program for these specific devices
    program.build(devices);

代码编译得很好,但是当我尝试运行它时,我会得到一个clBuildProgram(-11)错误。我已经验证我的内核文件可以成功打开。 我在这里错过了什么吗?或者有没有办法调试此错误?

提前致谢!

1 个答案:

答案 0 :(得分:2)

错误代码-11对应CL_BUILD_PROGRAM_FAILURE。这表明您的内核代码无法编译,可能是由于语法错误。假设您已在OpenCL C ++绑定(#define __CL_ENABLE_EXCEPTIONS)中启用了异常,则可以使用以下内容检索构建日志:

try
{
  program.build(devices);
}
catch (cl::Error error)
{
  if (error.err() == CL_BUILD_PROGRAM_FAILURE)
  {
    // Get the build log for the first device
    std::string log = program.getBuildInfo<CL_PROGRAM_BUILD_LOG>(devices[0]);
    std::cerr << log << std::endl;
  }
  throw(error);
}