util: Add drmSyncobj shim

Signed-off-by: Rob Clark <robdclark@chromium.org>
Reviewed-by: Dmitry Osipenko <dmitry.osipenko@collabora.com>
Tested-by: Dmitry Osipenko <dmitry.osipenko@collabora.com>
Part-of: <https://gitlab.freedesktop.org/mesa/mesa/-/merge_requests/33433>
This commit is contained in:
Rob Clark 2024-11-05 11:56:52 -08:00 committed by Marge Bot
parent 28ad8fd5b1
commit e76b1acbfe
3 changed files with 200 additions and 0 deletions

View file

@ -238,6 +238,11 @@ deps_for_libmesa_util = [
idep_mesautilformat,
]
if dep_libdrm.found()
files_mesa_util += files('u_sync_provider.c', 'u_sync_provider.h')
deps_for_libmesa_util += dep_libdrm
endif
if with_platform_android
deps_for_libmesa_util += dep_android
files_debug_stack = files('u_debug_stack_android.cpp')

142
src/util/u_sync_provider.c Normal file
View file

@ -0,0 +1,142 @@
/*
* Copyright © 2024 Google, Inc.
* SPDX-License-Identifier: MIT
*/
#include "util/u_memory.h"
#include "util/u_sync_provider.h"
#include <xf86drm.h>
struct util_sync_provider_drm {
struct util_sync_provider base;
int drm_fd;
};
static int
drm_fd(struct util_sync_provider *p)
{
struct util_sync_provider_drm *d = (struct util_sync_provider_drm *)p;
return d->drm_fd;
}
static int
drm_syncobj_create(struct util_sync_provider *p, uint32_t flags, uint32_t *handle)
{
return drmSyncobjCreate(drm_fd(p), flags, handle);
}
static int
drm_syncobj_destroy(struct util_sync_provider *p, uint32_t handle)
{
return drmSyncobjDestroy(drm_fd(p), handle);
}
static int
drm_syncobj_handle_to_fd(struct util_sync_provider *p, uint32_t handle, int *out_obj_fd)
{
return drmSyncobjHandleToFD(drm_fd(p), handle, out_obj_fd);
}
static int
drm_syncobj_fd_to_handle(struct util_sync_provider *p, int obj_fd, uint32_t *handle)
{
return drmSyncobjFDToHandle(drm_fd(p), obj_fd, handle);
}
static int
drm_syncobj_import_sync_file(struct util_sync_provider *p, uint32_t handle, int sync_file_fd)
{
return drmSyncobjImportSyncFile(drm_fd(p), handle, sync_file_fd);
}
static int
drm_syncobj_export_sync_file(struct util_sync_provider *p, uint32_t handle, int *out_sync_file_fd)
{
return drmSyncobjExportSyncFile(drm_fd(p), handle, out_sync_file_fd);
}
static int
drm_syncobj_wait(struct util_sync_provider *p, uint32_t *handles, unsigned num_handles,
int64_t timeout_nsec, unsigned flags, uint32_t *first_signaled)
{
return drmSyncobjWait(drm_fd(p), handles, num_handles, timeout_nsec, flags, first_signaled);
}
static int
drm_syncobj_reset(struct util_sync_provider *p, const uint32_t *handles, uint32_t handle_count)
{
return drmSyncobjReset(drm_fd(p), handles, handle_count);
}
static int
drm_syncobj_signal(struct util_sync_provider *p, const uint32_t *handles, uint32_t handle_count)
{
return drmSyncobjSignal(drm_fd(p), handles, handle_count);
}
static int
drm_syncobj_timeline_signal(struct util_sync_provider *p, const uint32_t *handles,
uint64_t *points, uint32_t handle_count)
{
return drmSyncobjTimelineSignal(drm_fd(p), handles, points, handle_count);
}
static int
drm_syncobj_timeline_wait(struct util_sync_provider *p, uint32_t *handles, uint64_t *points,
unsigned num_handles, int64_t timeout_nsec, unsigned flags,
uint32_t *first_signaled)
{
return drmSyncobjTimelineWait(drm_fd(p), handles, points, num_handles, timeout_nsec, flags, first_signaled);
}
static int
drm_syncobj_query(struct util_sync_provider *p, uint32_t *handles, uint64_t *points,
uint32_t handle_count, uint32_t flags)
{
return drmSyncobjQuery2(drm_fd(p), handles, points, handle_count, flags);
}
static int
drm_syncobj_transfer(struct util_sync_provider *p, uint32_t dst_handle, uint64_t dst_point,
uint32_t src_handle, uint64_t src_point, uint32_t flags)
{
return drmSyncobjTransfer(drm_fd(p), dst_handle, dst_point, src_handle, src_point, flags);
}
static void
drm_syncobj_finalize(struct util_sync_provider *p)
{
free(p);
}
struct util_sync_provider *
util_sync_provider_drm(int drm_fd)
{
struct util_sync_provider_drm *d = CALLOC_STRUCT(util_sync_provider_drm);
d->drm_fd = drm_fd;
d->base = (struct util_sync_provider) {
.create = drm_syncobj_create,
.destroy = drm_syncobj_destroy,
.handle_to_fd = drm_syncobj_handle_to_fd,
.fd_to_handle = drm_syncobj_fd_to_handle,
.import_sync_file = drm_syncobj_import_sync_file,
.export_sync_file = drm_syncobj_export_sync_file,
.wait = drm_syncobj_wait,
.reset = drm_syncobj_reset,
.signal = drm_syncobj_signal,
.query = drm_syncobj_query,
.transfer = drm_syncobj_transfer,
.finalize = drm_syncobj_finalize,
};
uint64_t cap;
int err = drmGetCap(drm_fd, DRM_CAP_SYNCOBJ_TIMELINE, &cap);
if (err == 0 && cap != 0) {
d->base.timeline_signal = drm_syncobj_timeline_signal;
d->base.timeline_wait = drm_syncobj_timeline_wait;
}
return &d->base;
}

