clCreateBuffer() 永远不会失败
clCreateBuffer() never fails
打算为我的算法使用所有可用的 GPU 内存,因此检索它的数量为:
clGetDeviceInfo( ..., CL_DEVICE_GLOBAL_MEM_SIZE, ... );
这是 536543232 字节,然后使用 GPU 将其分配给:
clCreateBuffer( gpuContext, CL_MEM_READ_WRITE, 536543232, NULL, & errcode_ret );
想知道它为什么有效,如果尝试分配更多内存是否会失败?尝试了 100 场演出,它仍然有效!
clCreateBuffer( gpuContext, CL_MEM_READ_WRITE, 100000000000, NULL, & errcode_ret );
所以问题是为什么它适用于指定的内存量?
如果 OpenCL 平台有延迟内存分配(几乎每个平台都这样做(,我可能会发生这种情况。我想一些 OpenCL 平台只是检查您请求的内容是否可以在 clCreateBuffer
上分配,而您的平台可能不会。您可能会在实际使用缓冲区的第一个 OpenCL 函数(如clEnqueueWriteBuffer()
等(上收到错误。你们的 OpenCL 平台是什么?
相关文章:
- 如果没有malloc,链表实现将失败
- 模板参数替换失败,并且未完成隐式转换
- 具有默认模板参数的多态类的模板推导失败
- 视图中的参数推导失败:take_while
- 链接到自行创建的dll失败
- 带有特殊路径部分的"std::filesystem::weakly_canonical"失败
- GetShortPathName在网络驱动器上使用中文文件夹时失败
- gcc和c++17的过载解析失败
- 为什么使用 P/Invoke 调用 dll 时,某些计算机中的 LoadLibrary 失败?
- 在WSL:configure_file上对config_file的每次调用都失败:配置文件时出现问题
- 使用 GCC 卸载的 OpenMP 卸载失败,并出现"Ptx assembly aborted due to errors"
- 使用cmake从源代码构建MySQL连接器/C++失败(与以前的声明冲突)
- 链接阶段在Ubuntu上失败,但在MacOS上失败
- 从父数组测试用例构造二叉树失败
- LibGit2 SSH身份验证失败
- 如何让LLDB在成功时退出,在失败时等待
- VS2017,C++包含目录与附加包含目录,子文件夹包含失败-但为什么
- 生成MRPT库时cmake配置失败
- clCreateBuffer() 永远不会失败
- Googletest 在 bazel test 中永远不会失败(在它应该失败的地方),但与 cmake & clion 一起工作