[Mesa-dev] [PATCH 05/24] mesa/st: start adding memory object support
Timothy Arceri
tarceri at itsqueeze.com
Thu Jul 27 13:08:30 UTC 2017
From: Dave Airlie <airlied at redhat.com>
v2: pass dedicated flag
v3 (Timothy Arceri):
- remove unrequired _mesa_init_memory_object_functions()
call in the state tracker.
Signed-off-by: Andres Rodriguez <andresx7 at gmail.com>
Reviewed-by: Marek Olšák <marek.olsak at amd.com>
---
src/mesa/Makefile.sources | 2 +
src/mesa/state_tracker/st_cb_memoryobjects.c | 64 ++++++++++++++++++++++++++++
src/mesa/state_tracker/st_cb_memoryobjects.h | 25 +++++++++++
src/mesa/state_tracker/st_context.c | 2 +
4 files changed, 93 insertions(+)
create mode 100644 src/mesa/state_tracker/st_cb_memoryobjects.c
create mode 100644 src/mesa/state_tracker/st_cb_memoryobjects.h
diff --git a/src/mesa/Makefile.sources b/src/mesa/Makefile.sources
index 2ee1d2f814..2e4b04c60f 100644
--- a/src/mesa/Makefile.sources
+++ b/src/mesa/Makefile.sources
@@ -460,20 +460,22 @@ STATETRACKER_FILES = \
state_tracker/st_cb_drawtex.c \
state_tracker/st_cb_drawtex.h \
state_tracker/st_cb_eglimage.c \
state_tracker/st_cb_eglimage.h \
state_tracker/st_cb_fbo.c \
state_tracker/st_cb_fbo.h \
state_tracker/st_cb_feedback.c \
state_tracker/st_cb_feedback.h \
state_tracker/st_cb_flush.c \
state_tracker/st_cb_flush.h \
+ state_tracker/st_cb_memoryobjects.c \
+ state_tracker/st_cb_memoryobjects.h \
state_tracker/st_cb_msaa.c \
state_tracker/st_cb_msaa.h \
state_tracker/st_cb_perfmon.c \
state_tracker/st_cb_perfmon.h \
state_tracker/st_cb_program.c \
state_tracker/st_cb_program.h \
state_tracker/st_cb_queryobj.c \
state_tracker/st_cb_queryobj.h \
state_tracker/st_cb_rasterpos.c \
state_tracker/st_cb_rasterpos.h \
diff --git a/src/mesa/state_tracker/st_cb_memoryobjects.c b/src/mesa/state_tracker/st_cb_memoryobjects.c
new file mode 100644
index 0000000000..a5764c352e
--- /dev/null
+++ b/src/mesa/state_tracker/st_cb_memoryobjects.c
@@ -0,0 +1,64 @@
+#include "main/imports.h"
+#include "main/mtypes.h"
+
+#include "main/externalobjects.h"
+
+#include "st_context.h"
+#include "st_cb_memoryobjects.h"
+
+#include "state_tracker/drm_driver.h"
+#include "pipe/p_context.h"
+#include "pipe/p_screen.h"
+
+static struct gl_memory_object *
+st_memoryobj_alloc(struct gl_context *ctx, GLuint name)
+{
+ struct st_memory_object *st_obj = ST_CALLOC_STRUCT(st_memory_object);
+ if (!st_obj)
+ return NULL;
+
+ _mesa_initialize_memory_object(ctx, &st_obj->Base, name);
+ return &st_obj->Base;
+}
+
+static void
+st_memoryobj_free(struct gl_context *ctx,
+ struct gl_memory_object *obj)
+{
+ _mesa_delete_memory_object(ctx, obj);
+}
+
+
+static void
+st_import_memoryobj_fd(struct gl_context *ctx,
+ struct gl_memory_object *obj,
+ GLuint64 size,
+ int fd)
+{
+ struct st_memory_object *st_obj = st_memory_object(obj);
+ struct st_context *st = st_context(ctx);
+ struct pipe_context *pipe = st->pipe;
+ struct pipe_screen *screen = pipe->screen;
+ struct winsys_handle whandle;
+
+ whandle.type = DRM_API_HANDLE_TYPE_FD;
+ whandle.handle = fd;
+ whandle.offset = 0;
+ whandle.layer = 0;
+ whandle.stride = 0;
+
+ st_obj->memory = screen->memobj_create_from_handle(screen,
+ &whandle,
+ obj->Dedicated);
+
+ /* We own fd, but we no longer need it. So get rid of it */
+ close(fd);
+}
+
+void
+st_init_memoryobject_functions(struct dd_function_table *functions)
+{
+ functions->NewMemoryObject = st_memoryobj_alloc;
+ functions->DeleteMemoryObject = st_memoryobj_free;
+ functions->ImportMemoryObjectFd = st_import_memoryobj_fd;
+}
diff --git a/src/mesa/state_tracker/st_cb_memoryobjects.h b/src/mesa/state_tracker/st_cb_memoryobjects.h
new file mode 100644
index 0000000000..66065169e7
--- /dev/null
+++ b/src/mesa/state_tracker/st_cb_memoryobjects.h
@@ -0,0 +1,25 @@
+#ifndef ST_CB_MEMORYOBJECTS_H
+#define ST_CB_MEMORYOBJECTS_H
+
+#include "main/compiler.h"
+#include "main/mtypes.h"
+
+struct dd_function_table;
+struct pipe_screen;
+
+struct st_memory_object
+{
+ struct gl_memory_object Base;
+ struct pipe_memory_object *memory;
+};
+
+static inline struct st_memory_object *
+st_memory_object(struct gl_memory_object *obj)
+{
+ return (struct st_memory_object *)obj;
+}
+
+extern void
+st_init_memoryobject_functions(struct dd_function_table *functions);
+
+#endif
diff --git a/src/mesa/state_tracker/st_context.c b/src/mesa/state_tracker/st_context.c
index 381ff9dae0..2420e74363 100644
--- a/src/mesa/state_tracker/st_context.c
+++ b/src/mesa/state_tracker/st_context.c
@@ -47,20 +47,21 @@
#include "st_cb_clear.h"
#include "st_cb_compute.h"
#include "st_cb_condrender.h"
#include "st_cb_copyimage.h"
#include "st_cb_drawpixels.h"
#include "st_cb_rasterpos.h"
#include "st_cb_drawtex.h"
#include "st_cb_eglimage.h"
#include "st_cb_fbo.h"
#include "st_cb_feedback.h"
+#include "st_cb_memoryobjects.h"
#include "st_cb_msaa.h"
#include "st_cb_perfmon.h"
#include "st_cb_program.h"
#include "st_cb_queryobj.h"
#include "st_cb_readpixels.h"
#include "st_cb_texture.h"
#include "st_cb_xformfb.h"
#include "st_cb_flush.h"
#include "st_cb_syncobj.h"
#include "st_cb_strings.h"
@@ -677,20 +678,21 @@ void st_init_driver_functions(struct pipe_screen *screen,
st_init_copy_image_functions(functions);
st_init_drawpixels_functions(functions);
st_init_rasterpos_functions(functions);
st_init_drawtex_functions(functions);
st_init_eglimage_functions(functions);
st_init_fbo_functions(functions);
st_init_feedback_functions(functions);
+ st_init_memoryobject_functions(functions);
st_init_msaa_functions(functions);
st_init_perfmon_functions(functions);
st_init_program_functions(functions);
st_init_query_functions(functions);
st_init_cond_render_functions(functions);
st_init_readpixels_functions(functions);
st_init_texture_functions(functions);
st_init_texture_barrier_functions(functions);
st_init_flush_functions(screen, functions);
st_init_string_functions(functions);
--
2.13.3
More information about the mesa-dev
mailing list