具有CUDA设备功能的功能指针

时间:2016-09-05 11:45:03

标签: c++ cuda function-pointers

我想在我的Cuda C ++代码中使用函数指针,如下所示,

typedef __device__ void customFunc(const char*, uint64_t, char*, const uint64_t);

这就是我所追求的。它没有“__device__”的等价物确实很好用。

Cuda是否支持函数指针?

编辑:

我特别感兴趣的是如何使用__device__函数作为__device__函数的函数指针

1 个答案:

答案 0 :(得分:2)

在设备代码中使用设备函数指针没有任何神奇之处。它在功能和语法上与标准C ++相同。

例如:

#include <cstdio>

typedef int (*ufunc)(int args);

__device__ int f1(int x)
{
    int res = 2*x;
    printf("f1 arg = %d, res = %d\n", x, res);
    return res;
}

__device__ int f2(int x, int y, ufunc op)
{
    int res = x + op(y);
    printf("f2 arg = %d, %d, res = %d\n", x, y, res);
    return res;
}


__global__ void kernel(int *z) 
{

    int x = threadIdx.x;
    int y = blockIdx.x;
    int tid = threadIdx.x + blockDim.x * blockIdx.x;

    z[tid] = f2(x, y, &f1);
}

int main()
{
    const int nt = 4, nb = 4;
    int* a_d;
    cudaMalloc(&a_d, sizeof(float) * nt *nb);

    kernel<<<nb, nt>>>(a_d);
    cudaDeviceSynchronize();
    cudaDeviceReset();

    return 0;
}
#include <cstdio>

typedef int (*bfunc)(int args);

__device__ int f1(int x)
{
    int res = 2*x;
    printf("f1 arg = %d, res = %d\n", x, res);
    return res;
}

__device__ int f2(int x, int y, bfunc op)
{
    int res = x + f1(y);
    printf("f2 arg = %d, %d, res = %d\n", x, y, res);
    return res;
}


__global__ void kernel(int *z) 
{

    int x = threadIdx.x;
    int y = blockIdx.x;
    int tid = threadIdx.x + blockDim.x * blockIdx.x;

    z[tid] = f2(x, y, &f1);
}

int main()
{
    const int nt = 4, nb = 4;
    int* a_d;
    cudaMalloc(&a_d, sizeof(float) * nt *nb);

    kernel<<<nb, nt>>>(a_d);
    cudaDeviceSynchronize();
    cudaDeviceReset();

    return 0;
}

在这里,我们将一个简单的指针定义为一元仿函数作为一个类型,然后定义一个将该类型作为参数的设备函数。内核调用中函数指针的静态赋值在编译时处理,一切正常。如果要在运行时选择函数指针,则需要按照已提供的link中的说明进行操作。

这里要记住的重要一点是,在CUDA中,在类型定义中包含CUDA说明符(__device____constant____global__等)是不合法的。每个变量实例都有一个说明符作为其定义的一部分。