Check OS version before going down screensaver path

This commit is contained in:
twinaphex 2016-03-04 04:51:57 +01:00
parent f86097aefb
commit 6d4212ca06

View File

@ -13,6 +13,8 @@
* If not, see <http://www.gnu.org/licenses/>.
*/
#include <retro_miscellaneous.h>
#include "../../general.h"
#include "../../verbosity.h"
#include "win32_common.h"
@ -386,19 +388,28 @@ bool win32_suppress_screensaver(void *data, bool enable)
#ifdef _XBOX
return false;
#else
if(enable)
{
int major, minor;
char tmp[PATH_MAX_LENGTH];
frontend->get_os(tmp, sizeof(tmp), &major, &minor);
if (major >= 6 && minor >= 1)
{
/* Windows 7, 8, 10 codepath */
typedef HANDLE (WINAPI * PowerCreateRequestPtr)(REASON_CONTEXT *context);
typedef BOOL (WINAPI * PowerSetRequestPtr)(HANDLE PowerRequest, POWER_REQUEST_TYPE RequestType);
typedef BOOL (WINAPI * PowerSetRequestPtr)(HANDLE PowerRequest,
POWER_REQUEST_TYPE RequestType);
HMODULE kernel32 = GetModuleHandleW(L"kernel32.dll");
PowerCreateRequestPtr powerCreateRequest =
(PowerCreateRequestPtr)GetProcAddress(kernel32, "PowerCreateRequest");
PowerSetRequestPtr powerSetRequest =
(PowerSetRequestPtr)GetProcAddress(kernel32, "PowerSetRequest");
if(enable)
{
if(powerCreateRequest && powerSetRequest)
{
/* Windows 7, 8, 10 codepath */
POWER_REQUEST_CONTEXT RequestContext;
HANDLE Request;
@ -411,6 +422,7 @@ bool win32_suppress_screensaver(void *data, bool enable)
powerSetRequest( Request, PowerRequestDisplayRequired);
return true;
}
}
else
{
/* XP / Vista codepath */