+++ /dev/null
-/**
- * Authors.....: Jens Steube <jens.steube@gmail.com>
- * Gabriele Gristina <matrix@hashcat.net>
- *
- * License.....: MIT
- */
-
-#include <ext_nvapi.h>
-
-int nvapi_init (NVAPI_PTR *nvapi)
-{
- if (!nvapi) return (-1);
-
- memset (nvapi, 0, sizeof (NVAPI_PTR));
-
- #if __x86_64__
- nvapi->lib = hc_dlopen ("nvapi64.dll");
- #elif __x86__
- nvapi->lib = hc_dlopen ("nvapi.dll");
- #endif
-
- if (!nvapi->lib)
- {
- //if (data.quiet == 0)
- // log_info ("WARNING: load NVAPI library failed, proceed without NVAPI HWMon enabled.");
-
- return (-1);
- }
-
- HC_LOAD_FUNC(nvapi, nvapi_QueryInterface, NVAPI_QUERYINTERFACE, NVAPI, 0)
- HC_LOAD_ADDR(nvapi, NvAPI_Initialize, NVAPI_INITIALIZE, nvapi_QueryInterface, 0x0150E828, NVAPI, 0)
- HC_LOAD_ADDR(nvapi, NvAPI_Unload, NVAPI_UNLOAD, nvapi_QueryInterface, 0xD22BDD7E, NVAPI, 0)
- HC_LOAD_ADDR(nvapi, NvAPI_GetErrorMessage, NVAPI_GETERRORMESSAGE, nvapi_QueryInterface, 0x6C2D048C, NVAPI, 0)
- HC_LOAD_ADDR(nvapi, NvAPI_EnumPhysicalGPUs, NVAPI_ENUMPHYSICALGPUS, nvapi_QueryInterface, 0xE5AC921F, NVAPI, 0)
- HC_LOAD_ADDR(nvapi, NvAPI_GPU_GetDynamicPstatesInfoEx, NVAPI_GPU_GETDYNAMICPSTATESINFOEX, nvapi_QueryInterface, 0x60DED2ED, NVAPI, 0)
- HC_LOAD_ADDR(nvapi, NvAPI_GPU_GetThermalSettings, NVAPI_GPU_GETTHERMALSETTINGS, nvapi_QueryInterface, 0xE3640A56, NVAPI, 0)
- HC_LOAD_ADDR(nvapi, NvAPI_GPU_GetTachReading, NVAPI_GPU_GETTACHREADING, nvapi_QueryInterface, 0x5F608315, NVAPI, 0)
- HC_LOAD_ADDR(nvapi, NvAPI_GPU_GetCoolerSettings, NVAPI_GPU_GETCOOLERSETTINGS, nvapi_QueryInterface, 0xDA141340, NVAPI, 0)
- HC_LOAD_ADDR(nvapi, NvAPI_GPU_SetCoolerLevels, NVAPI_GPU_SETCOOLERLEVELS, nvapi_QueryInterface, 0x891FA0AE, NVAPI, 0)
- HC_LOAD_ADDR(nvapi, NvAPI_GPU_GetAllClockFrequencies, NVAPI_GPU_GETALLCLOCKFREQUENCIES, nvapi_QueryInterface, 0xDCB616C3, NVAPI, 0)
- HC_LOAD_ADDR(nvapi, NvAPI_GPU_GetCurrentPCIEDownstreamWidth, NVAPI_GPU_GETCURRENTPCIEDOWNSTREAMWIDTH, nvapi_QueryInterface, 0xD048C3B1, NVAPI, 0)
- HC_LOAD_ADDR(nvapi, NvAPI_GPU_GetPerfDecreaseInfo, NVAPI_GPU_GETPERFDECREASEINFO, nvapi_QueryInterface, 0x7F7F4600, NVAPI, 0)
-
- return 0;
-}
-
-void nvapi_close (NVAPI_PTR *nvapi)
-{
- if (nvapi)
- {
- if (nvapi->lib)
- hc_dlclose (nvapi->lib);
-
- myfree (nvapi);
- }
-}
-
-int hm_NvAPI_Initialize (NVAPI_PTR *nvapi)
-{
- if (!nvapi) return (-1);
-
- NvAPI_Status NvAPI_rc = nvapi->NvAPI_Initialize ();
-
- if (NvAPI_rc == NVAPI_LIBRARY_NOT_FOUND) NvAPI_rc = NVAPI_OK; // not a bug
-
- if (NvAPI_rc != NVAPI_OK)
- {
- NvAPI_ShortString string = { 0 };
-
- hm_NvAPI_GetErrorMessage (nvapi, NvAPI_rc, string);
-
- log_info ("WARN: %s %d %s\n", "NvAPI_Initialize()", NvAPI_rc, string);
- }
-
- return NvAPI_rc;
-}
-
-int hm_NvAPI_Unload (NVAPI_PTR *nvapi)
-{
- if (!nvapi) return (-1);
-
- NvAPI_Status NvAPI_rc = nvapi->NvAPI_Unload ();
-
- if (NvAPI_rc != NVAPI_OK)
- {
- NvAPI_ShortString string = { 0 };
-
- hm_NvAPI_GetErrorMessage (nvapi, NvAPI_rc, string);
-
- log_info ("WARN: %s %d %s\n", "NvAPI_Unload()", NvAPI_rc, string);
- }
-
- return NvAPI_rc;
-}
-
-int hm_NvAPI_GetErrorMessage (NVAPI_PTR *nvapi, NvAPI_Status NvAPI_rc, NvAPI_ShortString string)
-{
- if (!nvapi) return (-1);
-
- return nvapi->NvAPI_GetErrorMessage (NvAPI_rc, string);
-}
-
-int hm_NvAPI_EnumPhysicalGPUs (NVAPI_PTR *nvapi, NvPhysicalGpuHandle nvGPUHandle[NVAPI_MAX_PHYSICAL_GPUS], NvU32 *pGpuCount)
-{
- if (!nvapi) return (-1);
-
- NvAPI_Status NvAPI_rc = nvapi->NvAPI_EnumPhysicalGPUs (nvGPUHandle, pGpuCount);
-
- if (NvAPI_rc != NVAPI_OK)
- {
- NvAPI_ShortString string = { 0 };
-
- hm_NvAPI_GetErrorMessage (nvapi, NvAPI_rc, string);
-
- log_info ("WARN: %s %d %s\n", "NvAPI_EnumPhysicalGPUs()", NvAPI_rc, string);
- }
-
- return NvAPI_rc;
-}
-
-int hm_NvAPI_GPU_GetThermalSettings (NVAPI_PTR *nvapi, NvPhysicalGpuHandle hPhysicalGpu, NvU32 sensorIndex, NV_GPU_THERMAL_SETTINGS *pThermalSettings)
-{
- if (!nvapi) return (-1);
-
- NvAPI_Status NvAPI_rc = nvapi->NvAPI_GPU_GetThermalSettings (hPhysicalGpu, sensorIndex, pThermalSettings);
-
- if (NvAPI_rc != NVAPI_OK)
- {
- NvAPI_ShortString string = { 0 };
-
- hm_NvAPI_GetErrorMessage (nvapi, NvAPI_rc, string);
-
- log_info ("WARN: %s %d %s\n", "NvAPI_GPU_GetThermalSettings()", NvAPI_rc, string);
- }
-
- return NvAPI_rc;
-}
-
-int hm_NvAPI_GPU_GetTachReading (NVAPI_PTR *nvapi, NvPhysicalGpuHandle hPhysicalGPU, NvU32 *pValue)
-{
- if (!nvapi) return (-1);
-
- NvAPI_Status NvAPI_rc = nvapi->NvAPI_GPU_GetTachReading (hPhysicalGPU, pValue);
-
- if (NvAPI_rc != NVAPI_OK)
- {
- NvAPI_ShortString string = { 0 };
-
- hm_NvAPI_GetErrorMessage (nvapi, NvAPI_rc, string);
-
- log_info ("WARN: %s %d %s\n", "NvAPI_GPU_GetTachReading()", NvAPI_rc, string);
- }
-
- return NvAPI_rc;
-}
-
-int hm_NvAPI_GPU_GetCoolerSettings (NVAPI_PTR *nvapi, NvPhysicalGpuHandle hPhysicalGpu, NvU32 coolerIndex, NV_GPU_COOLER_SETTINGS *pCoolerSettings)
-{
- if (!nvapi) return (-1);
-
- NvAPI_Status NvAPI_rc = nvapi->NvAPI_GPU_GetCoolerSettings (hPhysicalGpu, coolerIndex, pCoolerSettings);
-
- if (NvAPI_rc != NVAPI_OK)
- {
- NvAPI_ShortString string = { 0 };
-
- hm_NvAPI_GetErrorMessage (nvapi, NvAPI_rc, string);
-
- log_info ("WARN: %s %d %s\n", "NvAPI_GPU_GetCoolerSettings()", NvAPI_rc, string);
- }
-
- return NvAPI_rc;
-}
-
-int hm_NvAPI_GPU_SetCoolerLevels (NVAPI_PTR *nvapi, NvPhysicalGpuHandle hPhysicalGpu, NvU32 coolerIndex, NV_GPU_COOLER_LEVELS *pCoolerLevels)
-{
- if (!nvapi) return (-1);
-
- NvAPI_Status NvAPI_rc = nvapi->NvAPI_GPU_SetCoolerLevels (hPhysicalGpu, coolerIndex, pCoolerLevels);
-
- if (NvAPI_rc != NVAPI_OK)
- {
- NvAPI_ShortString string = { 0 };
-
- hm_NvAPI_GetErrorMessage (nvapi, NvAPI_rc, string);
-
- log_info ("WARN: %s %d %s\n", "NvAPI_GPU_SetCoolerLevels()", NvAPI_rc, string);
- }
-
- return NvAPI_rc;
-}
-
-int hm_NvAPI_GPU_GetDynamicPstatesInfoEx (NVAPI_PTR *nvapi, NvPhysicalGpuHandle hPhysicalGpu, NV_GPU_DYNAMIC_PSTATES_INFO_EX *pDynamicPstatesInfoEx)
-{
- if (!nvapi) return (-1);
-
- NvAPI_Status NvAPI_rc = nvapi->NvAPI_GPU_GetDynamicPstatesInfoEx (hPhysicalGpu, pDynamicPstatesInfoEx);
-
- if (NvAPI_rc != NVAPI_OK)
- {
- NvAPI_ShortString string = { 0 };
-
- hm_NvAPI_GetErrorMessage (nvapi, NvAPI_rc, string);
-
- log_info ("WARN: %s %d %s\n", "NvAPI_GPU_GetDynamicPstatesInfoEx()", NvAPI_rc, string);
- }
-
- return NvAPI_rc;
-}
-
-int hm_NvAPI_GPU_GetAllClockFrequencies (NVAPI_PTR *nvapi, NvPhysicalGpuHandle hPhysicalGpu, NV_GPU_CLOCK_FREQUENCIES *pClkFreqs)
-{
- if (!nvapi) return (-1);
-
- NvAPI_Status NvAPI_rc = nvapi->NvAPI_GPU_GetAllClockFrequencies (hPhysicalGpu, pClkFreqs);
-
- if (NvAPI_rc != NVAPI_OK)
- {
- NvAPI_ShortString string = { 0 };
-
- hm_NvAPI_GetErrorMessage (nvapi, NvAPI_rc, string);
-
- log_info ("WARN: %s %d %s\n", "NvAPI_GPU_GetAllClockFrequencies()", NvAPI_rc, string);
- }
-
- return NvAPI_rc;
-}
-
-int hm_NvAPI_GPU_GetCurrentPCIEDownstreamWidth (NVAPI_PTR *nvapi, NvPhysicalGpuHandle hPhysicalGpu, NvU32 *pWidth)
-{
- if (!nvapi) return (-1);
-
- NvAPI_Status NvAPI_rc = nvapi->NvAPI_GPU_GetCurrentPCIEDownstreamWidth (hPhysicalGpu, pWidth);
-
- if (NvAPI_rc != NVAPI_OK)
- {
- NvAPI_ShortString string = { 0 };
-
- hm_NvAPI_GetErrorMessage (nvapi, NvAPI_rc, string);
-
- log_info ("WARN: %s %d %s\n", "NvAPI_GPU_GetCurrentPCIEDownstreamWidth()", NvAPI_rc, string);
- }
-
- return NvAPI_rc;
-}
-
-int hm_NvAPI_GPU_GetPerfDecreaseInfo (NVAPI_PTR *nvapi, NvPhysicalGpuHandle hPhysicalGpu, NvU32 *pPerfDecrInfo)
-{
- if (!nvapi) return (-1);
-
- NvAPI_Status NvAPI_rc = nvapi->NvAPI_GPU_GetPerfDecreaseInfo (hPhysicalGpu, pPerfDecrInfo);
-
- if (NvAPI_rc != NVAPI_OK)
- {
- NvAPI_ShortString string = { 0 };
-
- hm_NvAPI_GetErrorMessage (nvapi, NvAPI_rc, string);
-
- log_info ("WARN: %s %d %s\n", "NvAPI_GPU_GetPerfDecreaseInfo()", NvAPI_rc, string);
- }
-
- return NvAPI_rc;
-}
-
-#ifdef __MINGW64__
-
-void __security_check_cookie (uintptr_t _StackCookie)
-{
- (void) _StackCookie;
-}
-
-void __GSHandlerCheck ()
-{
-}
-
-#endif