View file

@ -0,0 +1,53 @@
/*
* Copyright © 2024 Google, Inc.
* SPDX-License-Identifier: MIT
*/
#include <stdint.h>
#ifndef U_SYNC_PROVIDER_H
#define U_SYNC_PROVIDER_H
#ifdef __cplusplus
extern "C" {
#endif
struct util_sync_provider {
int (*create)(struct util_sync_provider *p, uint32_t flags, uint32_t *handle);
int (*destroy)(struct util_sync_provider *p, uint32_t handle);
int (*handle_to_fd)(struct util_sync_provider *p, uint32_t handle, int *out_obj_fd);
int (*fd_to_handle)(struct util_sync_provider *p, int obj_fd, uint32_t *handle);
int (*import_sync_file)(struct util_sync_provider *p, uint32_t handle, int sync_file_fd);
int (*export_sync_file)(struct util_sync_provider *p, uint32_t handle, int *out_sync_file_fd);
int (*wait)(struct util_sync_provider *p, uint32_t *handles, unsigned num_handles,
int64_t timeout_nsec, unsigned flags, uint32_t *first_signaled);
int (*reset)(struct util_sync_provider *p, const uint32_t *handles, uint32_t handle_count);
int (*signal)(struct util_sync_provider *p, const uint32_t *handles, uint32_t handle_count);
int (*timeline_signal)(struct util_sync_provider *p, const uint32_t *handles,
uint64_t *points, uint32_t handle_count);
int (*timeline_wait)(struct util_sync_provider *p, uint32_t *handles, uint64_t *points,
unsigned num_handles, int64_t timeout_nsec, unsigned flags,
uint32_t *first_signaled);
int (*query)(struct util_sync_provider *p, uint32_t *handles, uint64_t *points,
uint32_t handle_count, uint32_t flags);
int (*transfer)(struct util_sync_provider *p, uint32_t dst_handle, uint64_t dst_point,
uint32_t src_handle, uint64_t src_point, uint32_t flags);
void (*finalize)(struct util_sync_provider *p);
};
#if HAVE_LIBDRM
struct util_sync_provider * util_sync_provider_drm(int drm_fd);
#else
static inline struct util_sync_provider *
util_sync_provider_drm(int drm_fd)
{
return NULL;
}
#endif
#ifdef __cplusplus
}
#endif
#endif /* U_SYNC_PROVIDER_H */