[PATCH] D136103: OpenMP asynchronous memory copy support
Johannes Doerfert via Phabricator via cfe-commits
cfe-commits at lists.llvm.org
Mon Oct 17 16:50:39 PDT 2022
jdoerfert added a comment.
First set of comments.
================
Comment at: clang/docs/ReleaseNotes.rst:253
+ `Issue 47177 <https://github.com/llvm/llvm-project/issues/47177>`_
+ `Issue 47179 <https://github.com/llvm/llvm-project/issues/47179>`_
----------------
Unrelated, probably bad diff origin.
================
Comment at: openmp/libomptarget/src/api.cpp:204
+// The helper function that calls omp_target_memcpy
+int __kmpc_target_memcpy_async_helper(kmp_int32 gtid, kmp_task_t *task) {
+ if (task == 0)
----------------
`static` also below.
================
Comment at: openmp/libomptarget/src/api.cpp:208
+
+ TargetMemcpyArgsTy* args = (TargetMemcpyArgsTy *)task->shareds;
+
----------------
LLVM codeing style, please. So here, `Args`
================
Comment at: openmp/libomptarget/src/api.cpp:211
+ if (args == 0)
+ return -1;
+
----------------
not 0 but nullptr, also lots of other places.
================
Comment at: openmp/libomptarget/src/api.cpp:217
+
+ return 0;
+}
----------------
Why ignore the return value of memcpy and return 0 here?
================
Comment at: openmp/libomptarget/src/api.cpp:233
+ if (Dst == 0 || Src == 0)
+ return 5;
+
----------------
5? Why 5?
================
Comment at: openmp/libomptarget/src/api.cpp:238
+ int errsz = sizeof(kmp_task_t);
+ int errhr = 0;
+ int gtid = __kmpc_global_thread_num(NULL);
----------------
Proper names, please. Also coding style.
================
Comment at: openmp/libomptarget/src/api.cpp:243
+ kmp_int32 flags = 0;
+ kmp_tasking_flags_t *input_flags = (kmp_tasking_flags_t *)&flags;
+ input_flags->hidden_helper = 1;
----------------
This is very suspicious. Why can't we have a `kmp_tasking_flags_t` object?
================
Comment at: openmp/libomptarget/src/api.cpp:256
+ // omp_target_memcpy(Dst, Src, Length, DstOffset, SrcOffset, DstDevice, SrcDevice);
+ __kmpc_omp_task_with_deps(NULL, gtid, ptr, Depobj_count, args_->Depobjs, 0, NULL);
+
----------------
Does this return anything? The use of Rc seems useless. Why do you access args_ for some parts and not for others? That said, where does the hidden helper need access to the dependences anyway?
================
Comment at: openmp/libomptarget/src/api.cpp:387
+ return Rc;
+}
+
----------------
This screams helper as it is literally the same code modulo 5 characters in a few places. Please refactor and run clang-format on the patch.
Repository:
rG LLVM Github Monorepo
CHANGES SINCE LAST ACTION
https://reviews.llvm.org/D136103/new/
https://reviews.llvm.org/D136103
More information about the cfe-commits
mailing list