[mutter/gbsneto/dmabuf-screencast: 6/13] renderer-native: Move DMABuf creation to an auxiliary function
- From: Georges Basile Stavracas Neto <gbsneto src gnome org>
- To: commits-list gnome org
- Cc:
- Subject: [mutter/gbsneto/dmabuf-screencast: 6/13] renderer-native: Move DMABuf creation to an auxiliary function
- Date: Tue, 25 Feb 2020 01:01:31 +0000 (UTC)
commit 2a3ea7f73487c75260304543c18a36d70744f9db
Author: Georges Basile Stavracas Neto <georges stavracas gmail com>
Date: Mon Dec 9 10:04:56 2019 -0300
renderer-native: Move DMABuf creation to an auxiliary function
This will be reused by the DMA buffer exporting function.
https://gitlab.gnome.org/GNOME/mutter/merge_requests/1086
src/backends/native/meta-renderer-native.c | 149 +++++++++++++++++------------
1 file changed, 89 insertions(+), 60 deletions(-)
---
diff --git a/src/backends/native/meta-renderer-native.c b/src/backends/native/meta-renderer-native.c
index 57597ce8d..5a7fcd045 100644
--- a/src/backends/native/meta-renderer-native.c
+++ b/src/backends/native/meta-renderer-native.c
@@ -1913,9 +1913,16 @@ secondary_gpu_get_next_dumb_buffer (MetaOnscreenNativeSecondaryGpuState *seconda
return &secondary_gpu_state->cpu.dumb_fbs[0];
}
-static gboolean
-copy_shared_framebuffer_primary_gpu (CoglOnscreen *onscreen,
- MetaOnscreenNativeSecondaryGpuState *secondary_gpu_state)
+static CoglFramebuffer *
+create_dmabuf_image (CoglOnscreen *onscreen,
+ int dmabuf_fd,
+ uint32_t width,
+ uint32_t height,
+ uint32_t stride,
+ uint32_t offset,
+ uint64_t modifier,
+ uint32_t drm_format,
+ GError **error)
{
CoglFramebuffer *framebuffer = COGL_FRAMEBUFFER (onscreen);
CoglContext *cogl_context = framebuffer->context;
@@ -1927,12 +1934,7 @@ copy_shared_framebuffer_primary_gpu (CoglOnscreen *onscre
EGLDisplay egl_display = cogl_renderer_egl->edpy;
MetaRendererNative *renderer_native = onscreen_native->renderer_native;
MetaEgl *egl = meta_renderer_native_get_egl (renderer_native);
- MetaRendererNativeGpuData *primary_gpu_data;
- MetaDrmBufferDumb *buffer_dumb;
- MetaDumbBuffer *dumb_fb;
- int dmabuf_fd;
EGLImageKHR egl_image;
- g_autoptr (GError) error = NULL;
uint32_t strides[1];
uint32_t offsets[1];
uint64_t modifiers[1];
@@ -1942,93 +1944,120 @@ copy_shared_framebuffer_primary_gpu (CoglOnscreen *onscre
CoglOffscreen *cogl_fbo;
int ret;
- COGL_TRACE_BEGIN_SCOPED (CopySharedFramebufferPrimaryGpu,
- "FB Copy (primary GPU)");
-
- primary_gpu_data = meta_renderer_native_get_gpu_data (renderer_native,
- renderer_native->primary_gpu_kms);
- if (!primary_gpu_data->secondary.has_EGL_EXT_image_dma_buf_import_modifiers)
- return FALSE;
-
- dumb_fb = secondary_gpu_get_next_dumb_buffer (secondary_gpu_state);
-
- g_assert (cogl_framebuffer_get_width (framebuffer) == dumb_fb->width);
- g_assert (cogl_framebuffer_get_height (framebuffer) == dumb_fb->height);
-
- ret = cogl_pixel_format_from_drm_format (dumb_fb->drm_format,
- &cogl_format,
- NULL);
+ ret = cogl_pixel_format_from_drm_format (drm_format, &cogl_format, NULL);
g_assert (ret);
- dmabuf_fd = meta_dumb_buffer_ensure_dmabuf_fd (dumb_fb,
- secondary_gpu_state->gpu_kms);
- if (dmabuf_fd == -1)
- return FALSE;
-
- strides[0] = dumb_fb->stride_bytes;
- offsets[0] = 0;
- modifiers[0] = DRM_FORMAT_MOD_LINEAR;
+ strides[0] = stride;
+ offsets[0] = offset;
+ modifiers[0] = modifier;
egl_image = meta_egl_create_dmabuf_image (egl,
egl_display,
- dumb_fb->width,
- dumb_fb->height,
- dumb_fb->drm_format,
+ width,
+ height,
+ drm_format,
1 /* n_planes */,
&dmabuf_fd,
strides,
offsets,
modifiers,
- &error);
+ error);
if (egl_image == EGL_NO_IMAGE_KHR)
- {
- g_debug ("%s: Failed to import dumb buffer to EGL: %s",
- __func__, error->message);
-
- return FALSE;
- }
+ return NULL;
flags = COGL_EGL_IMAGE_FLAG_NO_GET_DATA;
cogl_tex = cogl_egl_texture_2d_new_from_image (cogl_context,
- dumb_fb->width,
- dumb_fb->height,
+ width,
+ height,
cogl_format,
egl_image,
flags,
- &error);
+ error);
meta_egl_destroy_image (egl, egl_display, egl_image, NULL);
if (!cogl_tex)
- {
- g_debug ("%s: Failed to make Cogl texture: %s",
- __func__, error->message);
-
- return FALSE;
- }
+ return NULL;
cogl_fbo = cogl_offscreen_new_with_texture (COGL_TEXTURE (cogl_tex));
cogl_object_unref (cogl_tex);
- if (!cogl_framebuffer_allocate (COGL_FRAMEBUFFER (cogl_fbo), &error))
+ if (!cogl_framebuffer_allocate (COGL_FRAMEBUFFER (cogl_fbo), error))
{
- g_debug ("%s: Failed Cogl FBO alloc: %s",
- __func__, error->message);
cogl_object_unref (cogl_fbo);
+ return NULL;
+ }
+
+
+ return COGL_FRAMEBUFFER (cogl_fbo);
+}
+static gboolean
+copy_shared_framebuffer_primary_gpu (CoglOnscreen *onscreen,
+ MetaOnscreenNativeSecondaryGpuState *secondary_gpu_state)
+{
+ CoglFramebuffer *framebuffer = COGL_FRAMEBUFFER (onscreen);
+ CoglOnscreenEGL *onscreen_egl = onscreen->winsys;
+ MetaOnscreenNative *onscreen_native = onscreen_egl->platform;
+ MetaRendererNative *renderer_native = onscreen_native->renderer_native;
+ MetaRendererNativeGpuData *primary_gpu_data;
+ MetaDrmBufferDumb *buffer_dumb;
+ MetaDumbBuffer *dumb_fb;
+ CoglFramebuffer *dmabuf_fb;
+ int dmabuf_fd;
+ g_autoptr (GError) error = NULL;
+ CoglPixelFormat cogl_format;
+ int ret;
+
+ COGL_TRACE_BEGIN_SCOPED (CopySharedFramebufferPrimaryGpu,
+ "FB Copy (primary GPU)");
+
+ primary_gpu_data = meta_renderer_native_get_gpu_data (renderer_native,
+ renderer_native->primary_gpu_kms);
+ if (!primary_gpu_data->secondary.has_EGL_EXT_image_dma_buf_import_modifiers)
+ return FALSE;
+
+ dumb_fb = secondary_gpu_get_next_dumb_buffer (secondary_gpu_state);
+
+ g_assert (cogl_framebuffer_get_width (framebuffer) == dumb_fb->width);
+ g_assert (cogl_framebuffer_get_height (framebuffer) == dumb_fb->height);
+
+ ret = cogl_pixel_format_from_drm_format (dumb_fb->drm_format,
+ &cogl_format,
+ NULL);
+ g_assert (ret);
+
+ dmabuf_fd = meta_dumb_buffer_ensure_dmabuf_fd (dumb_fb,
+ secondary_gpu_state->gpu_kms);
+ if (dmabuf_fd == -1)
+ return FALSE;
+
+ dmabuf_fb = create_dmabuf_image (onscreen,
+ dmabuf_fd,
+ dumb_fb->width,
+ dumb_fb->height,
+ dumb_fb->stride_bytes,
+ 0, DRM_FORMAT_MOD_LINEAR,
+ dumb_fb->drm_format,
+ &error);
+
+ if (error)
+ {
+ g_debug ("%s: Failed to blit DMA buffer image: %s",
+ G_STRFUNC, error->message);
return FALSE;
}
- if (!cogl_blit_framebuffer (framebuffer, COGL_FRAMEBUFFER (cogl_fbo),
+ if (!cogl_blit_framebuffer (framebuffer, COGL_FRAMEBUFFER (dmabuf_fb),
0, 0, 0, 0,
- dumb_fb->width, dumb_fb->height, &error))
+ dumb_fb->width,
+ dumb_fb->height,
+ &error))
{
- g_debug ("%s: Failed Cogl blit: %s", __func__, error->message);
- cogl_object_unref (cogl_fbo);
-
+ cogl_object_unref (dmabuf_fb);
return FALSE;
}
- cogl_object_unref (cogl_fbo);
+ cogl_object_unref (dmabuf_fb);
g_clear_object (&secondary_gpu_state->gbm.next_fb);
buffer_dumb = meta_drm_buffer_dumb_new (dumb_fb->fb_id);
[
Date Prev][
Date Next] [
Thread Prev][
Thread Next]
[
Thread Index]
[
Date Index]
[
Author Index]