cuda 编程初探

cuda 编程可以通过 C/C++ 使用 GPU,使用 cuda 编程首先确保要有 cuda 环境,
但是使用时不能直接操作 gpu 数据,只能得到 gpu 上的一个指针,再把数据拷贝到对应位置。

具体使用

使用 cmake 构建项目可以使用宏

#ifdef USE_CUDA
#endif

添加头文件

#ifdef USE_CUDA
#include "cuda_runtime.h"
#endif

cudaMalloc 申请 GPU 内存

uint8_t *dst;
cudaMalloc((void **)&dst, bytes);

cudaMemcpy 拷贝

cudaMemcpy(gpu_data, src, bytes, cudaMemcpyHostToDevice);

cudaMemcpyHostToDevice 内存 To 显存
cudaMemcpyDeviceToHost 显存 To 内存
cudaMemcpyDeviceToDevice 内存 To 显存
cudaMemcpyHostToHost 内存 To 内存

cudaFree 释放 GPU 内存

cudaFree(dst);

返回值

assert(返回值 == cudaSuccess)
保证cudaMalloc 和 cudaMemcpy 的成功。

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值