【问题标题】:CUDA 3.0 and cmake and emulation modeCUDA 3.0 和 cmake 和仿真模式
【发布时间】:2010-04-20 15:38:35
【问题描述】:

我正在尝试在我的 Mac (OSX 10.6) 上使用 CUDA 和 cmake (v 2.8)。到目前为止它工作正常,我创建了一个小样本来尝试一下(见下文)。但是,当我打开仿真模式时,它无法再调用 CUDA 内核,并且我收到以下错误消息:

Cuda 错误:内核调用:设备功能无效。

我也试过手动调用nvcc编译,没有收到错误信息,所以我认为可能是cmake的问题。

我还注意到模拟模式在 CUDA 3.0 中已被弃用。为什么是这样? Nvidia 在他们的发行说明中指出,他们在 Linux 上为 VS 和 cuda-gdb 提供 Nexus。但是 OSX 呢?我在这里安装的 OSX 版本中找不到 cuda-gdb..?!

文件下方

CMakeLists.txt

cmake_minimum_required(VERSION 2.8)
project (test)

find_package(CUDA)
add_definitions(-Wall)

# Use CUDA emulator?
set(CUDA_BUILD_EMULATION ON)
set(CUDA_64_BIT_DEVICE_CODE OFF)    # Does not work on a Mac currently
set(CMAKE_C_FLAGS -m32)
set(CMAKE_CXX_FLAGS -m32)
set(CUDA_VERBOSE_BUILD ON)

include_directories("${PROJECT_BINARY_DIR}")

cuda_add_executable(test
    test.cu
)

test.cu

#include <cuda.h>
#include <stdlib.h>
#include <stdio.h>

#include "test_kernel.cu"

void checkCUDAError(const char *msg);

int main( int argc, const char** argv )
{
    int n = 3;
    float* a_h;
    a_h = (float *)malloc(sizeof(float)*n);
    float* a_d;
    cudaMalloc((void**) &a_d, sizeof(float)*n);

    hello<<<1,128>>>(a_d, n);
    checkCUDAError("kernel invocation");
    checkCUDAError("memcpy");

    free(a_h);
    cudaFree(a_d);

    return 0;
}

void checkCUDAError(const char *msg)
{
    cudaError_t err = cudaGetLastError();
    if( cudaSuccess != err)
    {
        fprintf(stderr, "Cuda error: %s: %s.\n", msg,
                cudaGetErrorString( err) );
        exit(EXIT_FAILURE);
    }
}

test_kernel.cu

#include <stdio.h>

__global__ void hello(float*a, int i)
{
    int j = i+1;
#ifdef _DEVICEEMU
    printf("Hello.\n");
#endif
}

【问题讨论】:

  • 有人吗?想在 Linux 上尝试一下,但没有装有 Linux 和 Nvidia 硬件的盒子..
  • 在Linux上试过了,同样的问题

标签: macos cmake cuda


【解决方案1】:
猜你喜欢
  • 1970-01-01
  • 1970-01-01
  • 1970-01-01
  • 1970-01-01
  • 2011-09-29
  • 2011-07-06
  • 2010-12-26
  • 2010-10-31
  • 2011-02-06
相关资源
最近更新 更多