SmartAudio/package/wayland/weston/patches/0004-weston-Add-NV21-video-...

223 lines
6.4 KiB
Diff
Raw Normal View History

2018-07-13 01:31:50 +00:00
From 20043b3c3200f541a2ae0c9a1ae2ce3db0ae8e5a Mon Sep 17 00:00:00 2001
From: dengbo <dengbo@allwinnertech.com>
Date: Fri, 12 May 2017 18:36:26 +0800
Subject: [PATCH 3/8] weston: Add NV21 video format surface tests
Add a NV21 video format surface, weston can get this video surface buffer by
dmabuf protocol, the weston will use GPU/DE to composite this surface to display
---
clients/simple-dmabuf-intel.c | 95 +++++++++++++++++++++++++++++++++++++------
configure.ac | 4 +-
2 files changed, 85 insertions(+), 14 deletions(-)
diff --git a/clients/simple-dmabuf-intel.c b/clients/simple-dmabuf-intel.c
index 67850b0..cf9eae6 100644
--- a/clients/simple-dmabuf-intel.c
+++ b/clients/simple-dmabuf-intel.c
@@ -40,7 +40,6 @@
#include <xf86drm.h>
#include <i915_drm.h>
-#include <intel_bufmgr.h>
#include <drm_fourcc.h>
#include <wayland-client.h>
@@ -64,9 +63,8 @@ struct buffer {
int busy;
int drm_fd;
+ struct drm_mode_create_dumb drm_buf;
- drm_intel_bufmgr *bufmgr;
- drm_intel_bo *bo;
uint32_t gem_handle;
int dmabuf_fd;
@@ -115,24 +113,20 @@ drm_connect(struct buffer *my_buf)
{
/* This won't work with card0 as we need to be authenticated; instead,
* boot with drm.rnodes=1 and use that. */
- my_buf->drm_fd = open("/dev/dri/renderD128", O_RDWR);
+ my_buf->drm_fd = open("/dev/dri/card0", O_RDWR);
if (my_buf->drm_fd < 0)
return 0;
- my_buf->bufmgr = drm_intel_bufmgr_gem_init(my_buf->drm_fd, 32);
- if (!my_buf->bufmgr)
- return 0;
-
return 1;
}
static void
drm_shutdown(struct buffer *my_buf)
{
- drm_intel_bufmgr_destroy(my_buf->bufmgr);
close(my_buf->drm_fd);
}
+#if 0
static int
alloc_bo(struct buffer *my_buf)
{
@@ -174,6 +168,7 @@ map_bo(struct buffer *my_buf)
return 1;
}
+#endif
static void
fill_content(struct buffer *my_buf)
@@ -192,11 +187,13 @@ fill_content(struct buffer *my_buf)
}
}
+#if 0
static void
unmap_bo(struct buffer *my_buf)
{
drm_intel_gem_bo_unmap_gtt(my_buf->bo);
}
+#endif
static void
create_succeeded(void *data,
@@ -236,12 +233,15 @@ create_dmabuf_buffer(struct display *display, struct buffer *buffer,
struct zwp_linux_buffer_params_v1 *params;
uint64_t modifier;
uint32_t flags;
+ int ret = 0;
+ struct drm_mode_map_dumb map_dumb;
if (!drm_connect(buffer)) {
fprintf(stderr, "drm_connect failed\n");
goto error;
}
+#if 0
buffer->width = width;
buffer->height = height;
buffer->bpp = 32; /* hardcoded XRGB8888 format */
@@ -287,11 +287,82 @@ create_dmabuf_buffer(struct display *display, struct buffer *buffer,
buffer->height,
DRM_FORMAT_XRGB8888,
flags);
+#endif
+
+/*
+* Create a buffer fill with NV21 format content
+*/
+ buffer->width = width;
+ buffer->height = height;
+ buffer->bpp = 8; /* hardcoded XRGB8888 format */
+ buffer->drm_buf.height = height * 3 / 2;
+ buffer->drm_buf.width = width;
+ buffer->drm_buf.bpp = buffer->bpp;
+ buffer->drm_buf.flags = 0x01; // contig memory allocate
+ buffer->drm_buf.size = width * height * 3 / 2;
+
+ if (drmIoctl(buffer->drm_fd, DRM_IOCTL_MODE_CREATE_DUMB, &buffer->drm_buf)) {
+ fprintf(stderr, "alloc_bo failed\n");
+ goto error1;
+ }
+
+ buffer->stride = buffer->drm_buf.pitch;
+ map_dumb.handle = buffer->drm_buf.handle;
+ if (drmIoctl(buffer->drm_fd, DRM_IOCTL_MODE_MAP_DUMB, &map_dumb)) {
+ fprintf(stderr,"map_bo failed\n");
+ goto error1;
+ }
+
+ buffer->mmap = mmap(NULL, buffer->drm_buf.size, PROT_READ | PROT_WRITE, MAP_SHARED,
+ buffer->drm_fd, map_dumb.offset);
+ if (!buffer->mmap) {
+ fprintf(stderr, "map_bo failed\n");
+ goto error2;
+ }
+ fill_content(buffer);
+ munmap(buffer->mmap, buffer->drm_buf.size);
+
+ if (drmPrimeHandleToFD(buffer->drm_fd, buffer->drm_buf.handle, O_RDWR, &buffer->dmabuf_fd)) {
+ fprintf(stderr, "drm_intel_bo_gem_export_to_prime failed\n");
+ goto error2;
+ }
+ if (buffer->dmabuf_fd < 0) {
+ fprintf(stderr, "error: dmabuf_fd < 0\n");
+ goto error2;
+ }
+
+ /* We now have a dmabuf! It should contain 2x2 tiles (i.e. each tile
+ * is 256x256) of misc colours, and be mappable, either as ARGB8888, or
+ * XRGB8888. */
+ modifier = 0;
+ flags = 0;
+
+ params = zwp_linux_dmabuf_v1_create_params(display->dmabuf);
+ zwp_linux_buffer_params_v1_add(params,
+ buffer->dmabuf_fd,
+ 0, /* plane_idx */
+ 0, /* offset */
+ buffer->stride,
+ modifier >> 32,
+ modifier & 0xffffffff);
+ zwp_linux_buffer_params_v1_add(params,
+ buffer->dmabuf_fd,
+ 1, /* plane_idx */
+ buffer->stride * buffer->height, /* offset */
+ buffer->stride,
+ modifier >> 32,
+ modifier & 0xffffffff);
+ zwp_linux_buffer_params_v1_add_listener(params, &params_listener, buffer);
+ zwp_linux_buffer_params_v1_create(params,
+ buffer->width,
+ buffer->height,
+ DRM_FORMAT_NV21,
+ flags);
return 0;
error2:
- free_bo(buffer);
+ //free_bo(buffer);
error1:
drm_shutdown(buffer);
error:
@@ -405,7 +476,7 @@ destroy_window(struct window *window)
continue;
wl_buffer_destroy(window->buffers[i].buffer);
- free_bo(&window->buffers[i]);
+ //free_bo(&window->buffers[i]);
close(window->buffers[i].dmabuf_fd);
drm_shutdown(&window->buffers[i]);
}
@@ -593,7 +664,7 @@ main(int argc, char **argv)
int ret = 0;
display = create_display();
- window = create_window(display, 250, 250);
+ window = create_window(display, 640, 384);
if (!window)
return 1;
diff --git a/configure.ac b/configure.ac
index a36a516..d42cc2e 100644
--- a/configure.ac
+++ b/configure.ac
@@ -381,10 +381,10 @@ AC_ARG_ENABLE(simple-dmabuf-intel-client,
[do not build the simple dmabuf intel client]),,
enable_simple_dmabuf_intel_client="auto")
if ! test "x$enable_simple_dmabuf_intel_client" = "xno"; then
- PKG_CHECK_MODULES(SIMPLE_DMABUF_INTEL_CLIENT, [wayland-client libdrm libdrm_intel],
+ PKG_CHECK_MODULES(SIMPLE_DMABUF_INTEL_CLIENT, [wayland-client libdrm],
have_simple_dmabuf_intel_client=yes, have_simple_dmabuf_intel_client=no)
if test "x$have_simple_dmabuf_intel_client" = "xno" -a "x$enable_simple_dmabuf_intel_client" = "xyes"; then
- AC_MSG_ERROR([Intel dmabuf client explicitly enabled, but libdrm_intel couldn't be found])
+ AC_MSG_ERROR([dmabuf client explicitly enabled, but dmabuf clietn couldn't be found])
fi
enable_simple_dmabuf_intel_client="$have_simple_dmabuf_intel_client"
fi
--
1.9.1