我有一个最初按顺序执行的程序,现在我试图通过OpenMP卸载来并行化它。问题是,当我使用update子句时,视情况而定,如果我包括要移动的数组的大小,它将返回一个不正确的结果,但其他情况下它会工作。例如,该实用程序:
#pragma omp target update from(image[:bands])
与以下情况不同:
#pragma omp target update from(image)
我想做的是把整件事都移开。假设变量最初在主机中声明如下:
double* image = (double*)malloc(bands*sizeof(double));
并且在目标数据区域中调用这些更新实用程序,在该区域中,变量映像被映射如下:
#pragma omp target data map(to: image[:bands]) {
// the code
}
我想把它移到主机上去做一些在设备中无法完成的工作。注意:同样的事情也可能发生在"to“更新的语用,而不仅仅是”从“。
发布于 2022-08-26 06:52:34
我不知道为什么OpenMP的人会回答这个问题,因为答案很简单(我这么说是因为他们已经没有论坛了,这里应该是问OpenMP问题的最好地方……)。如果要复制使用指针动态分配的数据,则必须使用omp_target_memcpy()函数。
https://stackoverflow.com/questions/73357455
复制相似问题