/* * Copyright (C) 2017-2019 Intel Corporation * * SPDX-License-Identifier: MIT * */ #include "runtime/os_interface/debug_settings_manager.h" #include "runtime/os_interface/windows/registry_reader.h" #include "runtime/os_interface/windows/windows_wrapper.h" #include "runtime/utilities/debug_settings_reader.h" #include namespace NEO { SettingsReader *SettingsReader::createOsReader(bool userScope) { return new RegistryReader(userScope); } SettingsReader *SettingsReader::createOsReader(const std::string ®Key) { return new RegistryReader("Software\\Intel\\IGFX\\OCL\\" + regKey); } RegistryReader::RegistryReader(bool userScope) { igdrclHkeyType = userScope ? HKEY_CURRENT_USER : HKEY_LOCAL_MACHINE; setUpProcessName(); } RegistryReader::RegistryReader(const std::string ®Key) : registryReadRootKey(regKey) { setUpProcessName(); } void RegistryReader::setUpProcessName() { char buff[MAX_PATH]; GetModuleFileNameA(nullptr, buff, MAX_PATH); if (GetLastError() == ERROR_INSUFFICIENT_BUFFER) { processName = ""; } processName.assign(buff); } const char *RegistryReader::appSpecificLocation(const std::string &name) { if (processName.length() > 0) return processName.c_str(); return name.c_str(); } bool RegistryReader::getSetting(const char *settingName, bool defaultValue) { return getSetting(settingName, static_cast(defaultValue)) ? true : false; } int32_t RegistryReader::getSetting(const char *settingName, int32_t defaultValue) { HKEY Key; DWORD value = defaultValue; DWORD success = ERROR_SUCCESS; success = RegOpenKeyExA(igdrclHkeyType, registryReadRootKey.c_str(), 0, KEY_READ, &Key); if (ERROR_SUCCESS == success) { DWORD regType; DWORD size = sizeof(ULONG); success = RegQueryValueExA(Key, settingName, NULL, ®Type, (LPBYTE)&value, &size); RegCloseKey(Key); value = ERROR_SUCCESS == success ? value : defaultValue; } return value; } std::string RegistryReader::getSetting(const char *settingName, const std::string &value) { HKEY Key; DWORD success = ERROR_SUCCESS; std::string keyValue = value; success = RegOpenKeyExA(igdrclHkeyType, registryReadRootKey.c_str(), 0, KEY_READ, &Key); if (ERROR_SUCCESS == success) { DWORD regType = REG_NONE; DWORD regSize = 0; success = RegQueryValueExA(Key, settingName, NULL, ®Type, NULL, ®Size); if (success == ERROR_SUCCESS && regType == REG_SZ) { char *regData = new char[regSize]; success = RegQueryValueExA(Key, settingName, NULL, ®Type, (LPBYTE)regData, ®Size); keyValue.assign(regData); delete[] regData; } else if (success == ERROR_SUCCESS && regType == REG_BINARY) { std::unique_ptr regData(new wchar_t[regSize]); success = RegQueryValueExA(Key, settingName, NULL, ®Type, (LPBYTE)regData.get(), ®Size); size_t charsConverted = 0; std::unique_ptr convertedData(new char[regSize]); wcstombs_s(&charsConverted, convertedData.get(), regSize, regData.get(), regSize); keyValue.assign(convertedData.get()); } RegCloseKey(Key); } return keyValue; } }; // namespace NEO