SWDEV-558855 - Enable Interop Map Buffer on Windows (#1748)

* Support Windows HANDLE in interop_map_buffer

* Refactored Windows HANDLE in interop_map_buffer

* ROCr System Dependent Handle Type

* Fix for ROCr Handle Conversion Bug

* Remove Windows Header
Cette révision appartient à :
Jin Jung
2025-11-07 12:47:01 -08:00
révisé par GitHub
Parent 2006a411e5
révision 291ff6c468
9 fichiers modifiés avec 32 ajouts et 14 suppressions
-5
Voir le fichier
@@ -206,12 +206,7 @@ hsa_status_t Memory::interopMapBuffer(amd::Os::FileDesc fdn) {
size_t size;
size_t metadata_size = 0;
void* metadata;
#if IS_WINDOWS
int fd = 0;
assert(!"Unimplemented");
#else
auto fd = fdn;
#endif
hsa_status_t status = Hsa::interop_map_buffer(1, &agent, fd, 0, &size, &interop_deviceMemory_,
&metadata_size, (const void**)&metadata);
ClPrint(amd::LOG_DEBUG, amd::LOG_MEM, "Map Interop memory %p, size 0x%zx", interop_deviceMemory_,
+2 -1
Voir le fichier
@@ -386,7 +386,8 @@ class Hsa : public amd::AllStatic {
return ROCR_DYN(hsa_amd_memory_unlock)(host_ptr);
}
static hsa_status_t interop_map_buffer(uint32_t num_agents, hsa_agent_t* agents,
int interop_handle, uint32_t flags, size_t* size,
amd::Os::FileDesc interop_handle,
uint32_t flags, size_t* size,
void** ptr, size_t* metadata_size, const void** metadata) {
return ROCR_DYN(hsa_amd_interop_map_buffer)(num_agents, agents, interop_handle, flags, size,
ptr, metadata_size, metadata);
+1 -1
Voir le fichier
@@ -1094,7 +1094,7 @@ hsa_status_t HSA_API
// Mirrors Amd Extension Apis
hsa_status_t HSA_API hsa_amd_interop_map_buffer(uint32_t num_agents,
hsa_agent_t* agents,
int interop_handle,
hsa_handle_t interop_handle,
uint32_t flags,
size_t* size,
void** ptr,
+1 -1
Voir le fichier
@@ -219,7 +219,7 @@ hsa_status_t
// Mirrors Amd Extension Apis
hsa_status_t hsa_amd_interop_map_buffer(uint32_t num_agents,
hsa_agent_t* agents,
int interop_handle,
hsa_handle_t interop_handle,
uint32_t flags,
size_t* size,
void** ptr,
+2 -1
Voir le fichier
@@ -346,7 +346,8 @@ class Runtime {
hsa_amd_signal_handler handler, void* arg);
hsa_status_t InteropMap(uint32_t num_agents, Agent** agents,
int interop_handle, uint32_t flags, size_t* size,
hsa_handle_t interop_handle,
uint32_t flags, size_t* size,
void** ptr, size_t* metadata_size,
const void** metadata);
+2 -1
Voir le fichier
@@ -993,7 +993,8 @@ hsa_status_t hsa_amd_agent_memory_pool_get_info(
}
hsa_status_t hsa_amd_interop_map_buffer(uint32_t num_agents,
hsa_agent_t* agents, int interop_handle,
hsa_agent_t* agents,
hsa_handle_t interop_handle,
uint32_t flags, size_t* size,
void** ptr, size_t* metadata_size,
const void** metadata) {
+14 -3
Voir le fichier
@@ -889,7 +889,8 @@ hsa_status_t Runtime::SetAsyncSignalHandler(hsa_signal_t signal,
}
hsa_status_t Runtime::InteropMap(uint32_t num_agents, Agent** agents,
int interop_handle, uint32_t flags,
hsa_handle_t interop_handle,
uint32_t flags,
size_t* size, void** ptr,
size_t* metadata_size, const void** metadata) {
static const int tinyArraySize=8;
@@ -897,6 +898,16 @@ hsa_status_t Runtime::InteropMap(uint32_t num_agents, Agent** agents,
HSAuint32 short_nodes[tinyArraySize];
HSAuint32* nodes = short_nodes;
static_assert(sizeof(HSAint64) >= sizeof(interop_handle),
"HSAint64 too small for interop_handle");
HSAint64 resource_handle =
#ifdef _WIN32
static_cast<HSAint64>(reinterpret_cast<uintptr_t>(interop_handle));
#else
static_cast<HSAint64>(interop_handle);
#endif
if (num_agents > tinyArraySize) {
nodes = new HSAuint32[num_agents];
if (nodes == NULL) return HSA_STATUS_ERROR_OUT_OF_RESOURCES;
@@ -912,7 +923,7 @@ hsa_status_t Runtime::InteropMap(uint32_t num_agents, Agent** agents,
agents[i]->GetInfo(static_cast<hsa_agent_info_t>(HSA_AMD_AGENT_INFO_DRIVER_NODE_ID), &nodes[i]);
}
if (HSAKMT_CALL(hsaKmtRegisterGraphicsHandleToNodes(interop_handle, &info, num_agents,
if (HSAKMT_CALL(hsaKmtRegisterGraphicsHandleToNodes(resource_handle, &info, num_agents,
nodes)) != HSAKMT_STATUS_SUCCESS)
return HSA_STATUS_ERROR;
@@ -1416,7 +1427,7 @@ hsa_status_t Runtime::IPCCreate(void* ptr, size_t len, hsa_amd_ipc_memory_t* han
if (agent->device_type() == Agent::kAmdGpuDevice) {
#if defined(__linux__)
AMD::GpuAgent* agent_ = reinterpret_cast<AMD::GpuAgent*>(agent);
AMD::GpuAgent* agent_ = reinterpret_cast<AMD::GpuAgent*>(agent);
amdgpu_bo_import_result res;
srand(static_cast<uint32_t>(std::chrono::high_resolution_clock::now().time_since_epoch().count()));
+9
Voir le fichier
@@ -5682,6 +5682,15 @@ typedef enum {
HSA_CODE_SYMBOL_INFO_KERNEL_WAVEFRONT_SIZE = 19
} hsa_code_symbol_info_t;
/**
* @brief System dependent handle type.
*/
#if defined(_WIN32)
typedef void* hsa_handle_t;
#else
typedef int hsa_handle_t;
#endif
/**
* @deprecated
*
+1 -1
Voir le fichier
@@ -2321,7 +2321,7 @@ hsa_status_t HSA_API
*/
hsa_status_t HSA_API hsa_amd_interop_map_buffer(uint32_t num_agents,
hsa_agent_t* agents,
int interop_handle,
hsa_handle_t interop_handle,
uint32_t flags,
size_t* size,
void** ptr,