(!1654) Xnest: fetch xcb setup data
Fetching the setup data from xcb instead of Xlib, storing in our own struct, holding all information needed for one particular upstream connection. For now, there's only one, but future multi-upstream implementation will change this to an array (and storing pointers to particular upstream in various places). Signed-off-by: Enrico Weigelt, metux IT consult <info@metux.net>
This commit is contained in:
		
							parent
							
								
									165d9ee9c4
								
							
						
					
					
						commit
						42305363b2
					
				|  | @ -31,6 +31,7 @@ is" without express or implied warranty. | ||||||
| #include "servermd.h" | #include "servermd.h" | ||||||
| 
 | 
 | ||||||
| #include "Xnest.h" | #include "Xnest.h" | ||||||
|  | #include "xnest-xcb.h" | ||||||
| 
 | 
 | ||||||
| #include "Display.h" | #include "Display.h" | ||||||
| #include "Init.h" | #include "Init.h" | ||||||
|  | @ -88,8 +89,10 @@ xnestOpenDisplay(int argc, char *argv[]) | ||||||
|     if (xnestSynchronize) |     if (xnestSynchronize) | ||||||
|         XSynchronize(xnestDisplay, TRUE); |         XSynchronize(xnestDisplay, TRUE); | ||||||
| 
 | 
 | ||||||
|  |     xnest_upstream_setup(); | ||||||
|  | 
 | ||||||
|     mask = VisualScreenMask; |     mask = VisualScreenMask; | ||||||
|     vi.screen = DefaultScreen(xnestDisplay); |     vi.screen = xnestUpstreamInfo.screenId; | ||||||
|     xnestVisuals = XGetVisualInfo(xnestDisplay, mask, &vi, &xnestNumVisuals); |     xnestVisuals = XGetVisualInfo(xnestDisplay, mask, &vi, &xnestNumVisuals); | ||||||
|     if (xnestNumVisuals == 0 || xnestVisuals == NULL) |     if (xnestNumVisuals == 0 || xnestVisuals == NULL) | ||||||
|         FatalError("Unable to find any visuals.\n"); |         FatalError("Unable to find any visuals.\n"); | ||||||
|  | @ -110,8 +113,7 @@ xnestOpenDisplay(int argc, char *argv[]) | ||||||
|     } |     } | ||||||
|     else { |     else { | ||||||
|         vi.visualid = XVisualIDFromVisual(DefaultVisual(xnestDisplay, |         vi.visualid = XVisualIDFromVisual(DefaultVisual(xnestDisplay, | ||||||
|                                                         DefaultScreen |                                                         xnestUpstreamInfo.screenId)); | ||||||
|                                                         (xnestDisplay))); |  | ||||||
|         xnestDefaultVisualIndex = 0; |         xnestDefaultVisualIndex = 0; | ||||||
|         for (i = 0; i < xnestNumVisuals; i++) |         for (i = 0; i < xnestNumVisuals; i++) | ||||||
|             if (vi.visualid == xnestVisuals[i].visualid) |             if (vi.visualid == xnestVisuals[i].visualid) | ||||||
|  | @ -128,14 +130,14 @@ xnestOpenDisplay(int argc, char *argv[]) | ||||||
|                                                    xnestVisuals[i].visual, |                                                    xnestVisuals[i].visual, | ||||||
|                                                    AllocNone); |                                                    AllocNone); | ||||||
| 
 | 
 | ||||||
|     xnestDepths = XListDepths(xnestDisplay, DefaultScreen(xnestDisplay), |     xnestDepths = XListDepths(xnestDisplay, xnestUpstreamInfo.screenId, | ||||||
|                               &xnestNumDepths); |                               &xnestNumDepths); | ||||||
| 
 | 
 | ||||||
|     xnestPixmapFormats = XListPixmapFormats(xnestDisplay, |     xnestPixmapFormats = XListPixmapFormats(xnestDisplay, | ||||||
|                                             &xnestNumPixmapFormats); |                                             &xnestNumPixmapFormats); | ||||||
| 
 | 
 | ||||||
|     xnestBlackPixel = BlackPixel(xnestDisplay, DefaultScreen(xnestDisplay)); |     xnestBlackPixel = BlackPixel(xnestDisplay, xnestUpstreamInfo.screenId); | ||||||
|     xnestWhitePixel = WhitePixel(xnestDisplay, DefaultScreen(xnestDisplay)); |     xnestWhitePixel = WhitePixel(xnestDisplay, xnestUpstreamInfo.screenId); | ||||||
| 
 | 
 | ||||||
|     if (xnestParentWindow != (Window) 0) |     if (xnestParentWindow != (Window) 0) | ||||||
|         xnestEventMask = XCB_EVENT_MASK_STRUCTURE_NOTIFY; |         xnestEventMask = XCB_EVENT_MASK_STRUCTURE_NOTIFY; | ||||||
|  | @ -164,12 +166,10 @@ xnestOpenDisplay(int argc, char *argv[]) | ||||||
| 
 | 
 | ||||||
