[Openmp-commits] [PATCH] D63106: [OpenMP][libomptarget] Add support for declare target to clause under unified memory
George Rokos via Phabricator via Openmp-commits
openmp-commits at lists.llvm.org
Fri Jun 14 12:43:41 PDT 2019
grokos accepted this revision.
grokos added a comment.
This revision is now accepted and ready to land.
LGTM
================
Comment at: libomptarget/plugins/cuda/src/rtl.cpp:452-453
if (DeviceInfo.RequiresFlags & OMP_REQ_UNIFIED_SHARED_MEMORY &&
- e->flags & OMP_DECLARE_TARGET_LINK) {
+ (e->flags & OMP_DECLARE_TARGET_LINK ||
+ e->flags == OMP_DECLARE_TARGET_TO)) {
// If unified memory is present any target link variables
----------------
gtbercea wrote:
> grokos wrote:
> > Maybe this OR is redundant; it always evaluates to true. Since the symbol we are processing has size!=0 it is a variable and variables are always either "to" or "link", there are no other possibilities (at least now, maybe in the future more attributes will be added).
> So I could remove the attribute check and just have:
>
> ```
> if (DeviceInfo.RequiresFlags & OMP_REQ_UNIFIED_SHARED_MEMORY) {..}
> ```
> Would that work?
>
> The reason I included this explicit check (even if it evaluates to true always) is that if in the future this is extended with other attributes then this check will not automatically work for that. I think this disambiguates the cases that are supported today and guard against this path being taken unintentionally.
>
Yes, that's what I thought as well. Let's leave the check there, it makes the implementation more future-proof.
Repository:
rOMP OpenMP
CHANGES SINCE LAST ACTION
https://reviews.llvm.org/D63106/new/
https://reviews.llvm.org/D63106
More information about the Openmp-commits
mailing list