为什么OpenCL无法链接?

如何解决为什么OpenCL无法链接?

这让我发疯。似乎每个人和他们的母亲都在Internet上的某个地方发布了有关此问题的论坛帖子,并获得了完全相同的解决方案,对我不起作用...

这是我从Internet复制的一个非常基本的“ hello world”类型的示例。我将其命名为cltest.c。

#include <stdio.h>
#include <stdlib.h>

#ifdef __APPLE__
    #include <OpenCL/opencl.h>
#else
    #include <CL/cl.h>
#endif

#define MAX_SOURCE_SIZE (0x100000)

int main()
{
    const int LIST_SIZE = 1024;
    int* a = (int*) malloc(sizeof(int) * LIST_SIZE);
    int* b = (int*) malloc(sizeof(int) * LIST_SIZE);

    int i;  
    for (i = 0; i < LIST_SIZE; i++)
    {
        a[i] = i;
        b[i] = LIST_SIZE - i;   
    }
    
    //load the kernel source code into the array source_str
    FILE* fp;
    char* source_str;
    size_t source_size;
    
    fp = fopen("gpu.cl","r");
    if (!fp)
    {
        printf("Failed to load kernel");
        exit(1);
    }
    source_str = (char *)malloc(MAX_SOURCE_SIZE);
    source_size = fread(source_str,1,MAX_SOURCE_SIZE,fp);
    fclose(fp);
    
    //Get platform and device information
    cl_platform_id platform_id = NULL;
    cl_device_id device_id = NULL;
    cl_uint ret_num_devices;
    cl_uint ret_num_platforms;
    cl_int ret = clGetPlatformIDs(1,&platform_id,&ret_num_platforms);
    ret = clGetDeviceIDs(platform_id,CL_DEVICE_TYPE_GPU,&device_id,&ret_num_devices);
    
    //create an OpenCL context
    cl_context context = clCreateContext(NULL,NULL,&ret);
    
    //create a command queue
    cl_command_queue command_queue = clCreateCommandQueue(context,device_id,&ret);
    
    //create memory buffers on the device for each vector
    cl_mem a_mem_obj = clCreateBuffer(context,CL_MEM_READ_ONLY,LIST_SIZE * sizeof(int),&ret);
    cl_mem b_mem_obj = clCreateBuffer(context,&ret);
    cl_mem c_mem_obj = clCreateBuffer(context,CL_MEM_WRITE_ONLY,&ret);
    
    //copy a and b to their respective memory buffers
    ret = clEnqueueWriteBuffer(command_queue,a_mem_obj,CL_TRUE,a,NULL);
    ret = clEnqueueWriteBuffer(command_queue,b_mem_obj,b,NULL);
    
    //create a program from the kernel source
    cl_program program = clCreateProgramWithSource(context,(const char **)&source_str,(const size_t *)&source_size,&ret);
    
    //build the program
    ret = clBuildProgram(program,NULL);
    
    //create the OpenCL kernel
    cl_kernel kernel = clCreateKernel(program,"vector_add",&ret);
    
    //set the arguments of the kernel
    ret = clSetKernelArg(kernel,sizeof(cl_mem),(void *)&a_mem_obj);
    ret = clSetKernelArg(kernel,(void *)&b_mem_obj);
    ret = clSetKernelArg(kernel,2,(void *)&c_mem_obj);
    
    //execute the OpenCL kernel on the list
    size_t global_item_size = LIST_SIZE;
    size_t local_item_size = 64;
    ret = clEnqueueNDRangeKernel(command_queue,kernel,&global_item_size,&local_item_size,NULL);
    
    //read memory buffer c on the device to the local variable c
    int* c = (int *)malloc(sizeof(int) * LIST_SIZE);
    ret = clEnqueueReadBuffer(command_queue,c_mem_obj,c,NULL);
    
    //display the result to the screen
    for (i = 0; i < LIST_SIZE; i++)
    {
        printf("%d + %d = %d\n",a[i],b[i],c[i]);
    }
    
    //clean up
    ret = clFlush(command_queue);
    ret = clFinish(command_queue);
    ret = clReleaseKernel(kernel);
    ret = clReleaseProgram(program);
    ret = clReleaseMemObject(a_mem_obj);
    ret = clReleaseMemObject(b_mem_obj);
    ret = clReleaseMemObject(c_mem_obj);
    ret = clReleaseContext(context);
    free(a);
    free(b);
    free(c);
    return 0;
}

要构建,我正在使用命令

gcc -v -Wl,--verbose -H cltest.c -I"C:\Program Files\NVIDIA GPU Computing Toolkit\CUDA\v11.0\include" -L"C:\Program Files\NVIDIA GPU Computing Toolkit\CUDA\v11.0\lib\x64" -lOpenCL

