[Openmp-commits] [PATCH] D68036: Tasks dependencies hash re-sizing fixed
Andrey Churbanov via Phabricator via Openmp-commits
openmp-commits at lists.llvm.org
Wed Sep 25 10:10:35 PDT 2019
AndreyChurbanov created this revision.
AndreyChurbanov added reviewers: hbae, jlpeyton, viroulep.
Herald added a reviewer: jdoerfert.
Herald added a project: OpenMP.
Herald added a subscriber: openmp-commits.
Three changes:
- nconflicts field initialized;
- formatting fix (moved declaration out of the long line);
- count conflicts in new hash as opposed to old one.
Repository:
rOMP OpenMP
https://reviews.llvm.org/D68036
Files:
runtime/src/kmp_taskdeps.cpp
Index: runtime/src/kmp_taskdeps.cpp
===================================================================
--- runtime/src/kmp_taskdeps.cpp
+++ runtime/src/kmp_taskdeps.cpp
@@ -85,19 +85,19 @@
h->nelements = current_dephash->nelements;
h->buckets = (kmp_dephash_entry **)(h + 1);
h->generation = gen;
-
+ h->nconflicts = 0;
// insert existing elements in the new table
for (size_t i = 0; i < current_dephash->size; i++) {
- kmp_dephash_entry_t *next;
- for (kmp_dephash_entry_t *entry = current_dephash->buckets[i]; entry; entry = next) {
+ kmp_dephash_entry_t *next, *entry;
+ for (entry = current_dephash->buckets[i]; entry; entry = next) {
next = entry->next_in_bucket;
// Compute the new hash using the new size, and insert the entry in
// the new bucket.
kmp_int32 new_bucket = __kmp_dephash_hash(entry->addr, h->size);
+ entry->next_in_bucket = h->buckets[new_bucket];
if (entry->next_in_bucket) {
h->nconflicts++;
}
- entry->next_in_bucket = h->buckets[new_bucket];
h->buckets[new_bucket] = entry;
}
}
-------------- next part --------------
A non-text attachment was scrubbed...
Name: D68036.221797.patch
Type: text/x-patch
Size: 1110 bytes
Desc: not available
URL: <http://lists.llvm.org/pipermail/openmp-commits/attachments/20190925/e0200815/attachment-0001.bin>
More information about the Openmp-commits
mailing list