blob: 1b765233947d3dfd6f14b9da36ea1e7aac80ac98 [file] [log] [blame]
/*!
* Copyright (c) 2015 by Contributors
* \file storage.h
* \brief Storage manager across multiple devices.
*/
#ifndef MXNET_STORAGE_H_
#define MXNET_STORAGE_H_
#include <memory>
#include "./base.h"
namespace mxnet {
/*!
* \brief Storage manager across multiple devices.
*/
class Storage {
public:
/*!
* \brief Storage handle.
*/
struct Handle {
/*!
* \brief Pointer to the data.
*/
void* dptr;
/*!
* \brief Size of the storage.
*/
size_t size;
/*!
* \brief Context information about device and ID.
*/
Context ctx;
};
/*!
* \brief Allocate a new contiguous memory for a given size.
* \param size Total size of memory in bytes.
* \param ctx Context information about the device and ID.
* \return Handle struct.
*/
virtual Handle Alloc(size_t size, Context ctx) = 0;
/*!
* \brief Free storage.
* \param handle Handle struect.
*/
virtual void Free(Handle handle) = 0;
/*!
* \brief Free storage directly, without putting it into memory pool.
* This can synchronization of all previous runned device functions.
*
* This function is suitable for conatiner structure with requirement on upsizing
* in the beginning phase of the iteration.
*
* \param handle Handle struct.
*/
virtual void DirectFree(Handle handle) = 0;
/*!
* \brief Destructor.
*/
virtual ~Storage() {}
/*!
* \return Storage singleton.
*/
static Storage* Get();
/*!
* \brief Get shared pointer reference to storage singleton.
* Most user should not call this function.
* This function is called by another singleton X who requires
* Storage to be destructed after X.
*
* \return A shared pointer to Storage singleton.
*/
static std::shared_ptr<Storage> _GetSharedRef();
}; // class Storage
} // namespace mxnet
#endif // MXNET_STORAGE_H_