c/client: doc and naming convention improvements

This commit is contained in:
Ryan Pavlik 2022-05-17 13:36:21 -05:00
parent 9edc6dd0bf
commit 7af6a78e54
4 changed files with 35 additions and 28 deletions

View file

@ -327,7 +327,7 @@ xrt_gfx_provider_create_gl_egl(struct xrt_compositor_native *xcn,
struct client_egl_compositor *ceglc = U_TYPED_CALLOC(struct client_egl_compositor); struct client_egl_compositor *ceglc = U_TYPED_CALLOC(struct client_egl_compositor);
ceglc->dpy = display; ceglc->dpy = display;
client_gl_swapchain_create_func sc_create = NULL; client_gl_swapchain_create_func_t sc_create = NULL;
EGL_DEBUG("Extension availability:"); EGL_DEBUG("Extension availability:");
#define DUMP_EXTENSION_STATUS(EXT) EGL_DEBUG(" - " #EXT ": %s", GLAD_##EXT ? "true" : "false") #define DUMP_EXTENSION_STATUS(EXT) EGL_DEBUG(" - " #EXT ": %s", GLAD_##EXT ? "true" : "false")
@ -381,7 +381,7 @@ xrt_gfx_provider_create_gl_egl(struct xrt_compositor_native *xcn,
* EGL_ANDROID_native_fence_sync is available, revisit this when a more * EGL_ANDROID_native_fence_sync is available, revisit this when a more
* generic synchronization mechanism is implemented. * generic synchronization mechanism is implemented.
*/ */
client_gl_insert_fence_func insert_fence_func = NULL; client_gl_insert_fence_func_t insert_fence_func = NULL;
if (GLAD_EGL_ANDROID_native_fence_sync) { if (GLAD_EGL_ANDROID_native_fence_sync) {
insert_fence_func = insert_fence_android_native; insert_fence_func = insert_fence_android_native;
} }

View file

@ -520,10 +520,10 @@ client_gl_compositor_close(struct client_gl_compositor *c)
bool bool
client_gl_compositor_init(struct client_gl_compositor *c, client_gl_compositor_init(struct client_gl_compositor *c,
struct xrt_compositor_native *xcn, struct xrt_compositor_native *xcn,
client_gl_context_begin_func context_begin, client_gl_context_begin_func_t context_begin,
client_gl_context_end_func context_end, client_gl_context_end_func_t context_end,
client_gl_swapchain_create_func create_swapchain, client_gl_swapchain_create_func_t create_swapchain,
client_gl_insert_fence_func insert_fence) client_gl_insert_fence_func_t insert_fence)
{ {
assert(context_begin != NULL); assert(context_begin != NULL);
assert(context_end != NULL); assert(context_end != NULL);

View file

@ -36,6 +36,7 @@ struct client_gl_compositor;
*/ */
struct client_gl_swapchain struct client_gl_swapchain
{ {
//! Implements @ref xrt_swapchain_gl
struct xrt_swapchain_gl base; struct xrt_swapchain_gl base;
struct xrt_swapchain_native *xscn; struct xrt_swapchain_native *xscn;
@ -43,24 +44,29 @@ struct client_gl_swapchain
//! The texture target of images in this swapchain. //! The texture target of images in this swapchain.
uint32_t tex_target; uint32_t tex_target;
//! The compositor this swapchain was created on. Used when swapchain functions need access to the GL context. /*!
* The compositor this swapchain was created on. Used when swapchain functions need access to the GL context.
*
* Not an owning pointer.
*/
struct client_gl_compositor *gl_compositor; struct client_gl_compositor *gl_compositor;
}; };
/*! /*!
* Fetches the OpenGL context that is current on this thread and makes the OpenGL context given in the graphics binding * Fetches the OpenGL context that is current on this thread and makes the OpenGL context given in the graphics binding
* current instead. Only one thread at a time can operate on the sections between @ref client_gl_context_begin_func and * current instead. Only one thread at a time can operate on the sections between @ref client_gl_context_begin_func_t
* @ref client_gl_context_end_func, therefore client_gl_context_end_func MUST be called to avoid blocking the next * and
* thread calling @ref client_gl_context_begin_func. * @ref client_gl_context_end_func_t, therefore client_gl_context_end_func_t MUST be called to avoid blocking the next
* thread calling @ref client_gl_context_begin_func_t.
* *
* If the return value is not XRT_SUCCESS, @ref client_gl_context_end_func should not be called. * If the return value is not XRT_SUCCESS, @ref client_gl_context_end_func_t should not be called.
*/ */
typedef xrt_result_t (*client_gl_context_begin_func)(struct xrt_compositor *xc); typedef xrt_result_t (*client_gl_context_begin_func_t)(struct xrt_compositor *xc);
/*! /*!
* Makes the OpenGL context current that was current before @ref client_gl_context_begin_func was called. * Makes the OpenGL context current that was current before @ref client_gl_context_begin_func_t was called.
*/ */
typedef void (*client_gl_context_end_func)(struct xrt_compositor *xc); typedef void (*client_gl_context_end_func_t)(struct xrt_compositor *xc);
/*! /*!
* The type of a swapchain create constructor. * The type of a swapchain create constructor.
@ -75,10 +81,10 @@ typedef void (*client_gl_context_end_func)(struct xrt_compositor *xc);
* - Must populate `destroy` * - Must populate `destroy`
* - Does not need to save/restore texture binding * - Does not need to save/restore texture binding
*/ */
typedef struct xrt_swapchain *(*client_gl_swapchain_create_func)(struct xrt_compositor *xc, typedef struct xrt_swapchain *(*client_gl_swapchain_create_func_t)(struct xrt_compositor *xc,
const struct xrt_swapchain_create_info *info, const struct xrt_swapchain_create_info *info,
struct xrt_swapchain_native *xscn, struct xrt_swapchain_native *xscn,
struct client_gl_swapchain **out_sc); struct client_gl_swapchain **out_sc);
/*! /*!
* The type of a fence insertion function. * The type of a fence insertion function.
@ -87,7 +93,8 @@ typedef struct xrt_swapchain *(*client_gl_swapchain_create_func)(struct xrt_comp
* *
* The returned graphics sync handle is given to xrt_compositor::layer_commit. * The returned graphics sync handle is given to xrt_compositor::layer_commit.
*/ */
typedef xrt_result_t (*client_gl_insert_fence_func)(struct xrt_compositor *xc, xrt_graphics_sync_handle_t *out_handle); typedef xrt_result_t (*client_gl_insert_fence_func_t)(struct xrt_compositor *xc,
xrt_graphics_sync_handle_t *out_handle);
/*! /*!
* @class client_gl_compositor * @class client_gl_compositor
@ -106,23 +113,23 @@ struct client_gl_compositor
/*! /*!
* Function pointer for making the OpenGL context current. * Function pointer for making the OpenGL context current.
*/ */
client_gl_context_begin_func context_begin; client_gl_context_begin_func_t context_begin;
/*! /*!
* Function pointer for restoring prior OpenGL context. * Function pointer for restoring prior OpenGL context.
*/ */
client_gl_context_end_func context_end; client_gl_context_end_func_t context_end;
/*! /*!
* Function pointer for creating the client swapchain. * Function pointer for creating the client swapchain.
*/ */
client_gl_swapchain_create_func create_swapchain; client_gl_swapchain_create_func_t create_swapchain;
/*! /*!
* Function pointer for inserting fences on * Function pointer for inserting fences on
* xrt_compositor::layer_commit. * xrt_compositor::layer_commit.
*/ */
client_gl_insert_fence_func insert_fence; client_gl_insert_fence_func_t insert_fence;
/*! /*!
* @ref client_gl_xlib_compositor::app_context can only be current on one thread; block other threads while we * @ref client_gl_xlib_compositor::app_context can only be current on one thread; block other threads while we
@ -165,10 +172,10 @@ client_gl_compositor(struct xrt_compositor *xc)
bool bool
client_gl_compositor_init(struct client_gl_compositor *c, client_gl_compositor_init(struct client_gl_compositor *c,
struct xrt_compositor_native *xcn, struct xrt_compositor_native *xcn,
client_gl_context_begin_func context_begin, client_gl_context_begin_func_t context_begin,
client_gl_context_end_func context_end, client_gl_context_end_func_t context_end,
client_gl_swapchain_create_func create_swapchain, client_gl_swapchain_create_func_t create_swapchain,
client_gl_insert_fence_func insert_fence); client_gl_insert_fence_func_t insert_fence);
/*! /*!
* Free all resources from the client_gl_compositor, does not free the * Free all resources from the client_gl_compositor, does not free the

View file

@ -43,7 +43,7 @@ struct client_gl_memobj_swapchain
* *
* The caller must ensure that the app context is current. * The caller must ensure that the app context is current.
* *
* @see client_gl_swapchain_create_func, client_gl_compositor_init * @see client_gl_swapchain_create_func_t, client_gl_compositor_init
*/ */
struct xrt_swapchain * struct xrt_swapchain *
client_gl_memobj_swapchain_create(struct xrt_compositor *xc, client_gl_memobj_swapchain_create(struct xrt_compositor *xc,