【发布时间】:2020-04-10 10:35:08
【问题描述】:
我是 CUDA 的新手。 我正在尝试编写一个应用程序,我从另一个内核函数调用一个内核函数。但我在构建应用程序时收到错误“从设备或全局函数启动内核需要单独的编译模式”。 这是我的完整代码。任何帮助将不胜感激。
#include<iostream>
#include<curand.h>
#include<cuda.h>
#include <curand_kernel.h>
#include <stdlib.h>
#include <stdio.h>
using namespace std;
__device__ int *vectorData;
__device__ void initializeArray(int elementCount)
{
for (int i = 0; i < elementCount; i++)
{
vectorData[i] = 1;
}
}
__global__ void AddOneToEachElement(int elementCount)
{
for (int i = 0; i < elementCount; i++)
{
vectorData[i] = vectorData[i]+1;
}
}
__global__ void addKernel(int *numberOfElements)
{
vectorData = (int*)malloc(sizeof(int));
initializeArray(*numberOfElements);
int gridSize = ceil((*numberOfElements) / 1024) + 1;
AddOneToEachElement << <gridSize, 1024 >> > (*numberOfElements);
cudaDeviceSynchronize();
free(vectorData);
}
int main()
{
int numberOfElements = 1;
int *device_numberOfElements;
cudaMalloc((int**)&device_numberOfElements, sizeof(int));
cout << "Enter the Number of elements" << endl;
cin >> numberOfElements;
cudaMemcpy(device_numberOfElements, &(numberOfElements), sizeof(int), cudaMemcpyHostToDevice);
addKernel << <1, 1 >> > (device_numberOfElements);
cudaFree(device_numberOfElements);
return 0;
}
【问题讨论】:
-
使用以下链接orangeowlsolutions.com/archives/1965中提供的信息解决了问题
标签: c++ visual-studio compilation cuda kernel