GPU: Compute: Document and cleanup header
No fonctional changes.
This commit is contained in:
@@ -2,6 +2,11 @@
|
||||
|
||||
/** \file
|
||||
* \ingroup gpu
|
||||
*
|
||||
* GPU Compute Pipeline
|
||||
*
|
||||
* Allows to dispatch compute shader tasks on the GPU.
|
||||
* Every dispatch is sent to the active `GPUContext`.
|
||||
*/
|
||||
|
||||
#pragma once
|
||||
@@ -15,12 +20,34 @@
|
||||
extern "C" {
|
||||
#endif
|
||||
|
||||
/**
|
||||
* Dispatch a compute shader task.
|
||||
* The number of work groups (aka thread groups) is bounded by `GPU_max_work_group_count()` which
|
||||
* might be different in each of the 3 dimensions.
|
||||
*/
|
||||
void GPU_compute_dispatch(GPUShader *shader,
|
||||
uint groups_x_len,
|
||||
uint groups_y_len,
|
||||
uint groups_z_len);
|
||||
|
||||
void GPU_compute_dispatch_indirect(GPUShader *shader, GPUStorageBuf *indirect_buf_);
|
||||
/**
|
||||
* Dispatch a compute shader task. The size of the dispatch is sourced from a \a indirect_buf
|
||||
* which must follow this layout:
|
||||
* \code{.c}
|
||||
* typedef struct {
|
||||
* uint groups_x_len;
|
||||
* uint groups_y_len;
|
||||
* uint groups_z_len;
|
||||
* } DispatchIndirectCommand;
|
||||
* \encode
|
||||
*
|
||||
* \note The writes to the \a indirect_buf do not need to be synchronized as a memory barrier is
|
||||
* emitted internally.
|
||||
*
|
||||
* The number of work groups (aka thread groups) is bounded by `GPU_max_work_group_count()` which
|
||||
* might be different in each of the 3 dimensions.
|
||||
*/
|
||||
void GPU_compute_dispatch_indirect(GPUShader *shader, GPUStorageBuf *indirect_buf);
|
||||
|
||||
#ifdef __cplusplus
|
||||
}
|
||||
|
||||
Reference in New Issue
Block a user