From 73c30d87a8bb2a09017656b45a8afc2dacdf4701 Mon Sep 17 00:00:00 2001 From: DrChat Date: Tue, 22 May 2018 16:41:05 -0500 Subject: [PATCH] [App] Request high-performance timer resolution on Windows --- src/xenia/base/main_win.cc | 30 ++++++++++++++++++++++++++++++ 1 file changed, 30 insertions(+) diff --git a/src/xenia/base/main_win.cc b/src/xenia/base/main_win.cc index 2bf1a2033..2841632f5 100644 --- a/src/xenia/base/main_win.cc +++ b/src/xenia/base/main_win.cc @@ -22,6 +22,8 @@ #include "xenia/base/platform_win.h" #include "xenia/base/string.h" +#include + namespace xe { bool has_console_attached_ = true; @@ -52,9 +54,37 @@ void AttachConsole() { setvbuf(stderr, nullptr, _IONBF, 0); } +static void RequestHighPerformance() { +#if XE_PLATFORM_WIN32 + NTSTATUS(*NtQueryTimerResolution) + (OUT PULONG MinimumResolution, OUT PULONG MaximumResolution, + OUT PULONG CurrentResolution); + + NTSTATUS(*NtSetTimerResolution) + (IN ULONG DesiredResolution, IN BOOLEAN SetResolution, + OUT PULONG CurrentResolution); + + NtQueryTimerResolution = (decltype(NtQueryTimerResolution))GetProcAddress( + GetModuleHandle(L"ntdll.dll"), "NtQueryTimerResolution"); + NtSetTimerResolution = (decltype(NtSetTimerResolution))GetProcAddress( + GetModuleHandle(L"ntdll.dll"), "NtSetTimerResolution"); + if (!NtQueryTimerResolution || !NtSetTimerResolution) { + return; + } + + ULONG minimum_resolution, maximum_resolution, current_resolution; + NtQueryTimerResolution(&minimum_resolution, &maximum_resolution, + ¤t_resolution); + NtSetTimerResolution(minimum_resolution, TRUE, ¤t_resolution); +#endif +} + int Main() { auto entry_info = xe::GetEntryInfo(); + // Request high performance timing. + RequestHighPerformance(); + // Convert command line to an argv-like format so we can share code/use // gflags. auto command_line = GetCommandLineW();