diff options
author | Philip Langdale <philipl@overt.org> | 2018-10-14 17:37:05 -0700 |
---|---|---|
committer | sfan5 <sfan5@live.de> | 2018-10-22 21:35:48 +0200 |
commit | a782197d216b2343abe04045b9bb3076864aca80 (patch) | |
tree | 6f344aa3c221f073784e695d70d676ae87442cfa /video/out | |
parent | 93f800a00f3f8ef416082e0a3f9d34d979a1e9a6 (diff) |
vo_gpu: vulkan: Add arbitrary user data for an ra_vk_buf
This is arguably a little contrived, but in the case of CUDA interop,
we have to track additional state on the cuda side for each exported
buffer. If we want to be able to manage buffers with an ra_buf_pool,
we need some way to keep that CUDA state associated with each created
buffer. The easiest way to do that is to attach it directly to the
buffers.
Diffstat (limited to 'video/out')
-rw-r--r-- | video/out/vulkan/ra_vk.c | 12 | ||||
-rw-r--r-- | video/out/vulkan/ra_vk.h | 6 |
2 files changed, 18 insertions, 0 deletions
diff --git a/video/out/vulkan/ra_vk.c b/video/out/vulkan/ra_vk.c index 1548b8c785..80019fa4bc 100644 --- a/video/out/vulkan/ra_vk.c +++ b/video/out/vulkan/ra_vk.c @@ -693,8 +693,20 @@ struct ra_buf_vk { // "current" metadata, can change during course of execution VkPipelineStageFlags current_stage; VkAccessFlags current_access; + // Arbitrary user data for the creator of a buffer + void *user_data; }; +void ra_vk_buf_set_user_data(struct ra_buf *buf, void *user_data) { + struct ra_buf_vk *vk_priv = buf->priv; + vk_priv->user_data = user_data; +} + +void *ra_vk_buf_get_user_data(struct ra_buf *buf) { + struct ra_buf_vk *vk_priv = buf->priv; + return vk_priv->user_data; +} + static void vk_buf_deref(struct ra *ra, struct ra_buf *buf) { if (!buf) diff --git a/video/out/vulkan/ra_vk.h b/video/out/vulkan/ra_vk.h index 89eb310146..393c01a3c1 100644 --- a/video/out/vulkan/ra_vk.h +++ b/video/out/vulkan/ra_vk.h @@ -43,3 +43,9 @@ struct vk_external_mem { // Export an ra_buf for importing by another api. bool ra_vk_buf_get_external_info(struct ra *ra, struct ra_buf *buf, struct vk_external_mem *ret); + +// Set the buffer user data +void ra_vk_buf_set_user_data(struct ra_buf *buf, void *priv); + +// Get the buffer user data +void *ra_vk_buf_get_user_data(struct ra_buf *buf); |