mirror of
https://github.com/pytorch/pytorch.git
synced 2025-10-20 21:14:14 +08:00
Summary: Pull Request resolved: https://github.com/pytorch/pytorch/pull/67746 Test Plan: Visual inspection. Sandcastle. Reviewed By: zertosh Differential Revision: D31986646 fbshipit-source-id: 91885c20c3cead3853c49abb9fe0a94a67f33cc8
47 lines
1.2 KiB
C++
47 lines
1.2 KiB
C++
#pragma once
|
|
|
|
#include <ATen/MapAllocator.h>
|
|
|
|
#ifdef __cplusplus
|
|
|
|
void libshm_init(const char* manager_exec_path);
|
|
|
|
// Superclass to run a constructor before at::RefcountedMapAllocator
|
|
class THManagedMapAllocatorInit {
|
|
protected:
|
|
THManagedMapAllocatorInit(const char* manager_handle, const char* filename);
|
|
std::string manager_handle_;
|
|
};
|
|
|
|
// Like a at::RefcountedMapAllocator, but it also makes use of an external
|
|
// shared memory manager process to ensure that shared memory regions actually
|
|
// get freed in the end (even if processes lose the memory).
|
|
class THManagedMapAllocator : private THManagedMapAllocatorInit,
|
|
public at::RefcountedMapAllocator {
|
|
public:
|
|
THManagedMapAllocator(
|
|
const char* manager_handle,
|
|
const char* filename,
|
|
int flags,
|
|
ptrdiff_t size);
|
|
|
|
void close() override;
|
|
|
|
~THManagedMapAllocator() {
|
|
close();
|
|
}
|
|
|
|
static at::DataPtr makeDataPtr(
|
|
const char* manager_handle,
|
|
const char* filename,
|
|
int flags,
|
|
ptrdiff_t size);
|
|
static THManagedMapAllocator* fromDataPtr(const at::DataPtr&);
|
|
|
|
const char* manager_handle() const {
|
|
return manager_handle_.c_str();
|
|
}
|
|
};
|
|
|
|
#endif
|