[PATCH] D136103: OpenMP asynchronous memory copy support
Johannes Doerfert via Phabricator via cfe-commits
cfe-commits at lists.llvm.org
Thu Oct 20 18:32:32 PDT 2022
jdoerfert added a comment.
Thanks for the latest updates. The duplication is still my main concern here. See below.
================
Comment at: openmp/libomptarget/src/api.cpp:343
+static int __kmpc_target_memcpy_rect_async_helper(kmp_int32 Gtid,
+ kmp_task_t *Task) {
+ if (Task == nullptr)
----------------
My point about the "5 character difference" was that this function is basically the same as `__kmpc_target_memcpy_async_helper` and similarly `omp_target_memcpy_rect_async` is almost the same as `omp_target_memcpy_async`. Can we use common helper functions to avoid duplicating all that code twice?
(Put differently: I assume that you implemented one of these functions and then copied it and renamed a few things to get the other. Doing that should have made it obvious that there is duplication and we want to avoid duplication.)
================
Comment at: openmp/libomptarget/src/api.cpp:409
+ omp_depend_t DepObj = DepObj_List[i];
+ DepObjs[i] = *((kmp_depend_info_t *)DepObj);
+ }
----------------
That's not how vectors work. `push_back(...)`
================
Comment at: openmp/libomptarget/src/private.h:222
+ DstDimensions(DstDimensions_), SrcDimensions(SrcDimensions_),
+ DstDevice(DstDevice_), SrcDevice(SrcDevice_){};
+};
----------------
These structs need doxygen comments describing where they are used.
CHANGES SINCE LAST ACTION
https://reviews.llvm.org/D136103/new/
https://reviews.llvm.org/D136103
More information about the cfe-commits
mailing list