DGPU共享内存的问题

        之前有介绍怎么用cudaIpcGetMemHandle,cudaIpcOpenMemHandle来开发共享内存,遇到了CUDA 208(cudaErrorAlreadyMapped = 208)错误。由于CUDA代码不开源,只能自己摸索分析下。

        首先cudaIpcOpenMemHandle的208错误不是必现的,程序运行一段时间,就会偶现。开始觉得是不是大量使用资源,导致资源不够用了。文档上说“If the memory handle has already been opened by the current context, the reference count on the handle is incremented by 1 and the existing device pointer is returned.”, 那就是在同一个进程,如果已经打开过一次,就会将引用加1,208可能是打开的时候有冲突。208怎么能快速重现?

static GMutex mutex;
void *func(void *ptr) {
	//const char *msg = (const char *) ptr;
  volatile shmStruct *shm = NULL;
  shm = (volatile shmStruct *)ptr;
  int frame_size = shm->data.frame_size;
  //g_mutex_lock (&mutex);
  cudaError_t err = cudaIpcOpenMemHandle(&ptr, *(cudaIpcMemHandle_t *)&shm->memHandle, cudaIpcMemLazyEnablePeerAccess);
  if(err  != 0)
    printf("err:%d\n", err);
  //g_mutex_unlock (&mutex);

  //printf("thread quit\n");
  return NULL;
}

  cudaError_t err = cudaIpcOpenMemHandle(&ptr, *(cudaIpcMemHandle_t *)&shm->memHandle, cudaIpcMemLazyEnablePeerAccess);
  if(err  != 0)
    printf("err:%d\n", err);

  printf("100 open\n");
  for(int i = 0; i < 1000; i++){
    cudaError_t err = cudaIpcOpenMemHandle(&ptr, *(cudaIpcMemHandle_t *)&shm->memHandle, cudaIpcMemLazyEnablePeerAccess);
    if(err  != 0)
      printf("err:%d\n", err);
  }

如果使用多线程反复同时调用cudaIpcOpenMemHandle,程序就能很快重现208错误。那既然同时调用有冲突,那可以加个锁,如上注释部分。加了锁之后,208错误就不能重现了。

  • 3
    点赞
  • 2
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

山西茄子

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值