在caffe源代码(分支opencl)中,有时我可以看到类似这些(例如在src / caffe / layers / base_conv_layer.cpp第400行):
void func(cl_mem a, ...)
{...}
void func2(float* a, ...)
{
...
func( (cl_mem) a, ...);
...
}
我觉得这很奇怪,所以我用Google搜索了一下,但对此一无所知。
然后我写了一个简单的测试代码来弄清楚发生了什么,但我发现这种转换毫无意义:
std::cout << long((void*)a) << " " << long((void*)(cl_mem(a))) << std::endl;
他们的价值是一样的!
所以我的问题是为什么这个转换在caffe opencl中没有问题? 这次转换发生了什么?
答案 0 :(得分:0)
如果您查看类SyncedMemory
(在include/caffe/syncedmem.hpp
和src/caffe/syncedmem.cpp
中),您会发现内存缓冲区首先由clCreateBuffer
创建,并且句柄存储为一个cl_mem
个对象。然后,在调用DType*
或gpu_data()
时,将句柄转换为mutable_gpu_data()
类型。因此,它可以强制转换为cl_mem
类型,因为它首先是cl_mem
对象。