|     if (xnestParentWindow == 0) { |     if (xnestParentWindow == 0) { | ||||||
|         if (!(xnestUserGeometry & WidthValue)) |         if (!(xnestUserGeometry & WidthValue)) | ||||||
|             xnestWidth = 3 * DisplayWidth(xnestDisplay, |             xnestWidth = 3 * DisplayWidth(xnestDisplay, xnestUpstreamInfo.screenId) / 4; | ||||||
|                                           DefaultScreen(xnestDisplay)) / 4; |  | ||||||
| 
 | 
 | ||||||
|         if (!(xnestUserGeometry & HeightValue)) |         if (!(xnestUserGeometry & HeightValue)) | ||||||
|             xnestHeight = 3 * DisplayHeight(xnestDisplay, |             xnestHeight = 3 * DisplayHeight(xnestDisplay, xnestUpstreamInfo.screenId) / 4; | ||||||
|                                             DefaultScreen(xnestDisplay)) / 4; |  | ||||||
|     } |     } | ||||||
| 
 | 
 | ||||||
|     if (!xnestUserBorderWidth) |     if (!xnestUserBorderWidth) | ||||||
|  | @ -188,8 +188,7 @@ xnestOpenDisplay(int argc, char *argv[]) | ||||||
|                                     screensaver_height, |                                     screensaver_height, | ||||||
|                                     xnestWhitePixel, |                                     xnestWhitePixel, | ||||||
|                                     xnestBlackPixel, |                                     xnestBlackPixel, | ||||||
|                                     DefaultDepth(xnestDisplay, |                                     DefaultDepth(xnestDisplay, xnestUpstreamInfo.screenId)); | ||||||
|                                                  DefaultScreen(xnestDisplay))); |  | ||||||
| } | } | ||||||
| 
 | 
 | ||||||
| void | void | ||||||
|  |  | ||||||
|  | @ -30,6 +30,7 @@ is" without express or implied warranty. | ||||||
| #include "resource.h" | #include "resource.h" | ||||||
| 
 | 
 | ||||||
| #include "Xnest.h" | #include "Xnest.h" | ||||||
|  | #include "xnest-xcb.h" | ||||||
| 
 | 
 | ||||||
| #include "Display.h" | #include "Display.h" | ||||||
| #include "Screen.h" | #include "Screen.h" | ||||||
|  | @ -325,13 +326,12 @@ xnestOpenScreen(ScreenPtr pScreen, int argc, char *argv[]) | ||||||
|                   &xnestCursorFuncs); |                   &xnestCursorFuncs); | ||||||
|     PointPriv->spriteFuncs = &xnestPointerSpriteFuncs; |     PointPriv->spriteFuncs = &xnestPointerSpriteFuncs; | ||||||
| 
 | 
 | ||||||
|     pScreen->mmWidth = xnestWidth * DisplayWidthMM(xnestDisplay, |     pScreen->mmWidth = xnestWidth * DisplayWidthMM(xnestDisplay, xnestUpstreamInfo.screenId) | ||||||
|                                                    DefaultScreen(xnestDisplay)) |         / DisplayWidth(xnestDisplay, xnestUpstreamInfo.screenId); | ||||||
|         / DisplayWidth(xnestDisplay, DefaultScreen(xnestDisplay)); |  | ||||||
|     pScreen->mmHeight = |     pScreen->mmHeight = | ||||||
|         xnestHeight * DisplayHeightMM(xnestDisplay, |         xnestHeight * DisplayHeightMM(xnestDisplay, | ||||||
|                                       DefaultScreen(xnestDisplay)) / |                                       xnestUpstreamInfo.screenId) / | ||||||
|         DisplayHeight(xnestDisplay, DefaultScreen(xnestDisplay)); |         DisplayHeight(xnestDisplay, xnestUpstreamInfo.screenId); | ||||||
| 
 | 
 | ||||||
