[vlc-commits] xcb/render: revector to use multiple picture formats

Rémi Denis-Courmont git at videolan.org
Thu Dec 20 19:43:15 CET 2018


vlc | branch: master | Rémi Denis-Courmont <remi at remlab.net> | Thu Dec 20 20:24:57 2018 +0200| [7baa877befbfba93751e0f786a459cde850dbfc4] | committer: Rémi Denis-Courmont

xcb/render: revector to use multiple picture formats

> http://git.videolan.org/gitweb.cgi/vlc.git/?a=commit;h=7baa877befbfba93751e0f786a459cde850dbfc4
---

 modules/video_output/xcb/render.c | 41 +++++++++++++++++++++------------------
 1 file changed, 22 insertions(+), 19 deletions(-)

diff --git a/modules/video_output/xcb/render.c b/modules/video_output/xcb/render.c
index 37d0651465..09bc84c8e4 100644
--- a/modules/video_output/xcb/render.c
+++ b/modules/video_output/xcb/render.c
@@ -57,11 +57,13 @@ struct vout_display_sys_t {
         xcb_render_picture_t scale;
         xcb_render_picture_t dest;
     } picture;
+    struct {
+        xcb_render_pictformat_t argb;
+    } format;
 
     xcb_gcontext_t gc;
     xcb_shm_seg_t segment;
     xcb_window_t root;
-    xcb_render_pictformat_t fmt_id;
     char *filter;
 
     vout_display_place_t place;
@@ -191,9 +193,9 @@ static void CreateBuffers(vout_display_t *vd, const vout_display_cfg_t *cfg)
     xcb_create_pixmap(conn, 32, sys->drawable.scale, sys->root,
                       cfg->display.width, cfg->display.height);
     xcb_render_create_picture(conn, sys->picture.crop, sys->drawable.crop,
-                             sys->fmt_id, 0, NULL);
-    xcb_render_create_picture(conn, sys->picture.scale,
-                              sys->drawable.scale, sys->fmt_id, 0, NULL);
+                              sys->format.argb, 0, NULL);
+    xcb_render_create_picture(conn, sys->picture.scale, sys->drawable.scale,
+                              sys->format.argb, 0, NULL);
 
     vout_display_place_t *place = &sys->place;
     vout_display_PlacePicture(place, fmt, cfg);
@@ -483,7 +485,7 @@ static int Open(vout_display_t *vd, const vout_display_cfg_t *cfg,
 
     sys->conn = conn;
     sys->root = screen->root;
-    sys->fmt_id = 0;
+    sys->format.argb = 0;
 
     if (!CheckRender(vd, conn))
         goto error;
@@ -498,13 +500,13 @@ static int Open(vout_display_t *vd, const vout_display_cfg_t *cfg,
     const xcb_setup_t *setup = xcb_get_setup(conn);
     const xcb_render_pictforminfo_t *const pic_fmts =
         xcb_render_query_pict_formats_formats(pic_fmt_r);
-    xcb_visualid_t vid = 0;
+    xcb_visualid_t visual = 0;
 
     for (unsigned i = 0; i < pic_fmt_r->num_formats; i++) {
         const xcb_render_pictforminfo_t *const pic_fmt = pic_fmts + i;
         const xcb_render_directformat_t *const d = &pic_fmt->direct;
 
-        vid = FindVisual(setup, screen, pic_fmt_r, pic_fmt->id);
+        xcb_visualid_t vid = FindVisual(setup, screen, pic_fmt_r, pic_fmt->id);
         if (vid == 0)
             continue;
 
@@ -512,24 +514,25 @@ static int Open(vout_display_t *vd, const vout_display_cfg_t *cfg,
         if (pic_fmt->depth != 32)
             continue;
 
-        fmtp->i_chroma = ParseFormat(setup, pic_fmt);
-        if (fmtp->i_chroma == 0)
+        vlc_fourcc_t chroma = ParseFormat(setup, pic_fmt);
+        if (chroma == 0)
             continue;
 
+        fmtp->i_chroma = chroma;
         fmtp->i_rmask = ((uint32_t)d->red_mask) << d->red_shift;
         fmtp->i_gmask = ((uint32_t)d->green_mask) << d->green_shift;
         fmtp->i_bmask = ((uint32_t)d->blue_mask) << d->blue_shift;
-        sys->fmt_id = pic_fmt->id;
-        break;
+        sys->format.argb = pic_fmt->id;
+        visual = vid;
     }
 
     free(pic_fmt_r);
 
-    if (sys->fmt_id == 0)
-        goto error;
+    if (unlikely(sys->format.argb == 0))
+        goto error; /* Buggy server */
 
-    msg_Dbg(obj, "using RENDER picture format %u", sys->fmt_id);
-    msg_Dbg(obj, "using X11 visual 0x%"PRIx32, vid);
+    msg_Dbg(obj, "using RENDER picture format %u", sys->format.argb);
+    msg_Dbg(obj, "using X11 visual 0x%"PRIx32, visual);
 
     char *filter = var_InheritString(obj, "x11-render-filter");
     if (filter != NULL) {
@@ -572,17 +575,17 @@ static int Open(vout_display_t *vd, const vout_display_cfg_t *cfg,
     };
 
     xcb_create_colormap(conn, XCB_COLORMAP_ALLOC_NONE, cmap, screen->root,
-                        vid);
+                        visual);
     xcb_create_pixmap(conn, 32, sys->drawable.source, screen->root,
                       vd->source.i_width, vd->source.i_height);
     xcb_create_gc(conn, sys->gc, sys->drawable.source, 0, NULL);
     xcb_create_window(conn, 32, sys->drawable.dest, cfg->window->handle.xid,
                       0, 0, cfg->display.width, cfg->display.height, 0,
-                      XCB_WINDOW_CLASS_INPUT_OUTPUT, vid, cw_mask, cw_list);
+                      XCB_WINDOW_CLASS_INPUT_OUTPUT, visual, cw_mask, cw_list);
     xcb_render_create_picture(conn, sys->picture.source, sys->drawable.source,
-                              sys->fmt_id, 0, NULL);
+                              sys->format.argb, 0, NULL);
     xcb_render_create_picture(conn, sys->picture.dest, sys->drawable.dest,
-                              sys->fmt_id, 0, NULL);
+                              sys->format.argb, 0, NULL);
     CreateBuffers(vd, cfg);
     xcb_map_window(conn, sys->drawable.dest);
 



More information about the vlc-commits mailing list