diff --git a/openmp/libomptarget/include/Utilities.h b/openmp/libomptarget/include/Utilities.h --- a/openmp/libomptarget/include/Utilities.h +++ b/openmp/libomptarget/include/Utilities.h @@ -23,9 +23,12 @@ #include #include #include +#include #include #include #include +#include +#include #include #include @@ -226,6 +229,25 @@ return Error::success(); } +/// Return the difference (in bytes) between \p Begin and \p End. +template +ptrdiff_t getPtrDiff(const void *End, const void *Begin) { + return reinterpret_cast(End) - + reinterpret_cast(Begin); +} + +/// Return \p Ptr advanced by \p Offset bytes. +template Ty *advanceVoidPtr(Ty *Ptr, int64_t Offset) { + static_assert(std::is_void::value); + return const_cast(reinterpret_cast(Ptr) + Offset); +} + +/// Return \p Ptr aligned to \p Alignment bytes. +template Ty *alignPtr(Ty *Ptr, int64_t Alignment) { + size_t Space = std::numeric_limits::max(); + return std::align(Alignment, sizeof(char), Ptr, Space); +} + } // namespace target } // namespace omp } // namespace llvm diff --git a/openmp/libomptarget/plugins-nextgen/amdgpu/src/rtl.cpp b/openmp/libomptarget/plugins-nextgen/amdgpu/src/rtl.cpp --- a/openmp/libomptarget/plugins-nextgen/amdgpu/src/rtl.cpp +++ b/openmp/libomptarget/plugins-nextgen/amdgpu/src/rtl.cpp @@ -2232,7 +2232,7 @@ GlobalTy &ImageGlobal) override { // The global's address in AMDGPU is computed as the image begin + the ELF // symbol value. Notice we do not add the ELF section offset. - ImageGlobal.setPtr((char *)Image.getStart() + Symbol.st_value); + ImageGlobal.setPtr(advanceVoidPtr(Image.getStart(), Symbol.st_value)); // Set the global's size. ImageGlobal.setSize(Symbol.st_size); @@ -2462,7 +2462,7 @@ // Initialize implicit arguments. utils::AMDGPUImplicitArgsTy *ImplArgs = reinterpret_cast( - static_cast(AllArgs) + KernelArgsSize); + advanceVoidPtr(AllArgs, KernelArgsSize)); // Initialize the implicit arguments to zero. std::memset(ImplArgs, 0, ImplicitArgsSize); diff --git a/openmp/libomptarget/plugins-nextgen/common/PluginInterface/GlobalHandler.cpp b/openmp/libomptarget/plugins-nextgen/common/PluginInterface/GlobalHandler.cpp --- a/openmp/libomptarget/plugins-nextgen/common/PluginInterface/GlobalHandler.cpp +++ b/openmp/libomptarget/plugins-nextgen/common/PluginInterface/GlobalHandler.cpp @@ -13,6 +13,7 @@ #include "GlobalHandler.h" #include "ELFSymbols.h" #include "PluginInterface.h" +#include "Utilities.h" #include @@ -52,8 +53,8 @@ // The global's address is computed as the image begin + the ELF section // offset + the ELF symbol value. - ImageGlobal.setPtr((char *)Image.getStart() + Section.sh_offset + - Symbol.st_value); + ImageGlobal.setPtr( + advanceVoidPtr(Image.getStart(), Section.sh_offset + Symbol.st_value)); // Set the global's size. ImageGlobal.setSize(Symbol.st_size); diff --git a/openmp/libomptarget/plugins-nextgen/common/PluginInterface/JIT.cpp b/openmp/libomptarget/plugins-nextgen/common/PluginInterface/JIT.cpp --- a/openmp/libomptarget/plugins-nextgen/common/PluginInterface/JIT.cpp +++ b/openmp/libomptarget/plugins-nextgen/common/PluginInterface/JIT.cpp @@ -127,7 +127,7 @@ Expected> createModuleFromImage(__tgt_device_image *Image, LLVMContext &Context) { StringRef Data((const char *)Image->ImageStart, - (char *)Image->ImageEnd - (char *)Image->ImageStart); + target::getPtrDiff(Image->ImageEnd, Image->ImageStart)); std::unique_ptr MB = MemoryBuffer::getMemBuffer( Data, /* BufferName */ "", /* RequiresNullTerminator */ false); return createModuleFromMemoryBuffer(MB, Context); @@ -378,8 +378,7 @@ } StringRef Data(reinterpret_cast(Image->ImageStart), - reinterpret_cast(Image->ImageEnd) - - reinterpret_cast(Image->ImageStart)); + target::getPtrDiff(Image->ImageEnd, Image->ImageStart)); std::unique_ptr MB = MemoryBuffer::getMemBuffer( Data, /* BufferName */ "", /* RequiresNullTerminator */ false); if (!MB) diff --git a/openmp/libomptarget/plugins-nextgen/common/PluginInterface/PluginInterface.h b/openmp/libomptarget/plugins-nextgen/common/PluginInterface/PluginInterface.h --- a/openmp/libomptarget/plugins-nextgen/common/PluginInterface/PluginInterface.h +++ b/openmp/libomptarget/plugins-nextgen/common/PluginInterface/PluginInterface.h @@ -132,7 +132,7 @@ /// Get the image size. size_t getSize() const { - return ((char *)TgtImage->ImageEnd) - ((char *)TgtImage->ImageStart); + return getPtrDiff(TgtImage->ImageEnd, TgtImage->ImageStart); } /// Get a memory buffer reference to the whole image. @@ -469,7 +469,7 @@ --It; // Evaluate whether the buffer is contained in the pinned allocation. - return ((const char *)It->first + It->second > (const char *)Buffer); + return (advanceVoidPtr(It->first, It->second) > (const char *)Buffer); } /// Return the execution mode used for kernel \p Name.