gpt4 book ai didi

cuda文件错误 "Invalid device function"

转载 作者:行者123 更新时间:2023-12-02 11:15:47 24 4
gpt4 key购买 nike

我有一张 GPU 卡 GeForce GTX 295 和 Visual Studio 2012 以及版本 6.5 的 cuda。我运行一个简单的代码,例如

#include "stdafx.h" 
#include <stdio.h>
#include <cuda.h>
// Kernel that executes on the CUDA device
__global__ void square_array(float *a, int N)
{
int idx = blockIdx.x * blockDim.x + threadIdx.x;
if (idx<N) a[idx] = a[idx] * a[idx]; }
// main routine that executes on the host
int main(void)
{ float *a_h, *a_d; // Pointer to host & device arrays
const int N = 10; // Number of elements in arrays
size_t size = N * sizeof(float);
a_h = (float *)malloc(size); // Allocate array on host
cudaMalloc((void **) &a_d, size); // Allocate array on device // Initialize host array and copy it to CUDA device
for (int i=0; i<N; i++) a_h[i] = (float)i;
cudaMemcpy(a_d, a_h, size, cudaMemcpyHostToDevice); // Do calculation on device:
int block_size = 4;
int n_blocks = N/block_size + (N%block_size == 0 ? 0:1);
square_array <<< n_blocks, block_size >>> (a_d, N);

// Retrieve result from device and store it in host array
cudaMemcpy(a_h, a_d, sizeof(float)*N, cudaMemcpyDeviceToHost);
// Print results
for (int i=0; i<N; i++)
printf("%d %f\n", i, a_h[i]);
// Cleanup
free(a_h);
cudaFree(a_d); }

在此代码中,当我在调用内核后使用命令 cudaGetLastError (void) 时,在控制台窗口中显示错误“无效的设备功能”。我该如何摆脱它?cuda kit 6.5 的示例代码已在 Visual Studio 2012 上成功运行。在此处输入代码

最佳答案

我相信 GTX 295 的计算能力为 1.3。可能值得检查您的解决方案编译器设置,看看您是否没有使用诸如 compute_20,sm_20 之类的内容来编译解决方案。如果是这样,请尝试将这些值更改为例如compute_10,sm_10,重建并看看是否有帮助。请参阅here有关设置这些值的详细信息。

编辑:

根据 njuffa 以及 CUDA documentation CUDA 6.5 中删除了对 cc1.0 设备的支持,因此您必须使用 compute_13,sm_13

关于cuda文件错误 "Invalid device function",我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/28071814/

24 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com