Accepting request 253132 from home:lbssousa:branches:X11:XOrg
Backport upstream patches to enable Xephyr window placement via new "-output" option or new "-screen WxH+X+Y" syntax. OBS-URL: https://build.opensuse.org/request/show/253132 OBS-URL: https://build.opensuse.org/package/show/X11:XOrg/xorg-x11-server?expand=0&rev=545
This commit is contained in:
parent
4c589ba2ce
commit
e4bc356daa
392
U_ephyr_add_output_option_support.patch
Normal file
392
U_ephyr_add_output_option_support.patch
Normal file
@ -0,0 +1,392 @@
|
|||||||
|
From 3a51418b2db353519a1779cf3cebbcc9afba2520 Mon Sep 17 00:00:00 2001
|
||||||
|
From: =?UTF-8?q?La=C3=A9rcio=20de=20Sousa?=
|
||||||
|
<laerciosousa@sme-mogidascruzes.sp.gov.br>
|
||||||
|
Date: Mon, 18 Aug 2014 08:45:43 -0300
|
||||||
|
Subject: ephyr: set screen size & origin from host X server output's CRTC
|
||||||
|
geometry
|
||||||
|
MIME-Version: 1.0
|
||||||
|
Content-Type: text/plain; charset=UTF-8
|
||||||
|
Content-Transfer-Encoding: 8bit
|
||||||
|
|
||||||
|
If a given output is passed via new -output option, Xephyr will query
|
||||||
|
host X server for its info. If the following conditions are met:
|
||||||
|
|
||||||
|
a. RandR extension is enabled in host X server;
|
||||||
|
b. supported RandR version in host X server is 1.2 or newer;
|
||||||
|
c. the given output name is valid;
|
||||||
|
d. the given output is connected;
|
||||||
|
|
||||||
|
then Xephyr will get output's CRTC geometry and use it to set its own
|
||||||
|
screen size and origin. It's just like starting Xephyr in fullscreen mode,
|
||||||
|
but restricted to the given output's CRTC geometry (fake "Zaphod mode").
|
||||||
|
|
||||||
|
This is the main feature needed for Xephyr-based single-card multiseat
|
||||||
|
setups where we don't have separate screens to start Xephyr in fullscreen
|
||||||
|
mode safely.
|
||||||
|
|
||||||
|
Signed-off-by: Laércio de Sousa <laerciosousa@sme-mogidascruzes.sp.gov.br>
|
||||||
|
Reviewed-by: Keith Packard <keithp@keithp.com>
|
||||||
|
Signed-off-by: Keith Packard <keithp@keithp.com>
|
||||||
|
|
||||||
|
diff --git a/configure.ac b/configure.ac
|
||||||
|
index f3d9654..cba7d24 100644
|
||||||
|
--- a/configure.ac
|
||||||
|
+++ b/configure.ac
|
||||||
|
@@ -2364,7 +2364,7 @@ if test "$KDRIVE" = yes; then
|
||||||
|
AC_DEFINE(KDRIVE_MOUSE, 1, [Enable KDrive mouse driver])
|
||||||
|
fi
|
||||||
|
|
||||||
|
- XEPHYR_REQUIRED_LIBS="xau xdmcp xcb xcb-shape xcb-aux xcb-image xcb-icccm xcb-shm xcb-keysyms"
|
||||||
|
+ XEPHYR_REQUIRED_LIBS="xau xdmcp xcb xcb-shape xcb-aux xcb-image xcb-icccm xcb-shm xcb-keysyms xcb-randr"
|
||||||
|
if test "x$XV" = xyes; then
|
||||||
|
XEPHYR_REQUIRED_LIBS="$XEPHYR_REQUIRED_LIBS xcb-xv"
|
||||||
|
fi
|
||||||
|
diff --git a/hw/kdrive/ephyr/ephyr.c b/hw/kdrive/ephyr/ephyr.c
|
||||||
|
index b039c68..85d4193 100644
|
||||||
|
--- a/hw/kdrive/ephyr/ephyr.c
|
||||||
|
+++ b/hw/kdrive/ephyr/ephyr.c
|
||||||
|
@@ -111,13 +111,16 @@ Bool
|
||||||
|
ephyrScreenInitialize(KdScreenInfo *screen)
|
||||||
|
{
|
||||||
|
EphyrScrPriv *scrpriv = screen->driver;
|
||||||
|
+ int x = 0, y = 0;
|
||||||
|
int width = 640, height = 480;
|
||||||
|
CARD32 redMask, greenMask, blueMask;
|
||||||
|
|
||||||
|
- if (hostx_want_screen_size(screen, &width, &height)
|
||||||
|
+ if (hostx_want_screen_geometry(screen, &width, &height, &x, &y)
|
||||||
|
|| !screen->width || !screen->height) {
|
||||||
|
screen->width = width;
|
||||||
|
screen->height = height;
|
||||||
|
+ screen->x = x;
|
||||||
|
+ screen->y = y;
|
||||||
|
}
|
||||||
|
|
||||||
|
if (EphyrWantGrayScale)
|
||||||
|
diff --git a/hw/kdrive/ephyr/ephyr.h b/hw/kdrive/ephyr/ephyr.h
|
||||||
|
index 5c4936b..4e753f1 100644
|
||||||
|
--- a/hw/kdrive/ephyr/ephyr.h
|
||||||
|
+++ b/hw/kdrive/ephyr/ephyr.h
|
||||||
|
@@ -74,8 +74,10 @@ typedef struct _ephyrScrPriv {
|
||||||
|
xcb_window_t peer_win; /* Used for GL; should be at most one */
|
||||||
|
xcb_image_t *ximg;
|
||||||
|
Bool win_explicit_position;
|
||||||
|
+ int win_x, win_y;
|
||||||
|
int win_width, win_height;
|
||||||
|
int server_depth;
|
||||||
|
+ const char *output; /* Set via -output option */
|
||||||
|
unsigned char *fb_data; /* only used when host bpp != server bpp */
|
||||||
|
xcb_shm_segment_info_t shminfo;
|
||||||
|
|
||||||
|
diff --git a/hw/kdrive/ephyr/ephyrinit.c b/hw/kdrive/ephyr/ephyrinit.c
|
||||||
|
index e04c8dc..38acc52 100644
|
||||||
|
--- a/hw/kdrive/ephyr/ephyrinit.c
|
||||||
|
+++ b/hw/kdrive/ephyr/ephyrinit.c
|
||||||
|
@@ -47,6 +47,8 @@ extern KdPointerDriver LinuxEvdevMouseDriver;
|
||||||
|
extern KdKeyboardDriver LinuxEvdevKeyboardDriver;
|
||||||
|
#endif
|
||||||
|
|
||||||
|
+void processScreenOrOutputArg(const char *screen_size, const char *output, char *parent_id);
|
||||||
|
+void processOutputArg(const char *output, char *parent_id);
|
||||||
|
void processScreenArg(const char *screen_size, char *parent_id);
|
||||||
|
|
||||||
|
void
|
||||||
|
@@ -134,6 +136,7 @@ ddxUseMsg(void)
|
||||||
|
ErrorF("-parent <XID> Use existing window as Xephyr root win\n");
|
||||||
|
ErrorF("-sw-cursor Render cursors in software in Xephyr\n");
|
||||||
|
ErrorF("-fullscreen Attempt to run Xephyr fullscreen\n");
|
||||||
|
+ ErrorF("-output <NAME> Attempt to run Xephyr fullscreen (restricted to given output geometry)\n");
|
||||||
|
ErrorF("-grayscale Simulate 8bit grayscale\n");
|
||||||
|
ErrorF("-resizeable Make Xephyr windows resizeable\n");
|
||||||
|
#ifdef GLAMOR
|
||||||
|
@@ -154,7 +157,7 @@ ddxUseMsg(void)
|
||||||
|
}
|
||||||
|
|
||||||
|
void
|
||||||
|
-processScreenArg(const char *screen_size, char *parent_id)
|
||||||
|
+processScreenOrOutputArg(const char *screen_size, const char *output, char *parent_id)
|
||||||
|
{
|
||||||
|
KdCardInfo *card;
|
||||||
|
|
||||||
|
@@ -178,13 +181,25 @@ processScreenArg(const char *screen_size, char *parent_id)
|
||||||
|
|
||||||
|
use_geometry = (strchr(screen_size, '+') != NULL);
|
||||||
|
EPHYR_DBG("screen number:%d\n", screen->mynum);
|
||||||
|
- hostx_add_screen(screen, p_id, screen->mynum, use_geometry);
|
||||||
|
+ hostx_add_screen(screen, p_id, screen->mynum, use_geometry, output);
|
||||||
|
}
|
||||||
|
else {
|
||||||
|
ErrorF("No matching card found!\n");
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
+void
|
||||||
|
+processScreenArg(const char *screen_size, char *parent_id)
|
||||||
|
+{
|
||||||
|
+ processScreenOrOutputArg(screen_size, NULL, parent_id);
|
||||||
|
+}
|
||||||
|
+
|
||||||
|
+void
|
||||||
|
+processOutputArg(const char *output, char *parent_id)
|
||||||
|
+{
|
||||||
|
+ processScreenOrOutputArg("100x100+0+0", output, parent_id);
|
||||||
|
+}
|
||||||
|
+
|
||||||
|
int
|
||||||
|
ddxProcessArgument(int argc, char **argv, int i)
|
||||||
|
{
|
||||||
|
@@ -226,6 +241,15 @@ ddxProcessArgument(int argc, char **argv, int i)
|
||||||
|
UseMsg();
|
||||||
|
exit(1);
|
||||||
|
}
|
||||||
|
+ else if (!strcmp(argv[i], "-output")) {
|
||||||
|
+ if (i + 1 < argc) {
|
||||||
|
+ processOutputArg(argv[i + 1], NULL);
|
||||||
|
+ return 2;
|
||||||
|
+ }
|
||||||
|
+
|
||||||
|
+ UseMsg();
|
||||||
|
+ exit(1);
|
||||||
|
+ }
|
||||||
|
else if (!strcmp(argv[i], "-sw-cursor")) {
|
||||||
|
hostx_use_sw_cursor();
|
||||||
|
return 1;
|
||||||
|
diff --git a/hw/kdrive/ephyr/hostx.c b/hw/kdrive/ephyr/hostx.c
|
||||||
|
index 92a8ada..2161ad5 100644
|
||||||
|
--- a/hw/kdrive/ephyr/hostx.c
|
||||||
|
+++ b/hw/kdrive/ephyr/hostx.c
|
||||||
|
@@ -51,6 +51,7 @@
|
||||||
|
#include <xcb/xcb_image.h>
|
||||||
|
#include <xcb/shape.h>
|
||||||
|
#include <xcb/xcb_keysyms.h>
|
||||||
|
+#include <xcb/randr.h>
|
||||||
|
#ifdef XF86DRI
|
||||||
|
#include <xcb/xf86dri.h>
|
||||||
|
#include <xcb/glx.h>
|
||||||
|
@@ -104,12 +105,15 @@ static void
|
||||||
|
#define host_depth_matches_server(_vars) (HostX.depth == (_vars)->server_depth)
|
||||||
|
|
||||||
|
int
|
||||||
|
-hostx_want_screen_size(KdScreenInfo *screen, int *width, int *height)
|
||||||
|
+hostx_want_screen_geometry(KdScreenInfo *screen, int *width, int *height, int *x, int *y)
|
||||||
|
{
|
||||||
|
EphyrScrPriv *scrpriv = screen->driver;
|
||||||
|
|
||||||
|
if (scrpriv && (scrpriv->win_pre_existing != None ||
|
||||||
|
+ scrpriv->output != NULL ||
|
||||||
|
HostX.use_fullscreen == TRUE)) {
|
||||||
|
+ *x = scrpriv->win_x;
|
||||||
|
+ *y = scrpriv->win_y;
|
||||||
|
*width = scrpriv->win_width;
|
||||||
|
*height = scrpriv->win_height;
|
||||||
|
return 1;
|
||||||
|
@@ -119,7 +123,7 @@ hostx_want_screen_size(KdScreenInfo *screen, int *width, int *height)
|
||||||
|
}
|
||||||
|
|
||||||
|
void
|
||||||
|
-hostx_add_screen(KdScreenInfo *screen, unsigned long win_id, int screen_num, Bool use_geometry)
|
||||||
|
+hostx_add_screen(KdScreenInfo *screen, unsigned long win_id, int screen_num, Bool use_geometry, const char *output)
|
||||||
|
{
|
||||||
|
EphyrScrPriv *scrpriv = screen->driver;
|
||||||
|
int index = HostX.n_screens;
|
||||||
|
@@ -132,6 +136,7 @@ hostx_add_screen(KdScreenInfo *screen, unsigned long win_id, int screen_num, Boo
|
||||||
|
scrpriv->screen = screen;
|
||||||
|
scrpriv->win_pre_existing = win_id;
|
||||||
|
scrpriv->win_explicit_position = use_geometry;
|
||||||
|
+ scrpriv->output = output;
|
||||||
|
}
|
||||||
|
|
||||||
|
void
|
||||||
|
@@ -211,6 +216,119 @@ hostx_want_preexisting_window(KdScreenInfo *screen)
|
||||||
|
}
|
||||||
|
|
||||||
|
void
|
||||||
|
+hostx_get_output_geometry(const char *output,
|
||||||
|
+ int *x, int *y,
|
||||||
|
+ int *width, int *height)
|
||||||
|
+{
|
||||||
|
+ int i, name_len = 0, output_found = FALSE;
|
||||||
|
+ char *name = NULL;
|
||||||
|
+ xcb_generic_error_t *error;
|
||||||
|
+ xcb_randr_query_version_cookie_t version_c;
|
||||||
|
+ xcb_randr_query_version_reply_t *version_r;
|
||||||
|
+ xcb_randr_get_screen_resources_cookie_t screen_resources_c;
|
||||||
|
+ xcb_randr_get_screen_resources_reply_t *screen_resources_r;
|
||||||
|
+ xcb_randr_output_t *randr_outputs;
|
||||||
|
+ xcb_randr_get_output_info_cookie_t output_info_c;
|
||||||
|
+ xcb_randr_get_output_info_reply_t *output_info_r;
|
||||||
|
+ xcb_randr_get_crtc_info_cookie_t crtc_info_c;
|
||||||
|
+ xcb_randr_get_crtc_info_reply_t *crtc_info_r;
|
||||||
|
+
|
||||||
|
+ /* First of all, check for extension */
|
||||||
|
+ if (!xcb_get_extension_data(HostX.conn, &xcb_randr_id)->present)
|
||||||
|
+ {
|
||||||
|
+ fprintf(stderr, "\nHost X server does not support RANDR extension (or it's disabled).\n");
|
||||||
|
+ exit(1);
|
||||||
|
+ }
|
||||||
|
+
|
||||||
|
+ /* Check RandR version */
|
||||||
|
+ version_c = xcb_randr_query_version(HostX.conn, 1, 2);
|
||||||
|
+ version_r = xcb_randr_query_version_reply(HostX.conn,
|
||||||
|
+ version_c,
|
||||||
|
+ &error);
|
||||||
|
+
|
||||||
|
+ if (error != NULL || version_r == NULL)
|
||||||
|
+ {
|
||||||
|
+ fprintf(stderr, "\nFailed to get RandR version supported by host X server.\n");
|
||||||
|
+ exit(1);
|
||||||
|
+ }
|
||||||
|
+ else if (version_r->major_version < 1 || version_r->minor_version < 2)
|
||||||
|
+ {
|
||||||
|
+ free(version_r);
|
||||||
|
+ fprintf(stderr, "\nHost X server doesn't support RandR 1.2, needed for -output usage.\n");
|
||||||
|
+ exit(1);
|
||||||
|
+ }
|
||||||
|
+
|
||||||
|
+ free(version_r);
|
||||||
|
+
|
||||||
|
+ /* Get list of outputs from screen resources */
|
||||||
|
+ screen_resources_c = xcb_randr_get_screen_resources(HostX.conn,
|
||||||
|
+ HostX.winroot);
|
||||||
|
+ screen_resources_r = xcb_randr_get_screen_resources_reply(HostX.conn,
|
||||||
|
+ screen_resources_c,
|
||||||
|
+ NULL);
|
||||||
|
+ randr_outputs = xcb_randr_get_screen_resources_outputs(screen_resources_r);
|
||||||
|
+
|
||||||
|
+ for (i = 0; !output_found && i < screen_resources_r->num_outputs; i++)
|
||||||
|
+ {
|
||||||
|
+ /* Get info on the output */
|
||||||
|
+ output_info_c = xcb_randr_get_output_info(HostX.conn,
|
||||||
|
+ randr_outputs[i],
|
||||||
|
+ XCB_CURRENT_TIME);
|
||||||
|
+ output_info_r = xcb_randr_get_output_info_reply(HostX.conn,
|
||||||
|
+ output_info_c,
|
||||||
|
+ NULL);
|
||||||
|
+
|
||||||
|
+ /* Get output name */
|
||||||
|
+ name_len = xcb_randr_get_output_info_name_length(output_info_r);
|
||||||
|
+ name = malloc(name_len + 1);
|
||||||
|
+ strncpy(name, (char*)xcb_randr_get_output_info_name(output_info_r), name_len);
|
||||||
|
+ name[name_len] = '\0';
|
||||||
|
+
|
||||||
|
+ if (!strcmp(name, output))
|
||||||
|
+ {
|
||||||
|
+ output_found = TRUE;
|
||||||
|
+
|
||||||
|
+ /* Check if output is connected */
|
||||||
|
+ if (output_info_r->crtc == XCB_NONE)
|
||||||
|
+ {
|
||||||
|
+ free(name);
|
||||||
|
+ free(output_info_r);
|
||||||
|
+ free(screen_resources_r);
|
||||||
|
+ fprintf(stderr, "\nOutput %s is currently disabled (or not connected).\n", output);
|
||||||
|
+ exit(1);
|
||||||
|
+ }
|
||||||
|
+
|
||||||
|
+ /* Get CRTC from output info */
|
||||||
|
+ crtc_info_c = xcb_randr_get_crtc_info(HostX.conn,
|
||||||
|
+ output_info_r->crtc,
|
||||||
|
+ XCB_CURRENT_TIME);
|
||||||
|
+ crtc_info_r = xcb_randr_get_crtc_info_reply(HostX.conn,
|
||||||
|
+ crtc_info_c,
|
||||||
|
+ NULL);
|
||||||
|
+
|
||||||
|
+ /* Get CRTC geometry */
|
||||||
|
+ *x = crtc_info_r->x;
|
||||||
|
+ *y = crtc_info_r->y;
|
||||||
|
+ *width = crtc_info_r->width;
|
||||||
|
+ *height = crtc_info_r->height;
|
||||||
|
+
|
||||||
|
+ free(crtc_info_r);
|
||||||
|
+ }
|
||||||
|
+
|
||||||
|
+ free(name);
|
||||||
|
+ free(output_info_r);
|
||||||
|
+ }
|
||||||
|
+
|
||||||
|
+ free(screen_resources_r);
|
||||||
|
+
|
||||||
|
+ if (!output_found)
|
||||||
|
+ {
|
||||||
|
+ fprintf(stderr, "\nOutput %s not available in host X server.\n", output);
|
||||||
|
+ exit(1);
|
||||||
|
+ }
|
||||||
|
+}
|
||||||
|
+
|
||||||
|
+void
|
||||||
|
hostx_use_fullscreen(void)
|
||||||
|
{
|
||||||
|
HostX.use_fullscreen = TRUE;
|
||||||
|
@@ -359,6 +477,8 @@ hostx_init(void)
|
||||||
|
scrpriv->win = xcb_generate_id(HostX.conn);
|
||||||
|
scrpriv->server_depth = HostX.depth;
|
||||||
|
scrpriv->ximg = NULL;
|
||||||
|
+ scrpriv->win_x = 0;
|
||||||
|
+ scrpriv->win_y = 0;
|
||||||
|
|
||||||
|
if (scrpriv->win_pre_existing != XCB_WINDOW_NONE) {
|
||||||
|
xcb_get_geometry_reply_t *prewin_geom;
|
||||||
|
@@ -416,6 +536,17 @@ hostx_init(void)
|
||||||
|
|
||||||
|
hostx_set_fullscreen_hint();
|
||||||
|
}
|
||||||
|
+ else if (scrpriv->output) {
|
||||||
|
+ hostx_get_output_geometry(scrpriv->output,
|
||||||
|
+ &scrpriv->win_x,
|
||||||
|
+ &scrpriv->win_y,
|
||||||
|
+ &scrpriv->win_width,
|
||||||
|
+ &scrpriv->win_height);
|
||||||
|
+
|
||||||
|
+ HostX.use_fullscreen = TRUE;
|
||||||
|
+ hostx_set_fullscreen_hint();
|
||||||
|
+ }
|
||||||
|
+
|
||||||
|
|
||||||
|
tmpstr = getenv("RESOURCE_NAME");
|
||||||
|
if (tmpstr && (!ephyrResNameFromCmd))
|
||||||
|
@@ -759,6 +890,8 @@ hostx_screen_init(KdScreenInfo *screen,
|
||||||
|
|
||||||
|
scrpriv->win_width = width;
|
||||||
|
scrpriv->win_height = height;
|
||||||
|
+ scrpriv->win_x = x;
|
||||||
|
+ scrpriv->win_y = y;
|
||||||
|
|
||||||
|
#ifdef GLAMOR
|
||||||
|
if (ephyr_glamor) {
|
||||||
|
diff --git a/hw/kdrive/ephyr/hostx.h b/hw/kdrive/ephyr/hostx.h
|
||||||
|
index c554ca3..80894c8 100644
|
||||||
|
--- a/hw/kdrive/ephyr/hostx.h
|
||||||
|
+++ b/hw/kdrive/ephyr/hostx.h
|
||||||
|
@@ -74,7 +74,7 @@ typedef struct {
|
||||||
|
} EphyrRect;
|
||||||
|
|
||||||
|
int
|
||||||
|
-hostx_want_screen_size(KdScreenInfo *screen, int *width, int *height);
|
||||||
|
+hostx_want_screen_geometry(KdScreenInfo *screen, int *width, int *height, int *x, int *y);
|
||||||
|
|
||||||
|
int
|
||||||
|
hostx_want_host_cursor(void);
|
||||||
|
@@ -83,6 +83,11 @@ void
|
||||||
|
hostx_use_sw_cursor(void);
|
||||||
|
|
||||||
|
void
|
||||||
|
+ hostx_get_output_geometry(const char *output,
|
||||||
|
+ int *x, int *y,
|
||||||
|
+ int *width, int *height);
|
||||||
|
+
|
||||||
|
+void
|
||||||
|
hostx_use_fullscreen(void);
|
||||||
|
|
||||||
|
int
|
||||||
|
@@ -107,7 +112,7 @@ int
|
||||||
|
hostx_init(void);
|
||||||
|
|
||||||
|
void
|
||||||
|
-hostx_add_screen(KdScreenInfo *screen, unsigned long win_id, int screen_num, Bool use_geometry);
|
||||||
|
+hostx_add_screen(KdScreenInfo *screen, unsigned long win_id, int screen_num, Bool use_geometry, const char *output);
|
||||||
|
|
||||||
|
void
|
||||||
|
hostx_set_display_name(char *name);
|
||||||
|
--
|
||||||
|
cgit v0.10.2
|
||||||
|
|
156
U_ephyr_enable_screen_window_placement.patch
Normal file
156
U_ephyr_enable_screen_window_placement.patch
Normal file
@ -0,0 +1,156 @@
|
|||||||
|
From 84b02469ef97e6f85d074d220a517d752180045f Mon Sep 17 00:00:00 2001
|
||||||
|
From: =?UTF-8?q?La=C3=A9rcio=20de=20Sousa?=
|
||||||
|
<laerciosousa@sme-mogidascruzes.sp.gov.br>
|
||||||
|
Date: Mon, 18 Aug 2014 08:45:42 -0300
|
||||||
|
Subject: ephyr: enable screen window placement following kdrive -screen option
|
||||||
|
extended syntax
|
||||||
|
MIME-Version: 1.0
|
||||||
|
Content-Type: text/plain; charset=UTF-8
|
||||||
|
Content-Transfer-Encoding: 8bit
|
||||||
|
|
||||||
|
With this patch, one can launch Xephyr with option "-screen WxH+X+Y"
|
||||||
|
to place its window origin at (X,Y). This patch relies on a previous
|
||||||
|
one that extends kdrive -screen option syntax to parse +X+Y substring
|
||||||
|
as expected.
|
||||||
|
|
||||||
|
If +X+Y is not passed in -screen argument string, let the WM place
|
||||||
|
the window for us, as before.
|
||||||
|
|
||||||
|
Signed-off-by: Laércio de Sousa <laerciosousa@sme-mogidascruzes.sp.gov.br>
|
||||||
|
Reviewed-by: Keith Packard <keithp@keithp.com>
|
||||||
|
Signed-off-by: Keith Packard <keithp@keithp.com>
|
||||||
|
|
||||||
|
diff --git a/hw/kdrive/ephyr/ephyr.c b/hw/kdrive/ephyr/ephyr.c
|
||||||
|
index d57e9f3..b039c68 100644
|
||||||
|
--- a/hw/kdrive/ephyr/ephyr.c
|
||||||
|
+++ b/hw/kdrive/ephyr/ephyr.c
|
||||||
|
@@ -242,7 +242,8 @@ ephyrMapFramebuffer(KdScreenInfo * screen)
|
||||||
|
buffer_height = ephyrBufferHeight(screen);
|
||||||
|
|
||||||
|
priv->base =
|
||||||
|
- hostx_screen_init(screen, screen->width, screen->height, buffer_height,
|
||||||
|
+ hostx_screen_init(screen, screen->x, screen->y,
|
||||||
|
+ screen->width, screen->height, buffer_height,
|
||||||
|
&priv->bytes_per_line, &screen->fb.bitsPerPixel);
|
||||||
|
|
||||||
|
if ((scrpriv->randr & RR_Rotate_0) && !(scrpriv->randr & RR_Reflect_All)) {
|
||||||
|
diff --git a/hw/kdrive/ephyr/ephyr.h b/hw/kdrive/ephyr/ephyr.h
|
||||||
|
index dfd93c9..5c4936b 100644
|
||||||
|
--- a/hw/kdrive/ephyr/ephyr.h
|
||||||
|
+++ b/hw/kdrive/ephyr/ephyr.h
|
||||||
|
@@ -73,6 +73,7 @@ typedef struct _ephyrScrPriv {
|
||||||
|
xcb_window_t win_pre_existing; /* Set via -parent option like xnest */
|
||||||
|
xcb_window_t peer_win; /* Used for GL; should be at most one */
|
||||||
|
xcb_image_t *ximg;
|
||||||
|
+ Bool win_explicit_position;
|
||||||
|
int win_width, win_height;
|
||||||
|
int server_depth;
|
||||||
|
unsigned char *fb_data; /* only used when host bpp != server bpp */
|
||||||
|
diff --git a/hw/kdrive/ephyr/ephyrinit.c b/hw/kdrive/ephyr/ephyrinit.c
|
||||||
|
index fc00010..e04c8dc 100644
|
||||||
|
--- a/hw/kdrive/ephyr/ephyrinit.c
|
||||||
|
+++ b/hw/kdrive/ephyr/ephyrinit.c
|
||||||
|
@@ -164,6 +164,7 @@ processScreenArg(const char *screen_size, char *parent_id)
|
||||||
|
if (card) {
|
||||||
|
KdScreenInfo *screen;
|
||||||
|
unsigned long p_id = 0;
|
||||||
|
+ Bool use_geometry;
|
||||||
|
|
||||||
|
screen = KdScreenInfoAdd(card);
|
||||||
|
KdParseScreen(screen, screen_size);
|
||||||
|
@@ -174,8 +175,10 @@ processScreenArg(const char *screen_size, char *parent_id)
|
||||||
|
if (parent_id) {
|
||||||
|
p_id = strtol(parent_id, NULL, 0);
|
||||||
|
}
|
||||||
|
+
|
||||||
|
+ use_geometry = (strchr(screen_size, '+') != NULL);
|
||||||
|
EPHYR_DBG("screen number:%d\n", screen->mynum);
|
||||||
|
- hostx_add_screen(screen, p_id, screen->mynum);
|
||||||
|
+ hostx_add_screen(screen, p_id, screen->mynum, use_geometry);
|
||||||
|
}
|
||||||
|
else {
|
||||||
|
ErrorF("No matching card found!\n");
|
||||||
|
diff --git a/hw/kdrive/ephyr/hostx.c b/hw/kdrive/ephyr/hostx.c
|
||||||
|
index 1c75974..92a8ada 100644
|
||||||
|
--- a/hw/kdrive/ephyr/hostx.c
|
||||||
|
+++ b/hw/kdrive/ephyr/hostx.c
|
||||||
|
@@ -119,7 +119,7 @@ hostx_want_screen_size(KdScreenInfo *screen, int *width, int *height)
|
||||||
|
}
|
||||||
|
|
||||||
|
void
|
||||||
|
-hostx_add_screen(KdScreenInfo *screen, unsigned long win_id, int screen_num)
|
||||||
|
+hostx_add_screen(KdScreenInfo *screen, unsigned long win_id, int screen_num, Bool use_geometry)
|
||||||
|
{
|
||||||
|
EphyrScrPriv *scrpriv = screen->driver;
|
||||||
|
int index = HostX.n_screens;
|
||||||
|
@@ -131,6 +131,7 @@ hostx_add_screen(KdScreenInfo *screen, unsigned long win_id, int screen_num)
|
||||||
|
|
||||||
|
scrpriv->screen = screen;
|
||||||
|
scrpriv->win_pre_existing = win_id;
|
||||||
|
+ scrpriv->win_explicit_position = use_geometry;
|
||||||
|
}
|
||||||
|
|
||||||
|
void
|
||||||
|
@@ -637,6 +638,7 @@ hostx_set_cmap_entry(unsigned char idx,
|
||||||
|
*/
|
||||||
|
void *
|
||||||
|
hostx_screen_init(KdScreenInfo *screen,
|
||||||
|
+ int x, int y,
|
||||||
|
int width, int height, int buffer_height,
|
||||||
|
int *bytes_per_line, int *bits_per_pixel)
|
||||||
|
{
|
||||||
|
@@ -648,8 +650,8 @@ hostx_screen_init(KdScreenInfo *screen,
|
||||||
|
exit(1);
|
||||||
|
}
|
||||||
|
|
||||||
|
- EPHYR_DBG("host_screen=%p wxh=%dx%d, buffer_height=%d",
|
||||||
|
- host_screen, width, height, buffer_height);
|
||||||
|
+ EPHYR_DBG("host_screen=%p x=%d, y=%d, wxh=%dx%d, buffer_height=%d",
|
||||||
|
+ host_screen, x, y, width, height, buffer_height);
|
||||||
|
|
||||||
|
if (scrpriv->ximg != NULL) {
|
||||||
|
/* Free up the image data if previously used
|
||||||
|
@@ -740,6 +742,19 @@ hostx_screen_init(KdScreenInfo *screen,
|
||||||
|
|
||||||
|
xcb_map_window(HostX.conn, scrpriv->win);
|
||||||
|
|
||||||
|
+ /* Set explicit window position if it was informed in
|
||||||
|
+ * -screen option (WxH+X or WxH+X+Y). Otherwise, accept the
|
||||||
|
+ * position set by WM.
|
||||||
|
+ * The trick here is putting this code after xcb_map_window() call,
|
||||||
|
+ * so these values won't be overriden by WM. */
|
||||||
|
+ if (scrpriv->win_explicit_position)
|
||||||
|
+ {
|
||||||
|
+ uint32_t mask = XCB_CONFIG_WINDOW_X | XCB_CONFIG_WINDOW_Y;
|
||||||
|
+ uint32_t values[2] = {x, y};
|
||||||
|
+ xcb_configure_window(HostX.conn, scrpriv->win, mask, values);
|
||||||
|
+ }
|
||||||
|
+
|
||||||
|
+
|
||||||
|
xcb_aux_sync(HostX.conn);
|
||||||
|
|
||||||
|
scrpriv->win_width = width;
|
||||||
|
diff --git a/hw/kdrive/ephyr/hostx.h b/hw/kdrive/ephyr/hostx.h
|
||||||
|
index e83323a..c554ca3 100644
|
||||||
|
--- a/hw/kdrive/ephyr/hostx.h
|
||||||
|
+++ b/hw/kdrive/ephyr/hostx.h
|
||||||
|
@@ -107,7 +107,7 @@ int
|
||||||
|
hostx_init(void);
|
||||||
|
|
||||||
|
void
|
||||||
|
-hostx_add_screen(KdScreenInfo *screen, unsigned long win_id, int screen_num);
|
||||||
|
+hostx_add_screen(KdScreenInfo *screen, unsigned long win_id, int screen_num, Bool use_geometry);
|
||||||
|
|
||||||
|
void
|
||||||
|
hostx_set_display_name(char *name);
|
||||||
|
@@ -136,6 +136,7 @@ hostx_set_cmap_entry(unsigned char idx,
|
||||||
|
unsigned char r, unsigned char g, unsigned char b);
|
||||||
|
|
||||||
|
void *hostx_screen_init(KdScreenInfo *screen,
|
||||||
|
+ int x, int y,
|
||||||
|
int width, int height, int buffer_height,
|
||||||
|
int *bytes_per_line, int *bits_per_pixel);
|
||||||
|
|
||||||
|
--
|
||||||
|
cgit v0.10.2
|
||||||
|
|
108
U_kdrive_extend_screen_option_syntax.patch
Normal file
108
U_kdrive_extend_screen_option_syntax.patch
Normal file
@ -0,0 +1,108 @@
|
|||||||
|
From 376f4de8ae927748417046390c24afbda24b0583 Mon Sep 17 00:00:00 2001
|
||||||
|
From: =?UTF-8?q?La=C3=A9rcio=20de=20Sousa?=
|
||||||
|
<laerciosousa@sme-mogidascruzes.sp.gov.br>
|
||||||
|
Date: Mon, 18 Aug 2014 08:45:41 -0300
|
||||||
|
Subject: kdrive: add support to +X+Y syntax in -screen option parsing
|
||||||
|
MIME-Version: 1.0
|
||||||
|
Content-Type: text/plain; charset=UTF-8
|
||||||
|
Content-Transfer-Encoding: 8bit
|
||||||
|
|
||||||
|
This patch enhances current -screen option parsing for kdrive-based
|
||||||
|
applications. It can parse strings like
|
||||||
|
<WIDTH>x<HEIGHT>+<XOFFSET>+<YOFFSET>, storing X and Y offsets
|
||||||
|
in KdScreenInfo instances.
|
||||||
|
|
||||||
|
For negative values, this patch supports +-X+-Y (not -X-Y) syntax.
|
||||||
|
|
||||||
|
It will allow e.g. proper Xephyr window placement for multiseat
|
||||||
|
purposes.
|
||||||
|
|
||||||
|
Signed-off-by: Laércio de Sousa <laerciosousa@sme-mogidascruzes.sp.gov.br>
|
||||||
|
Reviewed-by: Keith Packard <keithp@keithp.com>
|
||||||
|
Signed-off-by: Keith Packard <keithp@keithp.com>
|
||||||
|
|
||||||
|
diff --git a/hw/kdrive/src/kdrive.c b/hw/kdrive/src/kdrive.c
|
||||||
|
index b5b91c0..5dbff3f 100644
|
||||||
|
--- a/hw/kdrive/src/kdrive.c
|
||||||
|
+++ b/hw/kdrive/src/kdrive.c
|
||||||
|
@@ -300,6 +300,8 @@ KdParseScreen(KdScreenInfo * screen, const char *arg)
|
||||||
|
screen->softCursor = kdSoftCursor;
|
||||||
|
screen->origin = kdOrigin;
|
||||||
|
screen->randr = RR_Rotate_0;
|
||||||
|
+ screen->x = 0;
|
||||||
|
+ screen->y = 0;
|
||||||
|
screen->width = 0;
|
||||||
|
screen->height = 0;
|
||||||
|
screen->width_mm = 0;
|
||||||
|
@@ -313,7 +315,7 @@ KdParseScreen(KdScreenInfo * screen, const char *arg)
|
||||||
|
return;
|
||||||
|
|
||||||
|
for (i = 0; i < 2; i++) {
|
||||||
|
- arg = KdParseFindNext(arg, "x/@XY", save, &delim);
|
||||||
|
+ arg = KdParseFindNext(arg, "x/+@XY", save, &delim);
|
||||||
|
if (!save[0])
|
||||||
|
return;
|
||||||
|
|
||||||
|
@@ -321,7 +323,7 @@ KdParseScreen(KdScreenInfo * screen, const char *arg)
|
||||||
|
mm = 0;
|
||||||
|
|
||||||
|
if (delim == '/') {
|
||||||
|
- arg = KdParseFindNext(arg, "x@XY", save, &delim);
|
||||||
|
+ arg = KdParseFindNext(arg, "x+@XY", save, &delim);
|
||||||
|
if (!save[0])
|
||||||
|
return;
|
||||||
|
mm = atoi(save);
|
||||||
|
@@ -335,7 +337,8 @@ KdParseScreen(KdScreenInfo * screen, const char *arg)
|
||||||
|
screen->height = pixels;
|
||||||
|
screen->height_mm = mm;
|
||||||
|
}
|
||||||
|
- if (delim != 'x' && delim != '@' && delim != 'X' && delim != 'Y' &&
|
||||||
|
+ if (delim != 'x' && delim != '+' && delim != '@' &&
|
||||||
|
+ delim != 'X' && delim != 'Y' &&
|
||||||
|
(delim != '\0' || i == 0))
|
||||||
|
return;
|
||||||
|
}
|
||||||
|
@@ -346,6 +349,18 @@ KdParseScreen(KdScreenInfo * screen, const char *arg)
|
||||||
|
kdSoftCursor = FALSE;
|
||||||
|
kdSubpixelOrder = SubPixelUnknown;
|
||||||
|
|
||||||
|
+ if (delim == '+') {
|
||||||
|
+ arg = KdParseFindNext(arg, "+@xXY", save, &delim);
|
||||||
|
+ if (save[0])
|
||||||
|
+ screen->x = atoi(save);
|
||||||
|
+ }
|
||||||
|
+
|
||||||
|
+ if (delim == '+') {
|
||||||
|
+ arg = KdParseFindNext(arg, "@xXY", save, &delim);
|
||||||
|
+ if (save[0])
|
||||||
|
+ screen->y = atoi(save);
|
||||||
|
+ }
|
||||||
|
+
|
||||||
|
if (delim == '@') {
|
||||||
|
arg = KdParseFindNext(arg, "xXY", save, &delim);
|
||||||
|
if (save[0]) {
|
||||||
|
@@ -425,7 +440,7 @@ KdUseMsg(void)
|
||||||
|
{
|
||||||
|
ErrorF("\nTinyX Device Dependent Usage:\n");
|
||||||
|
ErrorF
|
||||||
|
- ("-screen WIDTH[/WIDTHMM]xHEIGHT[/HEIGHTMM][@ROTATION][X][Y][xDEPTH/BPP[xFREQ]] Specify screen characteristics\n");
|
||||||
|
+ ("-screen WIDTH[/WIDTHMM]xHEIGHT[/HEIGHTMM][+[-]XOFFSET][+[-]YOFFSET][@ROTATION][X][Y][xDEPTH/BPP[xFREQ]] Specify screen characteristics\n");
|
||||||
|
ErrorF
|
||||||
|
("-rgba rgb/bgr/vrgb/vbgr/none Specify subpixel ordering for LCD panels\n");
|
||||||
|
ErrorF
|
||||||
|
diff --git a/hw/kdrive/src/kdrive.h b/hw/kdrive/src/kdrive.h
|
||||||
|
index 08b1681..066a134 100644
|
||||||
|
--- a/hw/kdrive/src/kdrive.h
|
||||||
|
+++ b/hw/kdrive/src/kdrive.h
|
||||||
|
@@ -89,6 +89,8 @@ typedef struct _KdScreenInfo {
|
||||||
|
ScreenPtr pScreen;
|
||||||
|
void *driver;
|
||||||
|
Rotation randr; /* rotation and reflection */
|
||||||
|
+ int x;
|
||||||
|
+ int y;
|
||||||
|
int width;
|
||||||
|
int height;
|
||||||
|
int rate;
|
||||||
|
--
|
||||||
|
cgit v0.10.2
|
||||||
|
|
@ -1,3 +1,9 @@
|
|||||||
|
-------------------------------------------------------------------
|
||||||
|
Mon Sep 29 14:53:45 UTC 2014 - lbsousajr@gmail.com
|
||||||
|
|
||||||
|
- Backport upstream patches to enable Xephyr window placement
|
||||||
|
via new "-output" option or new "-screen WxH+X+Y" syntax.
|
||||||
|
|
||||||
-------------------------------------------------------------------
|
-------------------------------------------------------------------
|
||||||
Sun Sep 21 17:31:53 UTC 2014 - tobias.johannes.klausmann@mni.thm.de
|
Sun Sep 21 17:31:53 UTC 2014 - tobias.johannes.klausmann@mni.thm.de
|
||||||
|
|
||||||
|
@ -164,6 +164,10 @@ Patch1162: b_cache-xkbcomp-output-for-fast-start-up.patch
|
|||||||
Patch1211: b_0001-Prevent-XSync-Alarms-from-senslessly-calling-CheckTr.patch
|
Patch1211: b_0001-Prevent-XSync-Alarms-from-senslessly-calling-CheckTr.patch
|
||||||
Patch1222: b_sync-fix.patch
|
Patch1222: b_sync-fix.patch
|
||||||
|
|
||||||
|
Patch200: U_kdrive_extend_screen_option_syntax.patch
|
||||||
|
Patch201: U_ephyr_enable_screen_window_placement.patch
|
||||||
|
Patch202: U_ephyr_add_output_option_support.patch
|
||||||
|
|
||||||
%description
|
%description
|
||||||
This package contains the X.Org Server.
|
This package contains the X.Org Server.
|
||||||
|
|
||||||
@ -248,6 +252,10 @@ cp %{SOURCE90} .
|
|||||||
### patch222 might not be applicable anymore
|
### patch222 might not be applicable anymore
|
||||||
#%patch1222 -p1
|
#%patch1222 -p1
|
||||||
|
|
||||||
|
%patch200 -p1
|
||||||
|
%patch201 -p1
|
||||||
|
%patch202 -p1
|
||||||
|
|
||||||
%build
|
%build
|
||||||
autoreconf -fi
|
autoreconf -fi
|
||||||
%configure CFLAGS="%{optflags} -fno-strict-aliasing" \
|
%configure CFLAGS="%{optflags} -fno-strict-aliasing" \
|
||||||
|
Loading…
Reference in New Issue
Block a user