Skip to content

Commit

Permalink
[GPU] Abstraction of cl_buffer_manager
Browse files Browse the repository at this point in the history
Adding abstraction in cl_buffer_manager
using const for opencl::Buffer methods

Signed-off-by: Debadri Samaddar <[email protected]>
  • Loading branch information
s-debadri committed Dec 10, 2024
1 parent dab2d91 commit cc94bad
Show file tree
Hide file tree
Showing 5 changed files with 66 additions and 34 deletions.
20 changes: 10 additions & 10 deletions nntrainer/cl_buffer_manager.cpp
Original file line number Diff line number Diff line change
Expand Up @@ -22,20 +22,20 @@ ClBufferManager &ClBufferManager::getInstance() {
// to-do: Implementation to be updated with array of Buffer objects if required
// fp16 Buffer objects to be added in future
void ClBufferManager::initBuffers() {
readBufferA = new opencl::Buffer(context_inst_, buffer_size_bytes, true);
readBufferB = new opencl::Buffer(context_inst_, buffer_size_bytes, true);
readBufferC = new opencl::Buffer(context_inst_, buffer_size_bytes, true);
writeBufferA = new opencl::Buffer(context_inst_, buffer_size_bytes, false);
writeBufferB = new opencl::Buffer(context_inst_, buffer_size_bytes, false);
inBufferA = new opencl::Buffer(context_inst_, buffer_size_bytes, true);
inBufferB = new opencl::Buffer(context_inst_, buffer_size_bytes, true);
inBufferC = new opencl::Buffer(context_inst_, buffer_size_bytes, true);
outBufferA = new opencl::Buffer(context_inst_, buffer_size_bytes, false);
outBufferB = new opencl::Buffer(context_inst_, buffer_size_bytes, false);
ml_logi("ClBufferManager: Buffers initialized");
}

ClBufferManager::~ClBufferManager() {
delete readBufferA;
delete readBufferB;
delete readBufferC;
delete writeBufferA;
delete writeBufferB;
delete inBufferA;
delete inBufferB;
delete inBufferC;
delete outBufferA;
delete outBufferB;
ml_logi("ClBufferManager: Buffers destroyed");
}

Expand Down
44 changes: 37 additions & 7 deletions nntrainer/cl_buffer_manager.h
Original file line number Diff line number Diff line change
Expand Up @@ -45,7 +45,13 @@ class ClBufferManager {
/**
* @brief Buffer size in bytes preset (256 mebibytes)
*/
size_t buffer_size_bytes = 8192 * 8192 * sizeof(float);
const size_t buffer_size_bytes = 8192 * 8192 * sizeof(float);

const opencl::Buffer *inBufferA;
const opencl::Buffer *inBufferB;
const opencl::Buffer *inBufferC;
const opencl::Buffer *outBufferA;
const opencl::Buffer *outBufferB;

public:
/**
Expand All @@ -55,17 +61,41 @@ class ClBufferManager {
*/
static ClBufferManager &getInstance();

opencl::Buffer *readBufferA;
opencl::Buffer *readBufferB;
opencl::Buffer *readBufferC;
opencl::Buffer *writeBufferA;
opencl::Buffer *writeBufferB;

/**
* @brief Initialize Buffer objects.
*/
void initBuffers();

/**
* @brief Get read only inBufferA.
* @return const opencl::Buffer*
*/
const opencl::Buffer *getInBufferA() { return inBufferA; }

/**
* @brief Get read only inBufferB.
* @return const opencl::Buffer*
*/
const opencl::Buffer *getInBufferB() { return inBufferB; }

/**
* @brief Get read only inBufferC.
* @return const opencl::Buffer*
*/
const opencl::Buffer *getInBufferC() { return inBufferC; }

/**
* @brief Get read-write outBufferA.
* @return const opencl::Buffer*
*/
const opencl::Buffer *getOutBufferA() { return outBufferA; }

/**
* @brief Get read-write outBufferB.
* @return const opencl::Buffer*
*/
const opencl::Buffer *getOutBufferB() { return outBufferB; }

/**
* @brief Destroy Buffer pointers.
*
Expand Down
9 changes: 5 additions & 4 deletions nntrainer/opencl/opencl_buffer.cpp
Original file line number Diff line number Diff line change
Expand Up @@ -90,14 +90,14 @@ cl_mem &Buffer::GetBuffer() { return mem_buf_; }
* @return true if successful write or false otherwise
*/
bool Buffer::WriteData(CommandQueueManager &command_queue_inst,
const void *data) {
const void *data) const {
return command_queue_inst.EnqueueWriteBuffer(mem_buf_, size_, data);
}

bool Buffer::WriteDataRegion(CommandQueueManager &command_queue_inst,
size_t size_in_bytes, const void *data,
size_t host_origin_offset,
size_t buffer_origin_offset) {
size_t buffer_origin_offset) const {
if (size_in_bytes > size_) {
ml_loge("Failed to write buffer region. Region size(%lu bytes) greater "
"than buffer size(%lu bytes).",
Expand All @@ -115,14 +115,15 @@ bool Buffer::WriteDataRegion(CommandQueueManager &command_queue_inst,
* @param data
* @return true if successful read or false otherwise
*/
bool Buffer::ReadData(CommandQueueManager &command_queue_inst, void *data) {
bool Buffer::ReadData(CommandQueueManager &command_queue_inst,
void *data) const {
return command_queue_inst.EnqueueReadBuffer(mem_buf_, size_, data);
}

bool Buffer::ReadDataRegion(CommandQueueManager &command_queue_inst,
size_t size_in_bytes, void *data,
size_t host_origin_offset,
size_t buffer_origin_offset) {
size_t buffer_origin_offset) const {
if (size_in_bytes > size_) {
ml_loge("Failed to read from buffer region. Region size(%lu bytes) greater "
"than buffer size(%lu bytes).",
Expand Down
9 changes: 5 additions & 4 deletions nntrainer/opencl/opencl_buffer.h
Original file line number Diff line number Diff line change
Expand Up @@ -104,7 +104,8 @@ class Buffer {
* @param data
* @return true if successful write or false otherwise
*/
bool WriteData(CommandQueueManager &command_queue_inst, const void *data);
bool WriteData(CommandQueueManager &command_queue_inst,
const void *data) const;

/**
* @brief writing data to a buffer region
Expand All @@ -119,7 +120,7 @@ class Buffer {
bool WriteDataRegion(CommandQueueManager &command_queue_inst,
size_t size_in_bytes, const void *data,
size_t host_origin_offset = 0,
size_t buffer_origin_offset = 0);
size_t buffer_origin_offset = 0) const;

/**
* @brief reading data from the buffer
Expand All @@ -128,7 +129,7 @@ class Buffer {
* @param data
* @return true if successful read or false otherwise
*/
bool ReadData(CommandQueueManager &command_queue_inst, void *data);
bool ReadData(CommandQueueManager &command_queue_inst, void *data) const;

/**
* @brief Reading data from a buffer region
Expand All @@ -143,7 +144,7 @@ class Buffer {
bool ReadDataRegion(CommandQueueManager &command_queue_inst,
size_t size_in_bytes, void *data,
size_t host_origin_offset = 0,
size_t buffer_origin_offset = 0);
size_t buffer_origin_offset = 0) const;

/**
* @brief Mapping buffer to host memory
Expand Down
18 changes: 9 additions & 9 deletions nntrainer/tensor/cl_operations/blas_kernels.cpp
Original file line number Diff line number Diff line change
Expand Up @@ -40,39 +40,39 @@ void sgemv_cl(const float *matAdata, const float *vecXdata, float *vecYdata,
size_t dim1_size = sizeof(float) * dim1;
size_t dim2_size = sizeof(float) * dim2;

result = clbuffInstance.readBufferA->WriteDataRegion(
result = clbuffInstance.getInBufferA()->WriteDataRegion(
cl_context_ref.command_queue_inst_, dim1 * dim2 * sizeof(float),
matAdata);
if (!result) {
break;
}

result = clbuffInstance.readBufferB->WriteDataRegion(
result = clbuffInstance.getInBufferB()->WriteDataRegion(
cl_context_ref.command_queue_inst_, dim2_size, vecXdata);
if (!result) {
break;
}

result = clbuffInstance.writeBufferA->WriteDataRegion(
result = clbuffInstance.getOutBufferA()->WriteDataRegion(
cl_context_ref.command_queue_inst_, dim1_size, vecYdata);
if (!result) {
break;
}

result = kernel_sgemv_ptr->SetKernelArguments(0, clbuffInstance.readBufferA,
sizeof(cl_mem));
result = kernel_sgemv_ptr->SetKernelArguments(
0, clbuffInstance.getInBufferA(), sizeof(cl_mem));
if (!result) {
break;
}

result = kernel_sgemv_ptr->SetKernelArguments(1, clbuffInstance.readBufferB,
sizeof(cl_mem));
result = kernel_sgemv_ptr->SetKernelArguments(
1, clbuffInstance.getInBufferB(), sizeof(cl_mem));
if (!result) {
break;
}

result = kernel_sgemv_ptr->SetKernelArguments(
2, clbuffInstance.writeBufferA, sizeof(cl_mem));
2, clbuffInstance.getOutBufferA(), sizeof(cl_mem));
if (!result) {
break;
}
Expand All @@ -96,7 +96,7 @@ void sgemv_cl(const float *matAdata, const float *vecXdata, float *vecYdata,
break;
}

result = clbuffInstance.writeBufferA->ReadDataRegion(
result = clbuffInstance.getOutBufferA()->ReadDataRegion(
cl_context_ref.command_queue_inst_, dim1_size, vecYdata);
if (!result) {
break;
Expand Down

0 comments on commit cc94bad

Please sign in to comment.