c/render: Docs improvements

This commit is contained in:
Ryan Pavlik 2022-05-17 13:52:37 -05:00
parent 7af6a78e54
commit d5bed66734

View file

@ -318,6 +318,8 @@ struct render_resources
* Allocate pools and static resources. * Allocate pools and static resources.
* *
* @ingroup comp_main * @ingroup comp_main
*
* @public @memberof render_resources
*/ */
bool bool
render_resources_init(struct render_resources *r, render_resources_init(struct render_resources *r,
@ -327,6 +329,8 @@ render_resources_init(struct render_resources *r,
/*! /*!
* Free all pools and static resources, does not free the struct itself. * Free all pools and static resources, does not free the struct itself.
*
* @public @memberof render_resources
*/ */
void void
render_resources_close(struct render_resources *r); render_resources_close(struct render_resources *r);
@ -334,13 +338,16 @@ render_resources_close(struct render_resources *r);
/*! /*!
* Returns the timestamps for when the latest GPU work started and stopped that * Returns the timestamps for when the latest GPU work started and stopped that
* was submitted using @ref render_gfx or @ref render_compute cmd buf builders. * was submitted using @ref render_gfx or @ref render_compute cmd buf builders.
* Returned in the same time domain as returned by @ref os_monotonic_get_ns. *
* Returned in the same time domain as returned by @ref os_monotonic_get_ns .
* Behaviour for this function is undefined if the GPU has not completed before * Behaviour for this function is undefined if the GPU has not completed before
* calling this function, so make sure to call vkQueueWaitIdle or wait on the * calling this function, so make sure to call vkQueueWaitIdle or wait on the
* fence that the work was submitted with have fully completed. See other * fence that the work was submitted with have fully completed. See other
* limitation mentioned for @ref vk_convert_timestamps_to_host_ns. * limitation mentioned for @ref vk_convert_timestamps_to_host_ns .
* *
* @see vk_convert_timestamps_to_host_ns * @see vk_convert_timestamps_to_host_ns
*
* @public @memberof render_resources
*/ */
bool bool
render_resources_get_timestamps(struct render_resources *r, uint64_t *out_gpu_start_ns, uint64_t *out_gpu_end_ns); render_resources_get_timestamps(struct render_resources *r, uint64_t *out_gpu_start_ns, uint64_t *out_gpu_end_ns);
@ -421,6 +428,8 @@ struct render_gfx_target_resources
/*! /*!
* Init a target resource struct, caller has to keep target alive until closed. * Init a target resource struct, caller has to keep target alive until closed.
*
* @public @memberof render_gfx_target_resources
*/ */
bool bool
render_gfx_target_resources_init(struct render_gfx_target_resources *rtr, render_gfx_target_resources_init(struct render_gfx_target_resources *rtr,
@ -430,6 +439,8 @@ render_gfx_target_resources_init(struct render_gfx_target_resources *rtr,
/*! /*!
* Frees all resources held by the target, does not free the struct itself. * Frees all resources held by the target, does not free the struct itself.
*
* @public @memberof render_gfx_target_resources
*/ */
void void
render_gfx_target_resources_close(struct render_gfx_target_resources *rtr); render_gfx_target_resources_close(struct render_gfx_target_resources *rtr);
@ -479,12 +490,16 @@ struct render_gfx
/*! /*!
* Init struct and create resources needed for rendering. * Init struct and create resources needed for rendering.
*
* @public @memberof render_gfx
*/ */
bool bool
render_gfx_init(struct render_gfx *rr, struct render_resources *r); render_gfx_init(struct render_gfx *rr, struct render_resources *r);
/*! /*!
* Begins the rendering, takes the vk_bundle's pool lock and leaves it locked. * Begins the rendering, takes the vk_bundle's pool lock and leaves it locked.
*
* @public @memberof render_gfx
*/ */
bool bool
render_gfx_begin(struct render_gfx *rr); render_gfx_begin(struct render_gfx *rr);
@ -492,12 +507,16 @@ render_gfx_begin(struct render_gfx *rr);
/*! /*!
* Frees any unneeded resources and ends the command buffer so it can be used, * Frees any unneeded resources and ends the command buffer so it can be used,
* also unlocks the vk_bundle's pool lock that was taken by begin. * also unlocks the vk_bundle's pool lock that was taken by begin.
*
* @public @memberof render_gfx
*/ */
bool bool
render_gfx_end(struct render_gfx *rr); render_gfx_end(struct render_gfx *rr);
/*! /*!
* Frees all resources held by the rendering, does not free the struct itself. * Frees all resources held by the rendering, does not free the struct itself.
*
* @public @memberof render_gfx
*/ */
void void
render_gfx_close(struct render_gfx *rr); render_gfx_close(struct render_gfx *rr);
@ -519,26 +538,48 @@ struct render_gfx_mesh_ubo_data
struct xrt_normalized_rect post_transform; struct xrt_normalized_rect post_transform;
}; };
/*!
* @name Drawing functions
* @{
*/
/*! /*!
* This function allocates everything to start a single rendering. This is the * This function allocates everything to start a single rendering. This is the
* first function you call when you start rendering, you follow up with a call * first function you call when you start rendering, you follow up with a call
* to render_gfx_begin_view. * to render_gfx_begin_view.
*
* @public @memberof render_gfx
*/ */
bool bool
render_gfx_begin_target(struct render_gfx *rr, struct render_gfx_target_resources *rtr); render_gfx_begin_target(struct render_gfx *rr, struct render_gfx_target_resources *rtr);
/*!
* @public @memberof render_gfx
*/
void void
render_gfx_end_target(struct render_gfx *rr); render_gfx_end_target(struct render_gfx *rr);
/*!
* @public @memberof render_gfx
*/
void void
render_gfx_begin_view(struct render_gfx *rr, uint32_t view, struct render_viewport_data *viewport_data); render_gfx_begin_view(struct render_gfx *rr, uint32_t view, struct render_viewport_data *viewport_data);
/*!
* @public @memberof render_gfx
*/
void void
render_gfx_end_view(struct render_gfx *rr); render_gfx_end_view(struct render_gfx *rr);
/*!
* @public @memberof render_gfx
*/
void void
render_gfx_distortion(struct render_gfx *rr); render_gfx_distortion(struct render_gfx *rr);
/*!
* @}
*/
/* /*
* *
@ -546,13 +587,20 @@ render_gfx_distortion(struct render_gfx *rr);
* *
*/ */
/*!
* @name Update functions
* @{
*/
/*!
* @public @memberof render_gfx
*/
void void
render_gfx_update_distortion(struct render_gfx *rr, render_gfx_update_distortion(struct render_gfx *rr,
uint32_t view, uint32_t view,
VkSampler sampler, VkSampler sampler,
VkImageView image_view, VkImageView image_view,
struct render_gfx_mesh_ubo_data *data); struct render_gfx_mesh_ubo_data *data);
//! @}
/* /*
@ -580,6 +628,8 @@ struct render_compute
/*! /*!
* UBO data that is sent to the compute distortion shaders. * UBO data that is sent to the compute distortion shaders.
*
* Used in @ref render_compute
*/ */
struct render_compute_distortion_ubo_data struct render_compute_distortion_ubo_data
@ -592,12 +642,16 @@ struct render_compute_distortion_ubo_data
/*! /*!
* Init struct and create resources needed for compute rendering. * Init struct and create resources needed for compute rendering.
*
* @public @memberof render_compute
*/ */
bool bool
render_compute_init(struct render_compute *crc, struct render_resources *r); render_compute_init(struct render_compute *crc, struct render_resources *r);
/*! /*!
* Frees all resources held by the compute rendering, does not free the struct itself. * Frees all resources held by the compute rendering, does not free the struct itself.
*
* @public @memberof render_compute
*/ */
void void
render_compute_close(struct render_compute *crc); render_compute_close(struct render_compute *crc);
@ -605,6 +659,8 @@ render_compute_close(struct render_compute *crc);
/*! /*!
* Begin the compute command buffer building, takes the vk_bundle's pool lock * Begin the compute command buffer building, takes the vk_bundle's pool lock
* and leaves it locked. * and leaves it locked.
*
* @public @memberof render_compute
*/ */
bool bool
render_compute_begin(struct render_compute *crc); render_compute_begin(struct render_compute *crc);
@ -612,10 +668,15 @@ render_compute_begin(struct render_compute *crc);
/*! /*!
* Frees any unneeded resources and ends the command buffer so it can be used, * Frees any unneeded resources and ends the command buffer so it can be used,
* also unlocks the vk_bundle's pool lock that was taken by begin. * also unlocks the vk_bundle's pool lock that was taken by begin.
*
* @public @memberof render_compute
*/ */
bool bool
render_compute_end(struct render_compute *crc); render_compute_end(struct render_compute *crc);
/*!
* @public @memberof render_compute
*/
void void
render_compute_projection_timewarp(struct render_compute *crc, render_compute_projection_timewarp(struct render_compute *crc,
VkSampler src_samplers[2], VkSampler src_samplers[2],
@ -628,6 +689,9 @@ render_compute_projection_timewarp(struct render_compute *crc,
VkImageView target_image_view, VkImageView target_image_view,
const struct render_viewport_data views[2]); const struct render_viewport_data views[2]);
/*!
* @public @memberof render_compute
*/
void void
render_compute_projection(struct render_compute *crc, // render_compute_projection(struct render_compute *crc, //
VkSampler src_samplers[2], // VkSampler src_samplers[2], //
@ -637,6 +701,9 @@ render_compute_projection(struct render_compute *crc, //
VkImageView target_image_view, // VkImageView target_image_view, //
const struct render_viewport_data views[2]); // const struct render_viewport_data views[2]); //
/*!
* @public @memberof render_compute
*/
void void
render_compute_clear(struct render_compute *crc, // render_compute_clear(struct render_compute *crc, //
VkImage target_image, // VkImage target_image, //