[PATCH v5 1/6] win32u: Add invisible winstation virtual monitor outside of nulldrv.
Rémi Bernon
wine at gitlab.winehq.org
Tue Jul 5 02:01:47 CDT 2022
From: Rémi Bernon <rbernon at codeweavers.com>
Signed-off-by: Rémi Bernon <rbernon at codeweavers.com>
---
dlls/win32u/driver.c | 1 -
dlls/win32u/sysparams.c | 37 +++++++++++++++----------------------
2 files changed, 15 insertions(+), 23 deletions(-)
diff --git a/dlls/win32u/driver.c b/dlls/win32u/driver.c
index 4a853b516f4..af6d0d610fe 100644
--- a/dlls/win32u/driver.c
+++ b/dlls/win32u/driver.c
@@ -767,7 +767,6 @@ static BOOL nulldrv_EnumDisplaySettingsEx( LPCWSTR name, DWORD num, LPDEVMODEW m
static void nulldrv_UpdateDisplayDevices( const struct gdi_device_manager *manager,
BOOL force, void *param )
{
- manager->add_monitor( NULL, param ); /* use virtual monitor */
}
static BOOL nulldrv_CreateDesktopWindow( HWND hwnd )
diff --git a/dlls/win32u/sysparams.c b/dlls/win32u/sysparams.c
index a5a69a84bd9..b63df3e3aab 100644
--- a/dlls/win32u/sysparams.c
+++ b/dlls/win32u/sysparams.c
@@ -192,8 +192,6 @@ static const WCHAR guid_devinterface_monitorW[] =
{'{','E','6','F','0','7','B','5','F','-','E','E','9','7','-','4','A','9','0','-',
'B','0','7','6','-','3','3','F','5','7','B','F','4','E','A','A','7','}',0};
-#define NULLDRV_DEFAULT_HMONITOR ((HMONITOR)(UINT_PTR)(0x10000 + 1))
-
/* Cached display device information */
struct display_device
{
@@ -233,9 +231,10 @@ static pthread_mutex_t display_lock = PTHREAD_MUTEX_INITIALIZER;
BOOL enable_thunk_lock = FALSE;
+#define VIRTUAL_HMONITOR ((HMONITOR)(UINT_PTR)(0x10000 + 1))
static struct monitor virtual_monitor =
{
- .handle = NULLDRV_DEFAULT_HMONITOR,
+ .handle = VIRTUAL_HMONITOR,
.flags = MONITORINFOF_PRIMARY,
.rc_monitor.right = 1024,
.rc_monitor.bottom = 768,
@@ -804,7 +803,6 @@ struct device_manager_ctx
WCHAR gpu_guid[64];
LUID gpu_luid;
HKEY adapter_key;
- BOOL virtual_monitor;
};
static void link_device( const WCHAR *instance, const WCHAR *class )
@@ -1078,12 +1076,6 @@ static void add_monitor( const struct gdi_monitor *monitor, void *param )
static const WCHAR default_monitorW[] =
{'M','O','N','I','T','O','R','\\','D','e','f','a','u','l','t','_','M','o','n','i','t','o','r',0,0};
- if (!monitor)
- {
- ctx->virtual_monitor = TRUE;
- return;
- }
-
TRACE( "%s %s %s\n", debugstr_w(monitor->name), wine_dbgstr_rect(&monitor->rc_monitor),
wine_dbgstr_rect(&monitor->rc_work) );
@@ -1224,12 +1216,6 @@ static void clear_display_devices(void)
struct adapter *adapter;
struct monitor *monitor;
- if (list_head( &monitors ) == &virtual_monitor.entry)
- {
- list_init( &monitors );
- return;
- }
-
while (!list_empty( &monitors ))
{
monitor = LIST_ENTRY( list_head( &monitors ), struct monitor, entry );
@@ -1319,17 +1305,24 @@ static BOOL update_display_cache_from_registry(void)
static BOOL update_display_cache(void)
{
- struct device_manager_ctx ctx = { 0 };
+ HWINSTA winstation = NtUserGetProcessWindowStation();
+ struct device_manager_ctx ctx = {0};
+ USEROBJECTFLAGS flags;
- user_driver->pUpdateDisplayDevices( &device_manager, FALSE, &ctx );
- release_display_manager_ctx( &ctx );
- if (ctx.virtual_monitor)
+ /* services do not have any adapters, only a virtual monitor */
+ if (NtUserGetObjectInformation( winstation, UOI_FLAGS, &flags, sizeof(flags), NULL )
+ && !(flags.dwFlags & WSF_VISIBLE))
{
- clear_display_devices();
- list_add_tail( &monitors, &virtual_monitor.entry );
+ pthread_mutex_lock( &display_lock );
+ if (list_empty( &monitors ))
+ list_add_tail( &monitors, &virtual_monitor.entry );
+ pthread_mutex_unlock( &display_lock );
return TRUE;
}
+ user_driver->pUpdateDisplayDevices( &device_manager, FALSE, &ctx );
+ release_display_manager_ctx( &ctx );
+
if (update_display_cache_from_registry()) return TRUE;
if (ctx.gpu_count)
{
--
GitLab
https://gitlab.winehq.org/wine/wine/-/merge_requests/355
More information about the wine-devel
mailing list