这会生成1021行消息,但以下是(我认为)相关的消息:

(...)
#include "..." search starts here:
#include <...> search starts here:
 C:\Program Files\NVIDIA GPU Computing Toolkit\CUDA\v11.0\include
 c:\mingw\bin\../lib/gcc/mingw32/9.2.0/include
 c:\mingw\bin\../lib/gcc/mingw32/9.2.0/../../../../include
 c:\mingw\bin\../lib/gcc/mingw32/9.2.0/include-fixed
End of search list.
GNU C17 (MinGW.org GCC Build-20200227-1) version 9.2.0 (mingw32)
        compiled by GNU C version 9.2.0,GMP version 6.1.2,MPFR version 4.0.2,MPC version 1.1.0,isl version isl-0.21-GMP
(...)
. C:\Program Files\NVIDIA GPU Computing Toolkit\CUDA\v11.0\include/CL/cl.h
.. C:\Program Files\NVIDIA GPU Computing Toolkit\CUDA\v11.0\include/CL/cl_platform.h
... c:\mingw\lib\gcc\mingw32\9.2.0\include\stdint.h
.... c:\mingw\include\stdint.h
..... c:\mingw\lib\gcc\mingw32\9.2.0\include\stddef.h
... c:\mingw\lib\gcc\mingw32\9.2.0\include\stddef.h
(...)
C:\Users\Devsman\AppData\Local\Temp\ccwXijlf.o
attempt to open C:\Program Files\NVIDIA GPU Computing Toolkit\CUDA\v11.0\lib\x64/libOpenCL.dll.a failed
attempt to open C:\Program Files\NVIDIA GPU Computing Toolkit\CUDA\v11.0\lib\x64/OpenCL.dll.a failed
attempt to open C:\Program Files\NVIDIA GPU Computing Toolkit\CUDA\v11.0\lib\x64/libOpenCL.a failed
attempt to open C:\Program Files\NVIDIA GPU Computing Toolkit\CUDA\v11.0\lib\x64/OpenCL.lib succeeded
(...)
c:/mingw/bin/../lib/gcc/mingw32/9.2.0/../../../../mingw32/bin/ld.exe: C:\Users\Devsman\AppData\Local\Temp\ccwXijlf.o:cltest.c:(.text+0x11b): undefined reference to `clGetPlatformIDs@12'
c:/mingw/bin/../lib/gcc/mingw32/9.2.0/../../../../mingw32/bin/ld.exe: C:\Users\Devsman\AppData\Local\Temp\ccwXijlf.o:cltest.c:(.text+0x152): undefined reference to `clGetDeviceIDs@24'
c:/mingw/bin/../lib/gcc/mingw32/9.2.0/../../../../mingw32/bin/ld.exe: C:\Users\Devsman\AppData\Local\Temp\ccwXijlf.o:cltest.c:(.text+0x18a): undefined reference to `clCreateContext@24'
c:/mingw/bin/../lib/gcc/mingw32/9.2.0/../../../../mingw32/bin/ld.exe: C:\Users\Devsman\AppData\Local\Temp\ccwXijlf.o:cltest.c:(.text+0x1b9): undefined reference to `clCreateCommandQueue@20'
c:/mingw/bin/../lib/gcc/mingw32/9.2.0/../../../../mingw32/bin/ld.exe: C:\Users\Devsman\AppData\Local\Temp\ccwXijlf.o:cltest.c:(.text+0x1f7): undefined reference to `clCreateBuffer@24'
c:/mingw/bin/../lib/gcc/mingw32/9.2.0/../../../../mingw32/bin/ld.exe: C:\Users\Devsman\AppData\Local\Temp\ccwXijlf.o:cltest.c:(.text+0x235): undefined reference to `clCreateBuffer@24'
c:/mingw/bin/../lib/gcc/mingw32/9.2.0/../../../../mingw32/bin/ld.exe: C:\Users\Devsman\AppData\Local\Temp\ccwXijlf.o:cltest.c:(.text+0x273): undefined reference to `clCreateBuffer@24'
c:/mingw/bin/../lib/gcc/mingw32/9.2.0/../../../../mingw32/bin/ld.exe: C:\Users\Devsman\AppData\Local\Temp\ccwXijlf.o:cltest.c:(.text+0x2c8): undefined reference to `clEnqueueWriteBuffer@36'
c:/mingw/bin/../lib/gcc/mingw32/9.2.0/../../../../mingw32/bin/ld.exe: C:\Users\Devsman\AppData\Local\Temp\ccwXijlf.o:cltest.c:(.text+0x31d): undefined reference to `clEnqueueWriteBuffer@36'
c:/mingw/bin/../lib/gcc/mingw32/9.2.0/../../../../mingw32/bin/ld.exe: C:\Users\Devsman\AppData\Local\Temp\ccwXijlf.o:cltest.c:(.text+0x34b): undefined reference to `clCreateProgramWithSource@20'
c:/mingw/bin/../lib/gcc/mingw32/9.2.0/../../../../mingw32/bin/ld.exe: C:\Users\Devsman\AppData\Local\Temp\ccwXijlf.o:cltest.c:(.text+0x383): undefined reference to `clBuildProgram@24'
c:/mingw/bin/../lib/gcc/mingw32/9.2.0/../../../../mingw32/bin/ld.exe: C:\Users\Devsman\AppData\Local\Temp\ccwXijlf.o:cltest.c:(.text+0x3a3): undefined reference to `clCreateKernel@12'
c:/mingw/bin/../lib/gcc/mingw32/9.2.0/../../../../mingw32/bin/ld.exe: C:\Users\Devsman\AppData\Local\Temp\ccwXijlf.o:cltest.c:(.text+0x3cb): undefined reference to `clSetKernelArg@16'
c:/mingw/bin/../lib/gcc/mingw32/9.2.0/../../../../mingw32/bin/ld.exe: C:\Users\Devsman\AppData\Local\Temp\ccwXijlf.o:cltest.c:(.text+0x3f3): undefined reference to `clSetKernelArg@16'
c:/mingw/bin/../lib/gcc/mingw32/9.2.0/../../../../mingw32/bin/ld.exe: C:\Users\Devsman\AppData\Local\Temp\ccwXijlf.o:cltest.c:(.text+0x41b): undefined reference to `clSetKernelArg@16'
c:/mingw/bin/../lib/gcc/mingw32/9.2.0/../../../../mingw32/bin/ld.exe: C:\Users\Devsman\AppData\Local\Temp\ccwXijlf.o:cltest.c:(.text+0x476): undefined reference to `clEnqueueNDRangeKernel@36'
c:/mingw/bin/../lib/gcc/mingw32/9.2.0/../../../../mingw32/bin/ld.exe: C:\Users\Devsman\AppData\Local\Temp\ccwXijlf.o:cltest.c:(.text+0x4dc): undefined reference to `clEnqueueReadBuffer@36'
c:/mingw/bin/../lib/gcc/mingw32/9.2.0/../../../../mingw32/bin/ld.exe: C:\Users\Devsman\AppData\Local\Temp\ccwXijlf.o:cltest.c:(.text+0x54d): undefined reference to `clFlush@4'
c:/mingw/bin/../lib/gcc/mingw32/9.2.0/../../../../mingw32/bin/ld.exe: C:\Users\Devsman\AppData\Local\Temp\ccwXijlf.o:cltest.c:(.text+0x55e): undefined reference to `clFinish@4'
c:/mingw/bin/../lib/gcc/mingw32/9.2.0/../../../../mingw32/bin/ld.exe: C:\Users\Devsman\AppData\Local\Temp\ccwXijlf.o:cltest.c:(.text+0x56f): undefined reference to `clReleaseKernel@4'
c:/mingw/bin/../lib/gcc/mingw32/9.2.0/../../../../mingw32/bin/ld.exe: C:\Users\Devsman\AppData\Local\Temp\ccwXijlf.o:cltest.c:(.text+0x580): undefined reference to `clReleaseProgram@4'
c:/mingw/bin/../lib/gcc/mingw32/9.2.0/../../../../mingw32/bin/ld.exe: C:\Users\Devsman\AppData\Local\Temp\ccwXijlf.o:cltest.c:(.text+0x591): undefined reference to `clReleaseMemObject@4'
c:/mingw/bin/../lib/gcc/mingw32/9.2.0/../../../../mingw32/bin/ld.exe: C:\Users\Devsman\AppData\Local\Temp\ccwXijlf.o:cltest.c:(.text+0x5a2): undefined reference to `clReleaseMemObject@4'
c:/mingw/bin/../lib/gcc/mingw32/9.2.0/../../../../mingw32/bin/ld.exe: C:\Users\Devsman\AppData\Local\Temp\ccwXijlf.o:cltest.c:(.text+0x5b3): undefined reference to `clReleaseMemObject@4'
c:/mingw/bin/../lib/gcc/mingw32/9.2.0/../../../../mingw32/bin/ld.exe: C:\Users\Devsman\AppData\Local\Temp\ccwXijlf.o:cltest.c:(.text+0x5c4): undefined reference to `clReleaseContext@4'
c:/mingw/bin/../lib/gcc/mingw32/9.2.0/../../../../mingw32/bin/ld.exe: link errors found,deleting executable `a.exe'
(...)

