mirror of
https://github.com/FunkyFr3sh/cnc-ddraw.git
synced 2025-03-25 01:57:47 +01:00
Add workaround for alt+tab issues on windows 7 SP1 (opengl)
This commit is contained in:
parent
8d97550c2b
commit
64c4b73853
98
inc/versionhelpers.h
Normal file
98
inc/versionhelpers.h
Normal file
@ -0,0 +1,98 @@
|
|||||||
|
/**
|
||||||
|
* This file is part of the mingw-w64 runtime package.
|
||||||
|
* No warranty is given; refer to the file DISCLAIMER within this package.
|
||||||
|
*/
|
||||||
|
|
||||||
|
#ifndef _INC_VERSIONHELPERS
|
||||||
|
#define _INC_VERSIONHELPERS
|
||||||
|
|
||||||
|
#if 1
|
||||||
|
|
||||||
|
#ifdef __cplusplus
|
||||||
|
#define VERSIONHELPERAPI inline bool
|
||||||
|
#else
|
||||||
|
#define VERSIONHELPERAPI FORCEINLINE BOOL
|
||||||
|
#endif
|
||||||
|
|
||||||
|
#ifndef _WIN32_WINNT_WIN8
|
||||||
|
#define _WIN32_WINNT_WIN8 0x0602
|
||||||
|
#endif
|
||||||
|
#ifndef _WIN32_WINNT_WINBLUE
|
||||||
|
#define _WIN32_WINNT_WINBLUE 0x0603
|
||||||
|
#endif
|
||||||
|
#ifndef _WIN32_WINNT_WINTHRESHOLD
|
||||||
|
#define _WIN32_WINNT_WINTHRESHOLD 0x0A00 /* ABRACADABRA_THRESHOLD*/
|
||||||
|
#endif
|
||||||
|
#ifndef _WIN32_WINNT_WIN10
|
||||||
|
#define _WIN32_WINNT_WIN10 0x0A00 /* ABRACADABRA_THRESHOLD*/
|
||||||
|
#endif
|
||||||
|
|
||||||
|
VERSIONHELPERAPI IsWindowsVersionOrGreater(WORD major, WORD minor, WORD servpack)
|
||||||
|
{
|
||||||
|
OSVERSIONINFOEXW vi = {sizeof(vi),major,minor,0,0,{0},servpack};
|
||||||
|
return VerifyVersionInfoW(&vi, VER_MAJORVERSION|VER_MINORVERSION|VER_SERVICEPACKMAJOR,
|
||||||
|
VerSetConditionMask(VerSetConditionMask(VerSetConditionMask(0,
|
||||||
|
VER_MAJORVERSION,VER_GREATER_EQUAL),
|
||||||
|
VER_MINORVERSION,VER_GREATER_EQUAL),
|
||||||
|
VER_SERVICEPACKMAJOR, VER_GREATER_EQUAL));
|
||||||
|
}
|
||||||
|
|
||||||
|
VERSIONHELPERAPI IsWindowsXPOrGreater(void) {
|
||||||
|
return IsWindowsVersionOrGreater(HIBYTE(_WIN32_WINNT_WINXP), LOBYTE(_WIN32_WINNT_WINXP), 0);
|
||||||
|
}
|
||||||
|
|
||||||
|
VERSIONHELPERAPI IsWindowsXPSP1OrGreater(void) {
|
||||||
|
return IsWindowsVersionOrGreater(HIBYTE(_WIN32_WINNT_WINXP), LOBYTE(_WIN32_WINNT_WINXP), 1);
|
||||||
|
}
|
||||||
|
|
||||||
|
VERSIONHELPERAPI IsWindowsXPSP2OrGreater(void) {
|
||||||
|
return IsWindowsVersionOrGreater(HIBYTE(_WIN32_WINNT_WINXP), LOBYTE(_WIN32_WINNT_WINXP), 2);
|
||||||
|
}
|
||||||
|
|
||||||
|
VERSIONHELPERAPI IsWindowsXPSP3OrGreater(void) {
|
||||||
|
return IsWindowsVersionOrGreater(HIBYTE(_WIN32_WINNT_WINXP), LOBYTE(_WIN32_WINNT_WINXP), 3);
|
||||||
|
}
|
||||||
|
|
||||||
|
VERSIONHELPERAPI IsWindowsVistaOrGreater(void) {
|
||||||
|
return IsWindowsVersionOrGreater(HIBYTE(_WIN32_WINNT_VISTA), LOBYTE(_WIN32_WINNT_VISTA), 0);
|
||||||
|
}
|
||||||
|
|
||||||
|
VERSIONHELPERAPI IsWindowsVistaSP1OrGreater(void) {
|
||||||
|
return IsWindowsVersionOrGreater(HIBYTE(_WIN32_WINNT_VISTA), LOBYTE(_WIN32_WINNT_VISTA), 1);
|
||||||
|
}
|
||||||
|
|
||||||
|
VERSIONHELPERAPI IsWindowsVistaSP2OrGreater(void) {
|
||||||
|
return IsWindowsVersionOrGreater(HIBYTE(_WIN32_WINNT_VISTA), LOBYTE(_WIN32_WINNT_VISTA), 2);
|
||||||
|
}
|
||||||
|
|
||||||
|
VERSIONHELPERAPI IsWindows7OrGreater(void) {
|
||||||
|
return IsWindowsVersionOrGreater(HIBYTE(_WIN32_WINNT_WIN7), LOBYTE(_WIN32_WINNT_WIN7), 0);
|
||||||
|
}
|
||||||
|
|
||||||
|
VERSIONHELPERAPI IsWindows7SP1OrGreater(void) {
|
||||||
|
return IsWindowsVersionOrGreater(HIBYTE(_WIN32_WINNT_WIN7), LOBYTE(_WIN32_WINNT_WIN7), 1);
|
||||||
|
}
|
||||||
|
|
||||||
|
VERSIONHELPERAPI IsWindows8OrGreater(void) {
|
||||||
|
return IsWindowsVersionOrGreater(HIBYTE(_WIN32_WINNT_WIN8), LOBYTE(_WIN32_WINNT_WIN8), 0);
|
||||||
|
}
|
||||||
|
|
||||||
|
VERSIONHELPERAPI IsWindows8Point1OrGreater(void) {
|
||||||
|
return IsWindowsVersionOrGreater(HIBYTE(_WIN32_WINNT_WINBLUE), LOBYTE(_WIN32_WINNT_WINBLUE), 0);
|
||||||
|
}
|
||||||
|
|
||||||
|
VERSIONHELPERAPI IsWindowsThresholdOrGreater(void) {
|
||||||
|
return IsWindowsVersionOrGreater(HIBYTE(_WIN32_WINNT_WINTHRESHOLD), LOBYTE(_WIN32_WINNT_WINTHRESHOLD), 0);
|
||||||
|
}
|
||||||
|
|
||||||
|
VERSIONHELPERAPI IsWindows10OrGreater(void) {
|
||||||
|
return IsWindowsThresholdOrGreater();
|
||||||
|
}
|
||||||
|
|
||||||
|
VERSIONHELPERAPI IsWindowsServer(void) {
|
||||||
|
OSVERSIONINFOEXW vi = {sizeof(vi),0,0,0,0,{0},0,0,0,VER_NT_WORKSTATION};
|
||||||
|
return !VerifyVersionInfoW(&vi, VER_PRODUCT_TYPE, VerSetConditionMask(0, VER_PRODUCT_TYPE, VER_EQUAL));
|
||||||
|
}
|
||||||
|
|
||||||
|
#endif
|
||||||
|
#endif
|
14
src/dd.c
14
src/dd.c
@ -14,6 +14,7 @@
|
|||||||
#include "debug.h"
|
#include "debug.h"
|
||||||
#include "utils.h"
|
#include "utils.h"
|
||||||
#include "blt.h"
|
#include "blt.h"
|
||||||
|
#include "versionhelpers.h"
|
||||||
|
|
||||||
|
|
||||||
CNCDDRAW g_ddraw;
|
CNCDDRAW g_ddraw;
|
||||||
@ -1271,8 +1272,17 @@ HRESULT dd_WaitForVerticalBlank(DWORD dwFlags, HANDLE hEvent)
|
|||||||
{
|
{
|
||||||
if (g_config.maxgameticks == -2)
|
if (g_config.maxgameticks == -2)
|
||||||
{
|
{
|
||||||
if (fpsl_dwm_flush() || fpsl_wait_for_vblank())
|
/* Workaround for DwmFlush() freeze (e.g. slow alt+tab) issue on windows 7 SP1 */
|
||||||
return DD_OK;
|
if (g_ddraw.renderer == ogl_render_main && !g_config.is_wine && !IsWindows8OrGreater())
|
||||||
|
{
|
||||||
|
if (fpsl_wait_for_vblank())
|
||||||
|
return DD_OK;
|
||||||
|
}
|
||||||
|
else
|
||||||
|
{
|
||||||
|
if (fpsl_dwm_flush() || fpsl_wait_for_vblank())
|
||||||
|
return DD_OK;
|
||||||
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
if (!g_ddraw.flip_limiter.tick_length)
|
if (!g_ddraw.flip_limiter.tick_length)
|
||||||
|
@ -4,6 +4,9 @@
|
|||||||
#include "debug.h"
|
#include "debug.h"
|
||||||
#include "hook.h"
|
#include "hook.h"
|
||||||
#include "config.h"
|
#include "config.h"
|
||||||
|
#include "render_ogl.h"
|
||||||
|
#include "versionhelpers.h"
|
||||||
|
|
||||||
|
|
||||||
FPSLIMITER g_fpsl;
|
FPSLIMITER g_fpsl;
|
||||||
|
|
||||||
@ -153,8 +156,17 @@ void fpsl_frame_end()
|
|||||||
if (g_config.maxfps < 0 ||
|
if (g_config.maxfps < 0 ||
|
||||||
(g_config.vsync && (!g_config.maxfps || g_config.maxfps >= g_ddraw.mode.dmDisplayFrequency)))
|
(g_config.vsync && (!g_config.maxfps || g_config.maxfps >= g_ddraw.mode.dmDisplayFrequency)))
|
||||||
{
|
{
|
||||||
if (fpsl_dwm_flush() || fpsl_wait_for_vblank())
|
/* Workaround for DwmFlush() freeze (e.g. slow alt+tab) issue on windows 7 SP1 */
|
||||||
return;
|
if (g_ddraw.renderer == ogl_render_main && !g_config.is_wine && !IsWindows8OrGreater())
|
||||||
|
{
|
||||||
|
if (fpsl_wait_for_vblank())
|
||||||
|
return;
|
||||||
|
}
|
||||||
|
else
|
||||||
|
{
|
||||||
|
if (fpsl_dwm_flush() || fpsl_wait_for_vblank())
|
||||||
|
return;
|
||||||
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
if (g_fpsl.tick_length > 0)
|
if (g_fpsl.tick_length > 0)
|
||||||
|
Loading…
x
Reference in New Issue
Block a user