SWDEV-381627 - Move cl_vk_amd.hpp into rocclr

Rename VK interop to ExternalMemory object, since it should handle
DX interops also

Change-Id: I536ec46d3e53ece35234a2e29030393ad411b96d


[ROCm/clr commit: 3e5803c4c0]
This commit is contained in:
German Andryeyev
2023-04-19 16:48:00 -04:00
parent a00b618051
commit b2525dfb82
6 changed files with 123 additions and 163 deletions
+15 -17
View File
@@ -25,7 +25,7 @@
#include "platform/context.hpp"
#include "platform/command.hpp"
#include "platform/memory.hpp"
#include "amdocl/cl_vk_amd.hpp"
#include "platform/external_memory.hpp"
amd::Monitor hip::hipArraySetLock{"Guards global hipArray set"};
std::unordered_set<hipArray*> hip::hipArraySet;
@@ -108,29 +108,26 @@ hipError_t hipImportExternalMemory(
HIP_RETURN(hipErrorInvalidValue);
}
size_t sizeBytes = memHandleDesc->size;
amd::Context& amdContext = *hip::getCurrentDevice()->asContext();
amd::BufferVk* pBufferVk = nullptr;
#ifdef _WIN32
pBufferVk = new (amdContext)
amd::BufferVk(amdContext, sizeBytes, memHandleDesc->handle.win32.handle,
static_cast<amd::VkObject::HandleType>(memHandleDesc->type));
auto ext_buffer = new (amdContext) amd::ExternalBuffer(amdContext, memHandleDesc->size,
memHandleDesc->handle.win32.handle,
static_cast<amd::ExternalMemory::HandleType>(memHandleDesc->type));
#else
pBufferVk = new (amdContext)
amd::BufferVk(amdContext, sizeBytes, memHandleDesc->handle.fd,
static_cast<amd::VkObject::HandleType>(memHandleDesc->type));
auto ext_buffer = new (amdContext) amd::ExternalBuffer(amdContext, memHandleDesc->size,
memHandleDesc->handle.fd,
static_cast<amd::ExternalMemory::HandleType>(memHandleDesc->type));
#endif
if (!pBufferVk) {
if (!ext_buffer) {
HIP_RETURN(hipErrorOutOfMemory);
}
if (!pBufferVk->create()) {
pBufferVk->release();
if (!ext_buffer->create()) {
ext_buffer->release();
HIP_RETURN(hipErrorOutOfMemory);
}
*extMem_out = pBufferVk;
*extMem_out = ext_buffer;
HIP_RETURN(hipSuccess);
}
@@ -145,7 +142,7 @@ hipError_t hipExternalMemoryGetMappedBuffer(
if (devPtr == nullptr || extMem == nullptr || bufferDesc == nullptr || bufferDesc->flags != 0) {
HIP_RETURN(hipErrorInvalidValue);
}
amd::BufferVk *buf = reinterpret_cast<amd::BufferVk*>(extMem);
auto buf = reinterpret_cast<amd::ExternalBuffer*>(extMem);
const device::Memory* devMem = buf->getDeviceMemory(*hip::getCurrentDevice()->devices()[0]);
if (devMem == nullptr || ((bufferDesc->offset + bufferDesc->size) > devMem->size())) {
@@ -157,18 +154,19 @@ hipError_t hipExternalMemoryGetMappedBuffer(
HIP_RETURN(hipSuccess);
}
// ================================================================================================
hipError_t hipDestroyExternalMemory(hipExternalMemory_t extMem) {
HIP_INIT_API(hipDestroyExternalMemory, extMem);
if (extMem == nullptr) {
HIP_RETURN(hipErrorInvalidValue);
}
reinterpret_cast<amd::BufferVk*>(extMem)->release();
reinterpret_cast<amd::ExternalBuffer*>(extMem)->release();
HIP_RETURN(hipSuccess);
}
// ================================================================================================
hipError_t hipImportExternalSemaphore(hipExternalSemaphore_t* extSem_out,
const hipExternalSemaphoreHandleDesc* semHandleDesc)
{
-132
View File
@@ -1,132 +0,0 @@
/* Copyright (c) 2010 - 2021 Advanced Micro Devices, Inc.
Permission is hereby granted, free of charge, to any person obtaining a copy
of this software and associated documentation files (the "Software"), to deal
in the Software without restriction, including without limitation the rights
to use, copy, modify, merge, publish, distribute, sublicense, and/or sell
copies of the Software, and to permit persons to whom the Software is
furnished to do so, subject to the following conditions:
The above copyright notice and this permission notice shall be included in
all copies or substantial portions of the Software.
THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR
IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY,
FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE
AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER
LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM,
OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN
THE SOFTWARE. */
#pragma once
#include "platform/context.hpp"
#include "platform/memory.hpp"
namespace amd
{
class VkObject : public InteropObject
{
public:
enum HandleType {
ExternalMemoryFd = 1,
ExternalMemoryWin32 = 2,
ExternalMemoryWin32KMT = 3,
};
//! GLObject constructor initializes member variables
VkObject(
amd::Os::FileDesc handle,
VkObject::HandleType handle_type
) // Initialization of member variables
{
handleVk_ = handle;
handle_type_ = handle_type;
}
virtual ~VkObject() {}
VkObject* asVkObject() { return this; }
amd::Os::FileDesc getVkSharedHandle() const { return handleVk_; }
HandleType getHandleType() const { return handle_type_; }
protected:
amd::Os::FileDesc handleVk_;
VkObject::HandleType handle_type_;
};
class BufferVk : public Buffer, public VkObject
{
protected:
//! Initializes the device memory array which is nested
// after'BufferVk' object in memory layout.
void initDeviceMemory() {
deviceMemories_ =
reinterpret_cast<DeviceMemory*>(reinterpret_cast<char*>(this) + sizeof(BufferVk));
memset(deviceMemories_, 0, context_().devices().size() * sizeof(DeviceMemory));
}
public:
//! BufferVk constructor just calls constructors of base classes
//! to pass down the parameters
BufferVk(
Context& amdContext,
size_t uiSizeInBytes,
amd::Os::FileDesc handle,
VkObject::HandleType handle_type) : // Call base classes constructors
Buffer(
amdContext,
0,
uiSizeInBytes
),
VkObject(
handle, handle_type
)
{
setInteropObj(this);
}
virtual ~BufferVk() {}
BufferVk* asBufferVk() { return this; }
};
// to be modified once image requirments are known, for now, implement like buffer
class ImageVk : public Buffer, public VkObject
{
protected:
//! Initializes the device memory array which is nested
// after'ImageVk' object in memory layout.
void initDeviceMemory() {
deviceMemories_ =
reinterpret_cast<DeviceMemory*>(reinterpret_cast<char*>(this) + sizeof(ImageVk));
memset(deviceMemories_, 0, context_().devices().size() * sizeof(DeviceMemory));
}
public:
//! ImageVk constructor just calls constructors of base classes
//! to pass down the parameters
ImageVk(
Context& amdContext,
size_t uiSizeInBytes,
amd::Os::FileDesc handle,
VkObject::HandleType handle_type): // Call base classes constructors
Buffer(
amdContext,
0,
uiSizeInBytes
),
VkObject(
handle, handle_type
)
{
setInteropObj(this);
}
virtual ~ImageVk() {}
ImageVk* asImageVk() { return this; }
};
}
+7 -5
View File
@@ -34,7 +34,7 @@
#include "platform/interop_d3d11.hpp"
#endif //_WIN32
#include "platform/interop_gl.hpp"
#include "amdocl/cl_vk_amd.hpp"
#include "platform/external_memory.hpp"
#include <string>
#include <fstream>
@@ -241,7 +241,7 @@ bool Memory::createInterop() {
amd::InteropObject* interop = owner()->getInteropObj();
assert((interop != nullptr) && "An invalid interop object is impossible!");
amd::VkObject* vkObject = interop->asVkObject();
auto ext_memory = interop->asExternalMemory();
amd::GLObject* glObject = interop->asGLObject();
#ifdef _WIN32
amd::D3D10Object* d3d10Object = interop->asD3D10Object();
@@ -351,14 +351,16 @@ bool Memory::createInterop() {
}
} else
#endif //_WIN32
if (vkObject != nullptr) {
if (ext_memory != nullptr) {
createParams = &vkRes;
vkRes.owner_ = owner();
memType = Resource::VkInterop;
vkRes.handle_ = vkObject->getVkSharedHandle();
vkRes.handle_ = ext_memory->Handle();
vkRes.type_ = Resource::InteropTypeless;
vkRes.nt_handle_ =
(vkObject->getHandleType() == amd::VkObject::ExternalMemoryWin32) ? true : false;
((ext_memory->Type() != amd::ExternalMemory::HandleType::OpaqueFd) &&
(ext_memory->Type() != amd::ExternalMemory::HandleType::OpaqueWin32Kmt) &&
(ext_memory->Type() != amd::ExternalMemory::HandleType::D3D11ResourceKmt)) ? true : false;
}
else if (glObject != nullptr) {
@@ -36,7 +36,7 @@
#include "platform/memory.hpp"
#include "platform/sampler.hpp"
#include "platform/interop_gl.hpp"
#include "amdocl/cl_vk_amd.hpp"
#include "platform/external_memory.hpp"
namespace roc {
@@ -815,10 +815,10 @@ bool Buffer::create(bool alloc_local) {
// Interop buffer
if (owner()->isInterop()) {
amd::InteropObject* interop = owner()->getInteropObj();
amd::VkObject* vkObject = interop->asVkObject();
auto ext_memory = interop->asExternalMemory();
amd::GLObject* glObject = interop->asGLObject();
if (vkObject != nullptr) {
hsa_status_t status = interopMapBuffer(vkObject->getVkSharedHandle());
if (ext_memory != nullptr) {
hsa_status_t status = interopMapBuffer(ext_memory->Handle());
if (status != HSA_STATUS_SUCCESS) return false;
return true;
} else if (glObject != nullptr) {
@@ -0,0 +1,95 @@
/* Copyright (c) 2010 - 2021 Advanced Micro Devices, Inc.
Permission is hereby granted, free of charge, to any person obtaining a copy
of this software and associated documentation files (the "Software"), to deal
in the Software without restriction, including without limitation the rights
to use, copy, modify, merge, publish, distribute, sublicense, and/or sell
copies of the Software, and to permit persons to whom the Software is
furnished to do so, subject to the following conditions:
The above copyright notice and this permission notice shall be included in
all copies or substantial portions of the Software.
THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR
IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY,
FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE
AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER
LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM,
OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN
THE SOFTWARE. */
#pragma once
#include "platform/context.hpp"
#include "platform/memory.hpp"
namespace amd
{
class ExternalMemory : public InteropObject
{
public:
enum class HandleType : uint32_t {
OpaqueFd = 1,
OpaqueWin32 = 2,
OpaqueWin32Kmt = 3,
D3D12Heap = 4,
D3D12Resource = 5,
D3D11Resource = 6,
D3D11ResourceKmt = 7
};
ExternalMemory(amd::Os::FileDesc handle, ExternalMemory::HandleType handle_type)
: handle_(handle), handle_type_(handle_type) {}
virtual ~ExternalMemory() override {}
ExternalMemory* asExternalMemory() final { return this; }
amd::Os::FileDesc Handle() const { return handle_; }
HandleType Type() const { return handle_type_; }
protected:
amd::Os::FileDesc handle_;
ExternalMemory::HandleType handle_type_;
};
class ExternalBuffer : public Buffer, public ExternalMemory
{
protected:
// Initializes device memory array, which is located after ExternalBuffer object in memory
void initDeviceMemory() {
deviceMemories_ =
reinterpret_cast<DeviceMemory*>(reinterpret_cast<char*>(this) + sizeof(ExternalBuffer));
memset(deviceMemories_, 0, context_().devices().size() * sizeof(DeviceMemory));
}
public:
ExternalBuffer(Context& amdContext, size_t size_in_bytes, amd::Os::FileDesc handle,
ExternalMemory::HandleType handle_type)
: Buffer(amdContext, 0, size_in_bytes), ExternalMemory(handle, handle_type) {
setInteropObj(this);
}
virtual ~ExternalBuffer() final {}
};
// to be modified once image requirments are known, for now, implement like buffer
class ExternalImage : public Buffer, public ExternalMemory
{
protected:
// Initializes device memory array, which is located after ExternalImage object in memory
void initDeviceMemory() {
deviceMemories_ =
reinterpret_cast<DeviceMemory*>(reinterpret_cast<char*>(this) + sizeof(ExternalImage));
memset(deviceMemories_, 0, context_().devices().size() * sizeof(DeviceMemory));
}
public:
ExternalImage(Context& amdContext, size_t size_in_bytes, amd::Os::FileDesc handle,
ExternalMemory::HandleType handle_type)
: Buffer(amdContext, 0, size_in_bytes), ExternalMemory(handle, handle_type) {
setInteropObj(this);
}
virtual ~ExternalImage() final {}
};
}
+2 -5
View File
@@ -26,8 +26,7 @@ namespace amd {
//! Forward declarations of interop classes
class GLObject;
class BufferGL;
class VkObject;
class BufferVk;
class ExternalMemory;
#ifdef _WIN32
@@ -45,9 +44,7 @@ class InteropObject {
// Static cast functions for interop objects
virtual GLObject* asGLObject() { return nullptr; }
virtual BufferGL* asBufferGL() { return nullptr; }
virtual VkObject* asVkObject() { return nullptr; }
virtual BufferVk* asBufferVk() { return nullptr; }
virtual ExternalMemory* asExternalMemory() { return nullptr; }
#ifdef _WIN32
virtual D3D10Object* asD3D10Object() { return nullptr; }