Listing the "Blender Foundation" as copyright holder implied the Blender Foundation holds copyright to files which may include work from many developers. While keeping copyright on headers makes sense for isolated libraries, Blender's own code may be refactored or moved between files in a way that makes the per file copyright holders less meaningful. Copyright references to the "Blender Foundation" have been replaced with "Blender Authors", with the exception of `./extern/` since these this contains libraries which are more isolated, any changed to license headers there can be handled on a case-by-case basis. Some directories in `./intern/` have also been excluded: - `./intern/cycles/` it's own `AUTHORS` file is planned. - `./intern/opensubdiv/`. An "AUTHORS" file has been added, using the chromium projects authors file as a template. Design task: #110784 Ref !110783.
115 lines
2.4 KiB
C++
115 lines
2.4 KiB
C++
/* SPDX-FileCopyrightText: 2011 Blender Authors
|
|
*
|
|
* SPDX-License-Identifier: GPL-2.0-or-later */
|
|
|
|
#pragma once
|
|
|
|
#ifdef WITH_CXX_GUARDEDALLOC
|
|
# include "MEM_guardedalloc.h"
|
|
#endif
|
|
|
|
#include "COM_defines.h"
|
|
|
|
namespace blender::compositor {
|
|
|
|
/* Forward declarations. */
|
|
class MemoryBuffer;
|
|
class ExecutionGroup;
|
|
class WriteBufferOperation;
|
|
|
|
/**
|
|
* \brief A MemoryProxy is a unique identifier for a memory buffer.
|
|
* A single MemoryProxy is used among all chunks of the same buffer,
|
|
* the MemoryBuffer only stores the data of a single chunk.
|
|
* \ingroup Memory
|
|
*/
|
|
class MemoryProxy {
|
|
private:
|
|
/**
|
|
* \brief reference to the output operation of the executiongroup
|
|
*/
|
|
WriteBufferOperation *write_buffer_operation_;
|
|
|
|
/**
|
|
* \brief reference to the executor. the Execution group that can fill a chunk
|
|
*/
|
|
ExecutionGroup *executor_;
|
|
|
|
/**
|
|
* \brief the allocated memory
|
|
*/
|
|
MemoryBuffer *buffer_;
|
|
|
|
/**
|
|
* \brief datatype of this MemoryProxy
|
|
*/
|
|
DataType datatype_;
|
|
|
|
public:
|
|
MemoryProxy(DataType type);
|
|
|
|
/**
|
|
* \brief set the ExecutionGroup that can be scheduled to calculate a certain chunk.
|
|
* \param group: the ExecutionGroup to set
|
|
*/
|
|
void set_executor(ExecutionGroup *executor)
|
|
{
|
|
executor_ = executor;
|
|
}
|
|
|
|
/**
|
|
* \brief get the ExecutionGroup that can be scheduled to calculate a certain chunk.
|
|
*/
|
|
ExecutionGroup *get_executor() const
|
|
{
|
|
return executor_;
|
|
}
|
|
|
|
/**
|
|
* \brief set the WriteBufferOperation that is responsible for writing to this MemoryProxy
|
|
* \param operation:
|
|
*/
|
|
void set_write_buffer_operation(WriteBufferOperation *operation)
|
|
{
|
|
write_buffer_operation_ = operation;
|
|
}
|
|
|
|
/**
|
|
* \brief get the WriteBufferOperation that is responsible for writing to this MemoryProxy
|
|
* \return WriteBufferOperation
|
|
*/
|
|
WriteBufferOperation *get_write_buffer_operation() const
|
|
{
|
|
return write_buffer_operation_;
|
|
}
|
|
|
|
/**
|
|
* \brief allocate memory of size width x height
|
|
*/
|
|
void allocate(unsigned int width, unsigned int height);
|
|
|
|
/**
|
|
* \brief free the allocated memory
|
|
*/
|
|
void free();
|
|
|
|
/**
|
|
* \brief get the allocated memory
|
|
*/
|
|
inline MemoryBuffer *get_buffer()
|
|
{
|
|
return buffer_;
|
|
}
|
|
|
|
inline DataType get_data_type()
|
|
{
|
|
return datatype_;
|
|
}
|
|
|
|
#ifdef WITH_CXX_GUARDEDALLOC
|
|
MEM_CXX_CLASS_ALLOC_FUNCS("COM:MemoryProxy")
|
|
#endif
|
|
};
|
|
|
|
} // namespace blender::compositor
|