|     /* overwrite miCloseScreen with our own */ |     /* overwrite miCloseScreen with our own */ | ||||||
|     pScreen->CloseScreen = xnestCloseScreen; |     pScreen->CloseScreen = xnestCloseScreen; | ||||||
|  | @ -392,16 +392,15 @@ xnestOpenScreen(ScreenPtr pScreen, int argc, char *argv[]) | ||||||
|         valuemask = XCB_CW_BACK_PIXMAP | XCB_CW_COLORMAP; |         valuemask = XCB_CW_BACK_PIXMAP | XCB_CW_COLORMAP; | ||||||
|         attributes.background_pixmap = xnestScreenSaverPixmap; |         attributes.background_pixmap = xnestScreenSaverPixmap; | ||||||
|         attributes.colormap = |         attributes.colormap = | ||||||
|             DefaultColormap(xnestDisplay, DefaultScreen(xnestDisplay)); |             DefaultColormap(xnestDisplay, xnestUpstreamInfo.screenId); | ||||||
|         xnestScreenSaverWindows[pScreen->myNum] = |         xnestScreenSaverWindows[pScreen->myNum] = | ||||||
|             XCreateWindow(xnestDisplay, |             XCreateWindow(xnestDisplay, | ||||||
|                           xnestDefaultWindows[pScreen->myNum], |                           xnestDefaultWindows[pScreen->myNum], | ||||||
|                           0, 0, xnestWidth, xnestHeight, 0, |                           0, 0, xnestWidth, xnestHeight, 0, | ||||||
|                           DefaultDepth(xnestDisplay, |                           DefaultDepth(xnestDisplay, xnestUpstreamInfo.screenId), | ||||||
|                                        DefaultScreen(xnestDisplay)), |  | ||||||
|                           InputOutput, DefaultVisual(xnestDisplay, |                           InputOutput, DefaultVisual(xnestDisplay, | ||||||
|                                                      DefaultScreen |                                                      xnestUpstreamInfo.screenId), | ||||||
|                                                      (xnestDisplay)), valuemask, |                           valuemask, | ||||||
|                           &attributes); |                           &attributes); | ||||||
|     } |     } | ||||||
| 
 | 
 | ||||||
|  |  | ||||||
|  | @ -17,6 +17,7 @@ srcs = [ | ||||||
|     'Window.c', |     'Window.c', | ||||||
|     '../../mi/miinitext.c', |     '../../mi/miinitext.c', | ||||||
|     '../../mi/miinitext.h', |     '../../mi/miinitext.h', | ||||||
|  |     'xcb.c', | ||||||
| ] | ] | ||||||
| 
 | 
 | ||||||
| x11_xcb_dep = dependency('x11-xcb', required: true) | x11_xcb_dep = dependency('x11-xcb', required: true) | ||||||
|  |  | ||||||
|  | @ -0,0 +1,31 @@ | ||||||
|  | /* SPDX-License-Identifier: MIT OR X11
 | ||||||
|  |  * | ||||||
|  |  * Copyright © 2024 Enrico Weigelt, metux IT consult <info@metux.net> | ||||||
|  |  */ | ||||||
|  | #include <dix-config.h> | ||||||
|  | 
 | ||||||
|  | #include <xcb/xcb.h> | ||||||
|  | 
 | ||||||
|  | #include <X11/X.h> | ||||||
|  | #include <X11/Xdefs.h> | ||||||
|  | #include <X11/Xproto.h> | ||||||
|  | 
 | ||||||
|  | #include "Xnest.h" | ||||||
|  | #include "xnest-xcb.h" | ||||||
|  | 
 | ||||||
|  | #include "Display.h" | ||||||
|  | 
 | ||||||
|  | struct xnest_upstream_info xnestUpstreamInfo = { 0 }; | ||||||
|  | 
 | ||||||
|  | void xnest_upstream_setup(void) { | ||||||
|  |     xnestUpstreamInfo.screenId = DefaultScreen(xnestDisplay); | ||||||
|  | 
 | ||||||
|  |     /* retrieve setup data for our screen */ | ||||||
|  |     xnestUpstreamInfo.conn = XGetXCBConnection(xnestDisplay); | ||||||
|  |     xnestUpstreamInfo.setup = xcb_get_setup(xnestUpstreamInfo.conn); | ||||||
|  |     xcb_screen_iterator_t iter = xcb_setup_roots_iterator (xnestUpstreamInfo.setup); | ||||||
|  | 
 | ||||||
|  |     for (int i = 0; i < xnestUpstreamInfo.screenId; ++i) | ||||||
|  |         xcb_screen_next (&iter); | ||||||
|  |     xnestUpstreamInfo.screenInfo = iter.data; | ||||||
|  | } | ||||||
|  | @ -0,0 +1,22 @@ | ||||||
|  | /* SPDX-License-Identifier: MIT OR X11
 | ||||||
|  |  * | ||||||
|  |  * Copyright © 2024 Enrico Weigelt, metux IT consult <info@metux.net> | ||||||
|  |  */ | ||||||
|  | #ifndef __XNEST__XCB_H | ||||||
|  | #define __XNEST__XCB_H | ||||||
|  | 
 | ||||||
|  | #include <xcb/xcb.h> | ||||||
|  | 
 | ||||||
|  | struct xnest_upstream_info { | ||||||
|  |     xcb_connection_t *conn; | ||||||
|  |     uint32_t screenId; | ||||||
|  |     const xcb_screen_t *screenInfo; | ||||||
|  |     const xcb_setup_t *setup; | ||||||
|  | }; | ||||||
|  | 
 | ||||||
|  | extern struct xnest_upstream_info xnestUpstreamInfo; | ||||||
|  | 
 | ||||||
|  | /* fetch upstream connection's xcb setup data */ | ||||||
|  | void xnest_upstream_setup(void); | ||||||
|  | 
 | ||||||
|  | #endif /* __XNEST__XCB_H */ | ||||||
		Loading…
	
		Reference in New Issue