我已经多次更改了每个参数的顺序,已经对指定文件的目录进行了两次,三重和四重检查,我取出了-o标志,以防万一,我尝试编译cltest.c到一个对象,然后在一个单独的调用中将它们链接起来,我就没主意了!希望有一个简单的修复程序是如此基本/显而易见,我想不起来了。预先感谢。

版权声明:本文内容由互联网用户自发贡献,该文观点与技术仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 dio@foxmail.com 举报,一经查实,本站将立刻删除。

相关推荐


使用本地python环境可以成功执行 import pandas as pd import matplotlib.pyplot as plt # 设置字体 plt.rcParams[&#39;font.sans-serif&#39;] = [&#39;SimHei&#39;] # 能正确显示负号 p
错误1:Request method ‘DELETE‘ not supported 错误还原:controller层有一个接口,访问该接口时报错:Request method ‘DELETE‘ not supported 错误原因:没有接收到前端传入的参数,修改为如下 参考 错误2:cannot r
错误1:启动docker镜像时报错:Error response from daemon: driver failed programming external connectivity on endpoint quirky_allen 解决方法:重启docker -&gt; systemctl r
错误1:private field ‘xxx‘ is never assigned 按Altʾnter快捷键,选择第2项 参考:https://blog.csdn.net/shi_hong_fei_hei/article/details/88814070 错误2:启动时报错,不能找到主启动类 #
报错如下,通过源不能下载,最后警告pip需升级版本 Requirement already satisfied: pip in c:\users\ychen\appdata\local\programs\python\python310\lib\site-packages (22.0.4) Coll
错误1:maven打包报错 错误还原:使用maven打包项目时报错如下 [ERROR] Failed to execute goal org.apache.maven.plugins:maven-resources-plugin:3.2.0:resources (default-resources)
错误1:服务调用时报错 服务消费者模块assess通过openFeign调用服务提供者模块hires 如下为服务提供者模块hires的控制层接口 @RestController @RequestMapping(&quot;/hires&quot;) public class FeignControl
错误1:运行项目后报如下错误 解决方案 报错2:Failed to execute goal org.apache.maven.plugins:maven-compiler-plugin:3.8.1:compile (default-compile) on project sb 解决方案:在pom.
参考 错误原因 过滤器或拦截器在生效时,redisTemplate还没有注入 解决方案:在注入容器时就生效 @Component //项目运行时就注入Spring容器 public class RedisBean { @Resource private RedisTemplate&lt;String
使用vite构建项目报错 C:\Users\ychen\work&gt;npm init @vitejs/app @vitejs/create-app is deprecated, use npm init vite instead C:\Users\ychen\AppData\Local\npm-
参考1 参考2 解决方案 # 点击安装源 协议选择 http:// 路径填写 mirrors.aliyun.com/centos/8.3.2011/BaseOS/x86_64/os URL类型 软件库URL 其他路径 # 版本 7 mirrors.aliyun.com/centos/7/os/x86
报错1 [root@slave1 data_mocker]# kafka-console-consumer.sh --bootstrap-server slave1:9092 --topic topic_db [2023-12-19 18:31:12,770] WARN [Consumer clie
错误1 # 重写数据 hive (edu)&gt; insert overwrite table dwd_trade_cart_add_inc &gt; select data.id, &gt; data.user_id, &gt; data.course_id, &gt; date_format(
错误1 hive (edu)&gt; insert into huanhuan values(1,&#39;haoge&#39;); Query ID = root_20240110071417_fe1517ad-3607-41f4-bdcf-d00b98ac443e Total jobs = 1
报错1:执行到如下就不执行了,没有显示Successfully registered new MBean. [root@slave1 bin]# /usr/local/software/flume-1.9.0/bin/flume-ng agent -n a1 -c /usr/local/softwa
虚拟及没有启动任何服务器查看jps会显示jps,如果没有显示任何东西 [root@slave2 ~]# jps 9647 Jps 解决方案 # 进入/tmp查看 [root@slave1 dfs]# cd /tmp [root@slave1 tmp]# ll 总用量 48 drwxr-xr-x. 2
报错1 hive&gt; show databases; OK Failed with exception java.io.IOException:java.lang.RuntimeException: Error in configuring object Time taken: 0.474 se
报错1 [root@localhost ~]# vim -bash: vim: 未找到命令 安装vim yum -y install vim* # 查看是否安装成功 [root@hadoop01 hadoop]# rpm -qa |grep vim vim-X11-7.4.629-8.el7_9.x
修改hadoop配置 vi /usr/local/software/hadoop-2.9.2/etc/hadoop/yarn-site.xml # 添加如下 &lt;configuration&gt; &lt;property&gt; &lt;name&gt;yarn.nodemanager.res