// SPDX-FileCopyrightText: 2019-2024 Connor McLaughlin // SPDX-License-Identifier: (GPL-3.0 OR CC-BY-NC-ND-4.0) #include "platform_misc.h" #include "common/error.h" #include "common/file_system.h" #include "common/log.h" #include "common/small_string.h" #include "common/string_util.h" #include #include #include #include "common/windows_headers.h" #include #include Log_SetChannel(PlatformMisc); static bool s_screensaver_suspended = false; static bool s_winsock_initialized = false; static std::once_flag s_winsock_initializer; bool PlatformMisc::InitializeSocketSupport(Error* error) { std::call_once(s_winsock_initializer, [](Error* error) { WSADATA wsa = {}; if (WSAStartup(MAKEWORD(2, 2), &wsa) != 0) { Error::SetSocket(error, "WSAStartup() failed: ", WSAGetLastError()); return false; } s_winsock_initialized = true; std::atexit([]() { WSACleanup(); }); return true; }, error); return s_winsock_initialized; } static bool SetScreensaverInhibitWin32(bool inhibit) { if (SetThreadExecutionState(ES_CONTINUOUS | (inhibit ? (ES_DISPLAY_REQUIRED | ES_SYSTEM_REQUIRED) : 0)) == NULL) { ERROR_LOG("SetThreadExecutionState() failed: {}", GetLastError()); return false; } return true; } void PlatformMisc::SuspendScreensaver() { if (s_screensaver_suspended) return; if (!SetScreensaverInhibitWin32(true)) { ERROR_LOG("Failed to suspend screensaver."); return; } s_screensaver_suspended = true; } void PlatformMisc::ResumeScreensaver() { if (!s_screensaver_suspended) return; if (!SetScreensaverInhibitWin32(false)) ERROR_LOG("Failed to resume screensaver."); s_screensaver_suspended = false; } size_t PlatformMisc::GetRuntimePageSize() { SYSTEM_INFO si = {}; GetSystemInfo(&si); return si.dwPageSize; } size_t PlatformMisc::GetRuntimeCacheLineSize() { DWORD size = 0; if (!GetLogicalProcessorInformation(nullptr, &size) && GetLastError() != ERROR_INSUFFICIENT_BUFFER) return 0; std::unique_ptr lpi = std::make_unique( (size + (sizeof(SYSTEM_LOGICAL_PROCESSOR_INFORMATION) - 1)) / sizeof(SYSTEM_LOGICAL_PROCESSOR_INFORMATION)); if (!GetLogicalProcessorInformation(lpi.get(), &size)) return 0; u32 max_line_size = 0; for (u32 i = 0; i < size / sizeof(SYSTEM_LOGICAL_PROCESSOR_INFORMATION); i++) { if (lpi[i].Relationship == RelationCache) max_line_size = std::max(max_line_size, lpi[i].Cache.LineSize); } return max_line_size; } bool PlatformMisc::PlaySoundAsync(const char* path) { const std::wstring wpath(FileSystem::GetWin32Path(path)); return PlaySoundW(wpath.c_str(), NULL, SND_ASYNC | SND_NODEFAULT); }