2018-03-23 22:55:13 +08:00
|
|
|
/*
|
2023-04-25 04:45:11 +08:00
|
|
|
* Copyright (C) 2018-2023 Intel Corporation
|
2018-03-23 22:55:13 +08:00
|
|
|
*
|
2018-09-18 15:11:08 +08:00
|
|
|
* SPDX-License-Identifier: MIT
|
2018-03-23 22:55:13 +08:00
|
|
|
*
|
|
|
|
*/
|
|
|
|
|
2020-02-24 05:44:01 +08:00
|
|
|
#include "shared/source/os_interface/windows/sys_calls.h"
|
2018-03-23 22:55:13 +08:00
|
|
|
|
2023-04-25 04:45:11 +08:00
|
|
|
#include <cstdlib>
|
2023-04-27 16:42:36 +08:00
|
|
|
#include <string>
|
2023-04-25 04:45:11 +08:00
|
|
|
|
2019-03-26 18:59:46 +08:00
|
|
|
namespace NEO {
|
2018-03-23 22:55:13 +08:00
|
|
|
|
2021-05-27 05:45:38 +08:00
|
|
|
unsigned int getPid() {
|
|
|
|
return GetCurrentProcessId();
|
|
|
|
}
|
|
|
|
|
|
|
|
bool isShutdownInProgress() {
|
|
|
|
auto handle = GetModuleHandleA("ntdll.dll");
|
|
|
|
|
|
|
|
if (!handle) {
|
|
|
|
return true;
|
|
|
|
}
|
|
|
|
|
2023-10-30 22:49:49 +08:00
|
|
|
auto rtlDllShutdownInProgress = reinterpret_cast<BOOLEAN(WINAPI *)()>(GetProcAddress(handle, "RtlDllShutdownInProgress"));
|
|
|
|
return rtlDllShutdownInProgress();
|
2021-05-27 05:45:38 +08:00
|
|
|
}
|
|
|
|
|
2018-03-23 22:55:13 +08:00
|
|
|
namespace SysCalls {
|
2023-04-25 04:45:11 +08:00
|
|
|
void exit(int code) {
|
|
|
|
std::exit(code);
|
|
|
|
}
|
2018-03-23 22:55:13 +08:00
|
|
|
|
2021-07-09 01:19:43 +08:00
|
|
|
unsigned int getProcessId() {
|
|
|
|
return GetCurrentProcessId();
|
|
|
|
}
|
|
|
|
|
2022-10-06 20:21:52 +08:00
|
|
|
unsigned long getNumThreads() {
|
|
|
|
return 1;
|
|
|
|
}
|
|
|
|
|
2023-08-22 18:28:03 +08:00
|
|
|
DWORD getLastError() {
|
|
|
|
return GetLastError();
|
|
|
|
}
|
|
|
|
|
2023-04-27 16:42:36 +08:00
|
|
|
bool pathExists(const std::string &path) {
|
|
|
|
DWORD ret = GetFileAttributesA(path.c_str());
|
|
|
|
|
|
|
|
return ret == FILE_ATTRIBUTE_DIRECTORY;
|
|
|
|
}
|
|
|
|
|
2018-03-23 22:55:13 +08:00
|
|
|
HANDLE createEvent(LPSECURITY_ATTRIBUTES lpEventAttributes, BOOL bManualReset, BOOL bInitialState, LPCSTR lpName) {
|
|
|
|
return CreateEventA(lpEventAttributes, bManualReset, bInitialState, lpName);
|
|
|
|
}
|
|
|
|
|
|
|
|
BOOL closeHandle(HANDLE hObject) {
|
|
|
|
return CloseHandle(hObject);
|
|
|
|
}
|
|
|
|
|
2018-04-10 16:26:59 +08:00
|
|
|
BOOL getSystemPowerStatus(LPSYSTEM_POWER_STATUS systemPowerStatusPtr) {
|
|
|
|
return GetSystemPowerStatus(systemPowerStatusPtr);
|
|
|
|
}
|
2019-10-03 21:33:18 +08:00
|
|
|
BOOL getModuleHandle(DWORD dwFlags, LPCWSTR lpModuleName, HMODULE *phModule) {
|
|
|
|
return GetModuleHandleEx(dwFlags, lpModuleName, phModule);
|
|
|
|
}
|
|
|
|
DWORD getModuleFileName(HMODULE hModule, LPWSTR lpFilename, DWORD nSize) {
|
|
|
|
return GetModuleFileName(hModule, lpFilename, nSize);
|
|
|
|
}
|
2021-10-05 19:21:46 +08:00
|
|
|
|
2023-08-22 18:28:03 +08:00
|
|
|
UINT getTempFileNameA(LPCSTR lpPathName, LPCSTR lpPrefixString, UINT uUnique, LPSTR lpTempFileName) {
|
|
|
|
return GetTempFileNameA(lpPathName, lpPrefixString, uUnique, lpTempFileName);
|
|
|
|
}
|
|
|
|
|
|
|
|
BOOL moveFileExA(LPCSTR lpExistingFileName, LPCSTR lpNewFileName, DWORD dwFlags) {
|
|
|
|
return MoveFileExA(lpExistingFileName, lpNewFileName, dwFlags);
|
|
|
|
}
|
|
|
|
|
|
|
|
BOOL lockFileEx(HANDLE hFile, DWORD dwFlags, DWORD dwReserved, DWORD nNumberOfBytesToLockLow, DWORD nNumberOfBytesToLockHigh, LPOVERLAPPED lpOverlapped) {
|
|
|
|
return LockFileEx(hFile, dwFlags, dwReserved, nNumberOfBytesToLockLow, nNumberOfBytesToLockHigh, lpOverlapped);
|
|
|
|
}
|
|
|
|
|
|
|
|
BOOL unlockFileEx(HANDLE hFile, DWORD dwReserved, DWORD nNumberOfBytesToLockLow, DWORD nNumberOfBytesToLockHigh, LPOVERLAPPED lpOverlapped) {
|
|
|
|
return UnlockFileEx(hFile, dwReserved, nNumberOfBytesToLockLow, nNumberOfBytesToLockHigh, lpOverlapped);
|
|
|
|
}
|
|
|
|
|
|
|
|
BOOL getOverlappedResult(HANDLE hFile, LPOVERLAPPED lpOverlapped, LPDWORD lpNumberOfBytesTransferred, BOOL bWait) {
|
|
|
|
return GetOverlappedResult(hFile, lpOverlapped, lpNumberOfBytesTransferred, bWait);
|
|
|
|
}
|
|
|
|
|
2023-09-08 19:22:54 +08:00
|
|
|
BOOL createDirectoryA(LPCSTR lpPathName, LPSECURITY_ATTRIBUTES lpSecurityAttributes) {
|
|
|
|
return CreateDirectoryA(lpPathName, lpSecurityAttributes);
|
|
|
|
}
|
|
|
|
|
2023-08-22 18:28:03 +08:00
|
|
|
HANDLE createFileA(LPCSTR lpFileName, DWORD dwDesiredAccess, DWORD dwShareMode, LPSECURITY_ATTRIBUTES lpSecurityAttributes, DWORD dwCreationDisposition, DWORD dwFlagsAndAttributes, HANDLE hTemplateFile) {
|
|
|
|
return CreateFileA(lpFileName, dwDesiredAccess, dwShareMode, lpSecurityAttributes, dwCreationDisposition, dwFlagsAndAttributes, hTemplateFile);
|
|
|
|
}
|
|
|
|
|
|
|
|
BOOL deleteFileA(LPCSTR lpFileName) {
|
|
|
|
return DeleteFileA(lpFileName);
|
|
|
|
}
|
|
|
|
|
2023-09-08 19:22:54 +08:00
|
|
|
HRESULT shGetKnownFolderPath(REFKNOWNFOLDERID rfid, DWORD dwFlags, HANDLE hToken, PWSTR *ppszPat) {
|
|
|
|
return SHGetKnownFolderPath(rfid, dwFlags, hToken, ppszPat);
|
|
|
|
}
|
|
|
|
|
2023-10-02 17:35:55 +08:00
|
|
|
BOOL readFile(HANDLE hFile, LPVOID lpBuffer, DWORD nNumberOfBytesToRead, LPDWORD lpNumberOfBytesRead, LPOVERLAPPED lpOverlapped) {
|
|
|
|
return ReadFile(hFile, lpBuffer, nNumberOfBytesToRead, lpNumberOfBytesRead, lpOverlapped);
|
2023-08-22 18:28:03 +08:00
|
|
|
}
|
|
|
|
|
|
|
|
BOOL writeFile(HANDLE hFile, LPCVOID lpBuffer, DWORD nNumberOfBytesToWrite, LPDWORD lpNumberOfBytesWritten, LPOVERLAPPED lpOverlapped) {
|
|
|
|
return WriteFile(hFile, lpBuffer, nNumberOfBytesToWrite, lpNumberOfBytesWritten, lpOverlapped);
|
|
|
|
}
|
|
|
|
|
|
|
|
HANDLE findFirstFileA(LPCSTR lpFileName, LPWIN32_FIND_DATAA lpFindFileData) {
|
|
|
|
return FindFirstFileA(lpFileName, lpFindFileData);
|
|
|
|
}
|
|
|
|
|
|
|
|
BOOL findNextFileA(HANDLE hFindFile, LPWIN32_FIND_DATAA lpFindFileData) {
|
|
|
|
return FindNextFileA(hFindFile, lpFindFileData);
|
|
|
|
}
|
|
|
|
|
|
|
|
BOOL findClose(HANDLE hFindFile) {
|
|
|
|
return FindClose(hFindFile);
|
|
|
|
}
|
|
|
|
|
|
|
|
DWORD getFileAttributesA(LPCSTR lpFileName) {
|
|
|
|
return GetFileAttributesA(lpFileName);
|
|
|
|
}
|
|
|
|
|
2023-10-02 17:35:55 +08:00
|
|
|
DWORD setFilePointer(HANDLE hFile, LONG lDistanceToMove, PLONG lpDistanceToMoveHigh, DWORD dwMoveMethod) {
|
|
|
|
return SetFilePointer(hFile, lDistanceToMove, lpDistanceToMoveHigh, dwMoveMethod);
|
|
|
|
}
|
|
|
|
|
2023-09-08 19:22:54 +08:00
|
|
|
void coTaskMemFree(LPVOID pv) {
|
|
|
|
CoTaskMemFree(pv);
|
|
|
|
}
|
|
|
|
|
2023-12-04 20:06:22 +08:00
|
|
|
void setProcessPowerThrottlingState(ProcessPowerThrottlingState state) {
|
|
|
|
PROCESS_POWER_THROTTLING_STATE prio;
|
|
|
|
prio.Version = PROCESS_POWER_THROTTLING_CURRENT_VERSION;
|
|
|
|
prio.ControlMask = PROCESS_POWER_THROTTLING_EXECUTION_SPEED;
|
|
|
|
|
|
|
|
prio.StateMask = state == ProcessPowerThrottlingState::Eco ? PROCESS_POWER_THROTTLING_EXECUTION_SPEED : 0;
|
|
|
|
SetProcessInformation(GetCurrentProcess(), ProcessPowerThrottling, &prio, sizeof(prio));
|
|
|
|
}
|
|
|
|
|
2021-10-05 19:21:46 +08:00
|
|
|
LSTATUS regOpenKeyExA(HKEY hKey, LPCSTR lpSubKey, DWORD ulOptions, REGSAM samDesired, PHKEY phkResult) {
|
|
|
|
return RegOpenKeyExA(hKey, lpSubKey, ulOptions, samDesired, phkResult);
|
|
|
|
}
|
|
|
|
|
|
|
|
LSTATUS regQueryValueExA(HKEY hKey, LPCSTR lpValueName, LPDWORD lpReserved, LPDWORD lpType, LPBYTE lpData, LPDWORD lpcbData) {
|
|
|
|
return RegQueryValueExA(hKey, lpValueName, lpReserved, lpType, lpData, lpcbData);
|
|
|
|
}
|
2018-03-23 22:55:13 +08:00
|
|
|
} // namespace SysCalls
|
|
|
|
|
2019-03-26 18:59:46 +08:00
|
|
|
} // namespace NEO
|