This patch enables the usage of a host variable on the device for declare target link variables when unified memory is available.
Details
- Reviewers
ABataev caomhin grokos - Commits
- rGc5fe030c166b: [OpenMP][libomptarget] Enable usage of unified memory for declare target link…
rL362505: [OpenMP][libomptarget] Enable usage of unified memory for declare target link…
rOMP362505: [OpenMP][libomptarget] Enable usage of unified memory for declare target link…
Diff Detail
- Repository
- rOMP OpenMP
Event Timeline
- Disable device copies for target link variables under unified memory.
- Add requires init on plugin side.
Moved some of the functionality from D60223 to here since it fits better with what this patch is trying to achieve.
libomptarget/include/omptargetplugin.h | ||
---|---|---|
34–36 ↗ | (On Diff #200560) | According to init_requires_ty, this should have a return type. I think it's a good idea to have that from the beginning, this might be useful in the future without breaking compatibility. |
libomptarget/plugins/generic-elf-64bit/src/rtl.cpp | ||
73–75 ↗ | (On Diff #200560) | As before in D60223: You don't need this here and the implementation is optional, so it can go away. |
155–159 ↗ | (On Diff #200560) | likewise |
Looks mostly good, one last question about the return type of __tgt_rtl_init_requires that I noticed only now.
libomptarget/plugins/cuda/src/rtl.cpp | ||
---|---|---|
276 | This will truncate int64_t RequiresFlags to int32_t. Does it make sense to change the return type to int64_t? |
libomptarget/plugins/cuda/src/rtl.cpp | ||
---|---|---|
276 | I would suggest that we change the return type to 64 bits. In the future we may need to add extra "requires" attributes that go beyond 32 bits and then we will have to modify this interface function. Let's be proactive and avoid such situations. The same thing happened before with map types and device IDs. |
libomptarget/plugins/cuda/src/rtl.cpp | ||
---|---|---|
276 | Agreed. Just updated the patch to reflect that. |
libomptarget/plugins/exports | ||
---|---|---|
5 ↗ | (On Diff #201728) | One last question because I'm not very familiar with exporting symbols. If a plugin does not implement __tgt_rtl_init_requires (as is the case with generic-elf-64), will there be any problem with exporting the symbol? |
libomptarget/plugins/exports | ||
---|---|---|
5 ↗ | (On Diff #201728) | Supporting that method is optional so the function will not get called in that case. In the next chunk of added code you can see that the call to the init_requires() function is guarded: if (RTL->init_requires) RTL->init_requires(RTLRequiresFlags); |
libomptarget/plugins/exports | ||
---|---|---|
5 ↗ | (On Diff #201728) | My question was different. I meant, while building libomptarget.rtl.x86_64.so the linker is instructed to export a specific symbol from the exports list but this symbol is not defined in that plugin. Will the linker complain about the missing symbol or just ignore it? I suspect it's the latter, but I just want to make sure. |
libomptarget/plugins/exports | ||
---|---|---|
5 ↗ | (On Diff #201728) | I've never run into that particular issue so I suspect it is ignored. |
libomptarget/plugins/exports | ||
---|---|---|
5 ↗ | (On Diff #201728) | I commented our the method for the cuda plugin and I didn't get any link errors so it just gets ignored. |
This will truncate int64_t RequiresFlags to int32_t. Does it make sense to change the return type to int64_t?