2018-08-24 17:37:59 -05:00
|
|
|
From 07121577f503da242db989c9c78cffb7a86aafd6 Mon Sep 17 00:00:00 2001
|
2015-11-15 15:47:50 +01:00
|
|
|
From: =?UTF-8?q?Michael=20M=C3=BCller?= <michael@fds-team.de>
|
|
|
|
Date: Thu, 5 Nov 2015 14:33:48 +0100
|
|
|
|
Subject: winex11.drv: Allow to select default display frequency in registry
|
|
|
|
key.
|
|
|
|
|
|
|
|
When an application doesn't request a specific display frequency, Wine
|
|
|
|
currently just picks the first one. Most of the time this is fine, but
|
|
|
|
there is no way to switch to a different frequency. This patch adds a
|
|
|
|
registry key (of type STRING) to select the default display frequency:
|
|
|
|
|
|
|
|
HKCU\Software\Wine\X11 Driver\DefaultDisplayFrequency
|
|
|
|
---
|
2018-08-24 17:37:59 -05:00
|
|
|
dlls/winex11.drv/settings.c | 58 +++++++++++++++++++++++++++---------------
|
2015-11-15 15:47:50 +01:00
|
|
|
dlls/winex11.drv/x11drv.h | 1 +
|
2018-08-24 17:37:59 -05:00
|
|
|
dlls/winex11.drv/x11drv_main.c | 4 +++
|
|
|
|
3 files changed, 43 insertions(+), 20 deletions(-)
|
2015-11-15 15:47:50 +01:00
|
|
|
|
|
|
|
diff --git a/dlls/winex11.drv/settings.c b/dlls/winex11.drv/settings.c
|
2018-08-24 17:37:59 -05:00
|
|
|
index 800b65d..fc9d29c 100644
|
2015-11-15 15:47:50 +01:00
|
|
|
--- a/dlls/winex11.drv/settings.c
|
|
|
|
+++ b/dlls/winex11.drv/settings.c
|
|
|
|
@@ -342,7 +342,7 @@ static const char * _DM_fields(DWORD fields)
|
|
|
|
LONG CDECL X11DRV_ChangeDisplaySettingsEx( LPCWSTR devname, LPDEVMODEW devmode,
|
|
|
|
HWND hwnd, DWORD flags, LPVOID lpvoid )
|
|
|
|
{
|
|
|
|
- DWORD i, dwBpp = 0;
|
|
|
|
+ DWORD i, mode, dwBpp = 0;
|
|
|
|
DEVMODEW dm;
|
|
|
|
BOOL def_mode = TRUE;
|
2018-08-24 17:37:59 -05:00
|
|
|
char bpp_buffer[16], freq_buffer[18];
|
|
|
|
@@ -388,6 +388,7 @@ LONG CDECL X11DRV_ChangeDisplaySettingsEx( LPCWSTR devname, LPDEVMODEW devmode,
|
2015-11-15 15:47:50 +01:00
|
|
|
return DISP_CHANGE_BADMODE;
|
|
|
|
}
|
|
|
|
|
|
|
|
+ mode = ENUM_CURRENT_SETTINGS;
|
|
|
|
for (i = 0; i < dd_mode_count; i++)
|
|
|
|
{
|
|
|
|
if (devmode->dmFields & DM_BITSPERPEL)
|
2018-08-24 17:37:59 -05:00
|
|
|
@@ -405,32 +406,49 @@ LONG CDECL X11DRV_ChangeDisplaySettingsEx( LPCWSTR devname, LPDEVMODEW devmode,
|
2015-11-15 15:47:50 +01:00
|
|
|
if (devmode->dmPelsHeight != dd_modes[i].height)
|
|
|
|
continue;
|
|
|
|
}
|
|
|
|
- if ((devmode->dmFields & DM_DISPLAYFREQUENCY) && (dd_modes[i].refresh_rate != 0) &&
|
|
|
|
+ if ((devmode->dmFields & DM_DISPLAYFREQUENCY) &&
|
|
|
|
devmode->dmDisplayFrequency != 0)
|
|
|
|
{
|
|
|
|
- if (devmode->dmDisplayFrequency != dd_modes[i].refresh_rate)
|
|
|
|
+ if (dd_modes[i].refresh_rate != 0 &&
|
|
|
|
+ devmode->dmDisplayFrequency != dd_modes[i].refresh_rate)
|
|
|
|
continue;
|
|
|
|
}
|
|
|
|
- /* we have a valid mode */
|
|
|
|
- TRACE("Requested display settings match mode %d (%s)\n", i, handler_name);
|
|
|
|
-
|
|
|
|
- if (flags & CDS_UPDATEREGISTRY)
|
|
|
|
- write_registry_settings(devmode);
|
|
|
|
+ else if (default_display_frequency != 0)
|
|
|
|
+ {
|
|
|
|
+ if (dd_modes[i].refresh_rate != 0 &&
|
|
|
|
+ default_display_frequency == dd_modes[i].refresh_rate)
|
|
|
|
+ {
|
|
|
|
+ TRACE("Found display mode %d with default frequency (%s)\n", i, handler_name);
|
|
|
|
+ mode = i;
|
|
|
|
+ break;
|
|
|
|
+ }
|
|
|
|
+ }
|
|
|
|
|
|
|
|
- if (!(flags & (CDS_TEST | CDS_NORESET)))
|
|
|
|
- return pSetCurrentMode(i);
|
|
|
|
+ if (mode == ENUM_CURRENT_SETTINGS)
|
|
|
|
+ mode = i;
|
|
|
|
+ }
|
|
|
|
|
|
|
|
- return DISP_CHANGE_SUCCESSFUL;
|
|
|
|
+ if (mode == ENUM_CURRENT_SETTINGS)
|
|
|
|
+ {
|
2018-08-24 17:37:59 -05:00
|
|
|
+ /* no valid modes found, only print the fields we were trying to matching against */
|
|
|
|
+ bpp_buffer[0] = freq_buffer[0] = 0;
|
|
|
|
+ if (devmode->dmFields & DM_BITSPERPEL)
|
|
|
|
+ sprintf(bpp_buffer, "bpp=%u ", devmode->dmBitsPerPel);
|
|
|
|
+ if ((devmode->dmFields & DM_DISPLAYFREQUENCY) && (devmode->dmDisplayFrequency != 0))
|
|
|
|
+ sprintf(freq_buffer, "freq=%u ", devmode->dmDisplayFrequency);
|
|
|
|
+ ERR("No matching mode found: width=%d height=%d %s%s(%s)\n",
|
|
|
|
+ devmode->dmPelsWidth, devmode->dmPelsHeight, bpp_buffer, freq_buffer, handler_name);
|
2015-11-15 15:47:50 +01:00
|
|
|
+ return DISP_CHANGE_BADMODE;
|
|
|
|
}
|
|
|
|
|
2018-08-24 17:37:59 -05:00
|
|
|
- /* no valid modes found, only print the fields we were trying to matching against */
|
|
|
|
- bpp_buffer[0] = freq_buffer[0] = 0;
|
|
|
|
- if (devmode->dmFields & DM_BITSPERPEL)
|
|
|
|
- sprintf(bpp_buffer, "bpp=%u ", devmode->dmBitsPerPel);
|
|
|
|
- if ((devmode->dmFields & DM_DISPLAYFREQUENCY) && (devmode->dmDisplayFrequency != 0))
|
|
|
|
- sprintf(freq_buffer, "freq=%u ", devmode->dmDisplayFrequency);
|
|
|
|
- ERR("No matching mode found: width=%d height=%d %s%s(%s)\n",
|
|
|
|
- devmode->dmPelsWidth, devmode->dmPelsHeight, bpp_buffer, freq_buffer, handler_name);
|
2015-11-15 15:47:50 +01:00
|
|
|
+ /* we have a valid mode */
|
|
|
|
+ TRACE("Requested display settings match mode %d (%s)\n", mode, handler_name);
|
|
|
|
+
|
|
|
|
+ if (flags & CDS_UPDATEREGISTRY)
|
|
|
|
+ write_registry_settings(devmode);
|
|
|
|
+
|
|
|
|
+ if (!(flags & (CDS_TEST | CDS_NORESET)))
|
|
|
|
+ return pSetCurrentMode(mode);
|
2018-08-24 17:37:59 -05:00
|
|
|
|
|
|
|
- return DISP_CHANGE_BADMODE;
|
2015-11-15 15:47:50 +01:00
|
|
|
+ return DISP_CHANGE_SUCCESSFUL;
|
|
|
|
}
|
|
|
|
diff --git a/dlls/winex11.drv/x11drv.h b/dlls/winex11.drv/x11drv.h
|
2018-08-24 17:37:59 -05:00
|
|
|
index a0308b0..0e932e4 100644
|
2015-11-15 15:47:50 +01:00
|
|
|
--- a/dlls/winex11.drv/x11drv.h
|
|
|
|
+++ b/dlls/winex11.drv/x11drv.h
|
2018-08-24 17:37:59 -05:00
|
|
|
@@ -400,6 +400,7 @@ extern BOOL private_color_map DECLSPEC_HIDDEN;
|
2015-11-15 15:47:50 +01:00
|
|
|
extern int primary_monitor DECLSPEC_HIDDEN;
|
|
|
|
extern int copy_default_colors DECLSPEC_HIDDEN;
|
|
|
|
extern int alloc_system_colors DECLSPEC_HIDDEN;
|
|
|
|
+extern int default_display_frequency DECLSPEC_HIDDEN;
|
|
|
|
extern int xrender_error_base DECLSPEC_HIDDEN;
|
|
|
|
extern HMODULE x11drv_module DECLSPEC_HIDDEN;
|
2017-07-18 11:29:09 +02:00
|
|
|
extern char *process_name DECLSPEC_HIDDEN;
|
2015-11-15 15:47:50 +01:00
|
|
|
diff --git a/dlls/winex11.drv/x11drv_main.c b/dlls/winex11.drv/x11drv_main.c
|
2018-08-24 17:37:59 -05:00
|
|
|
index e67a3c0..9ff285e 100644
|
2015-11-15 15:47:50 +01:00
|
|
|
--- a/dlls/winex11.drv/x11drv_main.c
|
|
|
|
+++ b/dlls/winex11.drv/x11drv_main.c
|
2017-07-18 11:29:09 +02:00
|
|
|
@@ -82,6 +82,7 @@ BOOL client_side_with_render = TRUE;
|
2015-11-15 15:47:50 +01:00
|
|
|
BOOL shape_layered_windows = TRUE;
|
|
|
|
int copy_default_colors = 128;
|
|
|
|
int alloc_system_colors = 256;
|
|
|
|
+int default_display_frequency = 0;
|
|
|
|
DWORD thread_data_tls_index = TLS_OUT_OF_INDEXES;
|
|
|
|
int xrender_error_base = 0;
|
|
|
|
HMODULE x11drv_module = 0;
|
2018-08-24 17:37:59 -05:00
|
|
|
@@ -413,6 +414,9 @@ static void setup_options(void)
|
2015-11-15 15:47:50 +01:00
|
|
|
if (!get_config_key( hkey, appkey, "AllocSystemColors", buffer, sizeof(buffer) ))
|
|
|
|
alloc_system_colors = atoi(buffer);
|
|
|
|
|
|
|
|
+ if (!get_config_key( hkey, appkey, "DefaultDisplayFrequency", buffer, sizeof(buffer) ))
|
|
|
|
+ default_display_frequency = atoi(buffer);
|
|
|
|
+
|
|
|
|
get_config_key( hkey, appkey, "InputStyle", input_style, sizeof(input_style) );
|
|
|
|
|
|
|
|
if (appkey) RegCloseKey( appkey );
|
|
|
|
--
|
2018-08-24 17:37:59 -05:00
|
|
|
2.7.4
|
2015-11-15 15:47:50 +01:00
|
|
|
|