ccf7dad4556aad60661e3e445059b28423e1021f
[hashcat.git] / include / ext_nvapi.h
1 /**
2 * Authors.....: Jens Steube <jens.steube@gmail.com>
3 * Gabriele Gristina <matrix@hashcat.net>
4 *
5 * License.....: MIT
6 */
7
8 #ifndef EXT_NVAPI_H
9 #define EXT_NVAPI_H
10
11 #if defined(HAVE_HWMON)
12
13 #include <common.h>
14
15 /**
16 * Declarations from nvapi.h and subheaders
17 */
18
19 #define NVAPI_INTERFACE extern NvAPI_Status
20
21 typedef unsigned long NvU32;
22
23 #define NV_DECLARE_HANDLE(name) struct name##__ { int unused; }; typedef struct name##__ *name
24
25 NV_DECLARE_HANDLE(NvPhysicalGpuHandle); // A single physical GPU
26
27 #define NVAPI_GENERIC_STRING_MAX 4096
28 #define NVAPI_LONG_STRING_MAX 256
29 #define NVAPI_SHORT_STRING_MAX 64
30
31 typedef char NvAPI_String[NVAPI_GENERIC_STRING_MAX];
32 typedef char NvAPI_LongString[NVAPI_LONG_STRING_MAX];
33 typedef char NvAPI_ShortString[NVAPI_SHORT_STRING_MAX];
34
35 #define MAKE_NVAPI_VERSION(typeName,ver) (NvU32)(sizeof(typeName) | ((ver)<<16))
36
37 #define NVAPI_MAX_PHYSICAL_GPUS 64
38
39 typedef enum _NvAPI_Status
40 {
41 NVAPI_OK = 0, // Success. Request is completed.
42 NVAPI_ERROR = -1, // Generic error
43 NVAPI_LIBRARY_NOT_FOUND = -2, // NVAPI support library cannot be loaded.
44 NVAPI_NO_IMPLEMENTATION = -3, // not implemented in current driver installation
45 NVAPI_API_NOT_INITIALIZED = -4, // NvAPI_Initialize has not been called (successfully)
46 NVAPI_INVALID_ARGUMENT = -5, // The argument/parameter value is not valid or NULL.
47 NVAPI_NVIDIA_DEVICE_NOT_FOUND = -6, // No NVIDIA display driver, or NVIDIA GPU driving a display, was found.
48 NVAPI_END_ENUMERATION = -7, // No more items to enumerate
49 NVAPI_INVALID_HANDLE = -8, // Invalid handle
50 NVAPI_INCOMPATIBLE_STRUCT_VERSION = -9, // An argument's structure version is not supported
51 NVAPI_HANDLE_INVALIDATED = -10, // The handle is no longer valid (likely due to GPU or display re-configuration)
52 NVAPI_OPENGL_CONTEXT_NOT_CURRENT = -11, // No NVIDIA OpenGL context is current (but needs to be)
53 NVAPI_INVALID_POINTER = -14, // An invalid pointer, usually NULL, was passed as a parameter
54 NVAPI_NO_GL_EXPERT = -12, // OpenGL Expert is not supported by the current drivers
55 NVAPI_INSTRUMENTATION_DISABLED = -13, // OpenGL Expert is supported, but driver instrumentation is currently disabled
56 NVAPI_NO_GL_NSIGHT = -15, // OpenGL does not support Nsight
57
58 NVAPI_EXPECTED_LOGICAL_GPU_HANDLE = -100, // Expected a logical GPU handle for one or more parameters
59 NVAPI_EXPECTED_PHYSICAL_GPU_HANDLE = -101, // Expected a physical GPU handle for one or more parameters
60 NVAPI_EXPECTED_DISPLAY_HANDLE = -102, // Expected an NV display handle for one or more parameters
61 NVAPI_INVALID_COMBINATION = -103, // The combination of parameters is not valid.
62 NVAPI_NOT_SUPPORTED = -104, // Requested feature is not supported in the selected GPU
63 NVAPI_PORTID_NOT_FOUND = -105, // No port ID was found for the I2C transaction
64 NVAPI_EXPECTED_UNATTACHED_DISPLAY_HANDLE = -106, // Expected an unattached display handle as one of the input parameters.
65 NVAPI_INVALID_PERF_LEVEL = -107, // Invalid perf level
66 NVAPI_DEVICE_BUSY = -108, // Device is busy; request not fulfilled
67 NVAPI_NV_PERSIST_FILE_NOT_FOUND = -109, // NV persist file is not found
68 NVAPI_PERSIST_DATA_NOT_FOUND = -110, // NV persist data is not found
69 NVAPI_EXPECTED_TV_DISPLAY = -111, // Expected a TV output display
70 NVAPI_EXPECTED_TV_DISPLAY_ON_DCONNECTOR = -112, // Expected a TV output on the D Connector - HDTV_EIAJ4120.
71 NVAPI_NO_ACTIVE_SLI_TOPOLOGY = -113, // SLI is not active on this device.
72 NVAPI_SLI_RENDERING_MODE_NOTALLOWED = -114, // Setup of SLI rendering mode is not possible right now.
73 NVAPI_EXPECTED_DIGITAL_FLAT_PANEL = -115, // Expected a digital flat panel.
74 NVAPI_ARGUMENT_EXCEED_MAX_SIZE = -116, // Argument exceeds the expected size.
75 NVAPI_DEVICE_SWITCHING_NOT_ALLOWED = -117, // Inhibit is ON due to one of the flags in NV_GPU_DISPLAY_CHANGE_INHIBIT or SLI active.
76 NVAPI_TESTING_CLOCKS_NOT_SUPPORTED = -118, // Testing of clocks is not supported.
77 NVAPI_UNKNOWN_UNDERSCAN_CONFIG = -119, // The specified underscan config is from an unknown source (e.g. INF)
78 NVAPI_TIMEOUT_RECONFIGURING_GPU_TOPO = -120, // Timeout while reconfiguring GPUs
79 NVAPI_DATA_NOT_FOUND = -121, // Requested data was not found
80 NVAPI_EXPECTED_ANALOG_DISPLAY = -122, // Expected an analog display
81 NVAPI_NO_VIDLINK = -123, // No SLI video bridge is present
82 NVAPI_REQUIRES_REBOOT = -124, // NVAPI requires a reboot for the settings to take effect
83 NVAPI_INVALID_HYBRID_MODE = -125, // The function is not supported with the current Hybrid mode.
84 NVAPI_MIXED_TARGET_TYPES = -126, // The target types are not all the same
85 NVAPI_SYSWOW64_NOT_SUPPORTED = -127, // The function is not supported from 32-bit on a 64-bit system.
86 NVAPI_IMPLICIT_SET_GPU_TOPOLOGY_CHANGE_NOT_ALLOWED = -128, // There is no implicit GPU topology active. Use NVAPI_SetHybridMode to change topology.
87 NVAPI_REQUEST_USER_TO_CLOSE_NON_MIGRATABLE_APPS = -129, // Prompt the user to close all non-migratable applications.
88 NVAPI_OUT_OF_MEMORY = -130, // Could not allocate sufficient memory to complete the call.
89 NVAPI_WAS_STILL_DRAWING = -131, // The previous operation that is transferring information to or from this surface is incomplete.
90 NVAPI_FILE_NOT_FOUND = -132, // The file was not found.
91 NVAPI_TOO_MANY_UNIQUE_STATE_OBJECTS = -133, // There are too many unique instances of a particular type of state object.
92 NVAPI_INVALID_CALL = -134, // The method call is invalid. For example, a method's parameter may not be a valid pointer.
93 NVAPI_D3D10_1_LIBRARY_NOT_FOUND = -135, // d3d10_1.dll cannot be loaded.
94 NVAPI_FUNCTION_NOT_FOUND = -136, // Couldn't find the function in the loaded DLL.
95 NVAPI_INVALID_USER_PRIVILEGE = -137, // Current User is not Admin.
96 NVAPI_EXPECTED_NON_PRIMARY_DISPLAY_HANDLE = -138, // The handle corresponds to GDIPrimary.
97 NVAPI_EXPECTED_COMPUTE_GPU_HANDLE = -139, // Setting Physx GPU requires that the GPU is compute-capable.
98 NVAPI_STEREO_NOT_INITIALIZED = -140, // The Stereo part of NVAPI failed to initialize completely. Check if the stereo driver is installed.
99 NVAPI_STEREO_REGISTRY_ACCESS_FAILED = -141, // Access to stereo-related registry keys or values has failed.
100 NVAPI_STEREO_REGISTRY_PROFILE_TYPE_NOT_SUPPORTED = -142, // The given registry profile type is not supported.
101 NVAPI_STEREO_REGISTRY_VALUE_NOT_SUPPORTED = -143, // The given registry value is not supported.
102 NVAPI_STEREO_NOT_ENABLED = -144, // Stereo is not enabled and the function needed it to execute completely.
103 NVAPI_STEREO_NOT_TURNED_ON = -145, // Stereo is not turned on and the function needed it to execute completely.
104 NVAPI_STEREO_INVALID_DEVICE_INTERFACE = -146, // Invalid device interface.
105 NVAPI_STEREO_PARAMETER_OUT_OF_RANGE = -147, // Separation percentage or JPEG image capture quality is out of [0-100] range.
106 NVAPI_STEREO_FRUSTUM_ADJUST_MODE_NOT_SUPPORTED = -148, // The given frustum adjust mode is not supported.
107 NVAPI_TOPO_NOT_POSSIBLE = -149, // The mosaic topology is not possible given the current state of the hardware.
108 NVAPI_MODE_CHANGE_FAILED = -150, // An attempt to do a display resolution mode change has failed.
109 NVAPI_D3D11_LIBRARY_NOT_FOUND = -151, // d3d11.dll/d3d11_beta.dll cannot be loaded.
110 NVAPI_INVALID_ADDRESS = -152, // Address is outside of valid range.
111 NVAPI_STRING_TOO_SMALL = -153, // The pre-allocated string is too small to hold the result.
112 NVAPI_MATCHING_DEVICE_NOT_FOUND = -154, // The input does not match any of the available devices.
113 NVAPI_DRIVER_RUNNING = -155, // Driver is running.
114 NVAPI_DRIVER_NOTRUNNING = -156, // Driver is not running.
115 NVAPI_ERROR_DRIVER_RELOAD_REQUIRED = -157, // A driver reload is required to apply these settings.
116 NVAPI_SET_NOT_ALLOWED = -158, // Intended setting is not allowed.
117 NVAPI_ADVANCED_DISPLAY_TOPOLOGY_REQUIRED = -159, // Information can't be returned due to "advanced display topology".
118 NVAPI_SETTING_NOT_FOUND = -160, // Setting is not found.
119 NVAPI_SETTING_SIZE_TOO_LARGE = -161, // Setting size is too large.
120 NVAPI_TOO_MANY_SETTINGS_IN_PROFILE = -162, // There are too many settings for a profile.
121 NVAPI_PROFILE_NOT_FOUND = -163, // Profile is not found.
122 NVAPI_PROFILE_NAME_IN_USE = -164, // Profile name is duplicated.
123 NVAPI_PROFILE_NAME_EMPTY = -165, // Profile name is empty.
124 NVAPI_EXECUTABLE_NOT_FOUND = -166, // Application not found in the Profile.
125 NVAPI_EXECUTABLE_ALREADY_IN_USE = -167, // Application already exists in the other profile.
126 NVAPI_DATATYPE_MISMATCH = -168, // Data Type mismatch
127 NVAPI_PROFILE_REMOVED = -169, // The profile passed as parameter has been removed and is no longer valid.
128 NVAPI_UNREGISTERED_RESOURCE = -170, // An unregistered resource was passed as a parameter.
129 NVAPI_ID_OUT_OF_RANGE = -171, // The DisplayId corresponds to a display which is not within the normal outputId range.
130 NVAPI_DISPLAYCONFIG_VALIDATION_FAILED = -172, // Display topology is not valid so the driver cannot do a mode set on this configuration.
131 NVAPI_DPMST_CHANGED = -173, // Display Port Multi-Stream topology has been changed.
132 NVAPI_INSUFFICIENT_BUFFER = -174, // Input buffer is insufficient to hold the contents.
133 NVAPI_ACCESS_DENIED = -175, // No access to the caller.
134 NVAPI_MOSAIC_NOT_ACTIVE = -176, // The requested action cannot be performed without Mosaic being enabled.
135 NVAPI_SHARE_RESOURCE_RELOCATED = -177, // The surface is relocated away from video memory.
136 NVAPI_REQUEST_USER_TO_DISABLE_DWM = -178, // The user should disable DWM before calling NvAPI.
137 NVAPI_D3D_DEVICE_LOST = -179, // D3D device status is D3DERR_DEVICELOST or D3DERR_DEVICENOTRESET - the user has to reset the device.
138 NVAPI_INVALID_CONFIGURATION = -180, // The requested action cannot be performed in the current state.
139 NVAPI_STEREO_HANDSHAKE_NOT_DONE = -181, // Call failed as stereo handshake not completed.
140 NVAPI_EXECUTABLE_PATH_IS_AMBIGUOUS = -182, // The path provided was too short to determine the correct NVDRS_APPLICATION
141 NVAPI_DEFAULT_STEREO_PROFILE_IS_NOT_DEFINED = -183, // Default stereo profile is not currently defined
142 NVAPI_DEFAULT_STEREO_PROFILE_DOES_NOT_EXIST = -184, // Default stereo profile does not exist
143 NVAPI_CLUSTER_ALREADY_EXISTS = -185, // A cluster is already defined with the given configuration.
144 NVAPI_DPMST_DISPLAY_ID_EXPECTED = -186, // The input display id is not that of a multi stream enabled connector or a display device in a multi stream topology
145 NVAPI_INVALID_DISPLAY_ID = -187, // The input display id is not valid or the monitor associated to it does not support the current operation
146 NVAPI_STREAM_IS_OUT_OF_SYNC = -188, // While playing secure audio stream, stream goes out of sync
147 NVAPI_INCOMPATIBLE_AUDIO_DRIVER = -189, // Older audio driver version than required
148 NVAPI_VALUE_ALREADY_SET = -190, // Value already set, setting again not allowed.
149 NVAPI_TIMEOUT = -191, // Requested operation timed out
150 NVAPI_GPU_WORKSTATION_FEATURE_INCOMPLETE = -192, // The requested workstation feature set has incomplete driver internal allocation resources
151 NVAPI_STEREO_INIT_ACTIVATION_NOT_DONE = -193, // Call failed because InitActivation was not called.
152 NVAPI_SYNC_NOT_ACTIVE = -194, // The requested action cannot be performed without Sync being enabled.
153 NVAPI_SYNC_MASTER_NOT_FOUND = -195, // The requested action cannot be performed without Sync Master being enabled.
154 NVAPI_INVALID_SYNC_TOPOLOGY = -196, // Invalid displays passed in the NV_GSYNC_DISPLAY pointer.
155 NVAPI_ECID_SIGN_ALGO_UNSUPPORTED = -197, // The specified signing algorithm is not supported. Either an incorrect value was entered or the current installed driver/hardware does not support the input value.
156 NVAPI_ECID_KEY_VERIFICATION_FAILED = -198, // The encrypted public key verification has failed.
157 NVAPI_FIRMWARE_OUT_OF_DATE = -199, // The device's firmware is out of date.
158 NVAPI_FIRMWARE_REVISION_NOT_SUPPORTED = -200, // The device's firmware is not supported.
159 } NvAPI_Status;
160
161 typedef struct
162 {
163 // total size (of memset) is always: 76 = 0x4c
164
165 NvU32 version;
166
167 NvU32 a;
168 NvU32 info_value;
169
170 unsigned char x[64];
171
172 } NV_GPU_PERF_POLICIES_INFO_PARAMS_V1;
173
174 typedef struct
175 {
176 // total size (of memset) is always: 1360 = 0x550
177
178 NvU32 version;
179 NvU32 info_value;
180
181 NvU32 a;
182 NvU32 b;
183
184 NvU32 throttle;
185
186 unsigned char x[1340];
187
188 } NV_GPU_PERF_POLICIES_STATUS_PARAMS_V1;
189
190 NVAPI_INTERFACE NvAPI_QueryInterface (uint offset);
191 NVAPI_INTERFACE NvAPI_Initialize ();
192 NVAPI_INTERFACE NvAPI_Unload ();
193 NVAPI_INTERFACE NvAPI_GetErrorMessage (NvAPI_Status nr,NvAPI_ShortString szDesc);
194 NVAPI_INTERFACE NvAPI_EnumPhysicalGPUs (NvPhysicalGpuHandle nvGPUHandle[NVAPI_MAX_PHYSICAL_GPUS], NvU32 *pGpuCount);
195 NVAPI_INTERFACE NvAPI_GPU_GetPerfPoliciesInfo (NvPhysicalGpuHandle hPhysicalGpu, NV_GPU_PERF_POLICIES_INFO_PARAMS_V1 *perfPolicies_info);
196 NVAPI_INTERFACE NvAPI_GPU_GetPerfPoliciesStatus (NvPhysicalGpuHandle hPhysicalGpu, NV_GPU_PERF_POLICIES_STATUS_PARAMS_V1 *perfPolicies_status);
197
198 /*
199 * End of declarations from nvapi.h and subheaders
200 **/
201
202 typedef NvPhysicalGpuHandle HM_ADAPTER_NVAPI;
203
204 #include <shared.h>
205
206 #if defined(_WIN32) || defined(__WIN32__) || defined(__CYGWIN__)
207 #define NVAPI_API_CALL __stdcall
208 #else
209 #define NVAPI_API_CALL
210 #endif
211
212 typedef int *(*NVAPI_API_CALL NVAPI_QUERYINTERFACE) (uint);
213 typedef int (*NVAPI_API_CALL NVAPI_INITIALIZE) (void);
214 typedef int (*NVAPI_API_CALL NVAPI_UNLOAD) (void);
215 typedef int (*NVAPI_API_CALL NVAPI_GETERRORMESSAGE) (NvAPI_Status, NvAPI_ShortString);
216 typedef int (*NVAPI_API_CALL NVAPI_ENUMPHYSICALGPUS) (NvPhysicalGpuHandle nvGPUHandle[NVAPI_MAX_PHYSICAL_GPUS], NvU32 *);
217 typedef int (*NVAPI_API_CALL NVAPI_GPU_GETPERFPOLICIESINFO) (NvPhysicalGpuHandle, NV_GPU_PERF_POLICIES_INFO_PARAMS_V1 *);
218 typedef int (*NVAPI_API_CALL NVAPI_GPU_GETPERFPOLICIESSTATUS) (NvPhysicalGpuHandle, NV_GPU_PERF_POLICIES_STATUS_PARAMS_V1 *);
219
220 typedef struct
221 {
222 NVAPI_LIB lib;
223
224 NVAPI_QUERYINTERFACE nvapi_QueryInterface;
225 NVAPI_INITIALIZE NvAPI_Initialize;
226 NVAPI_UNLOAD NvAPI_Unload;
227 NVAPI_GETERRORMESSAGE NvAPI_GetErrorMessage;
228 NVAPI_ENUMPHYSICALGPUS NvAPI_EnumPhysicalGPUs;
229 NVAPI_GPU_GETPERFPOLICIESINFO NvAPI_GPU_GetPerfPoliciesInfo;
230 NVAPI_GPU_GETPERFPOLICIESSTATUS NvAPI_GPU_GetPerfPoliciesStatus;
231
232 } hm_nvapi_lib_t;
233
234 #define NVAPI_PTR hm_nvapi_lib_t
235
236 int nvapi_init (NVAPI_PTR *nvapi);
237 void nvapi_close (NVAPI_PTR *nvapi);
238
239 int hm_NvAPI_QueryInterface (NVAPI_PTR *nvapi, uint offset);
240 int hm_NvAPI_Initialize (NVAPI_PTR *nvapi);
241 int hm_NvAPI_Unload (NVAPI_PTR *nvapi);
242 int hm_NvAPI_GetErrorMessage (NVAPI_PTR *nvapi, NvAPI_Status nr, NvAPI_ShortString szDesc);
243 int hm_NvAPI_EnumPhysicalGPUs (NVAPI_PTR *nvapi, NvPhysicalGpuHandle nvGPUHandle[NVAPI_MAX_PHYSICAL_GPUS], NvU32 *pGpuCount);
244 int hm_NvAPI_GPU_GetPerfPoliciesInfo (NVAPI_PTR *nvapi, NvPhysicalGpuHandle hPhysicalGpu, NV_GPU_PERF_POLICIES_INFO_PARAMS_V1 *perfPolicies_info);
245 int hm_NvAPI_GPU_GetPerfPoliciesStatus (NVAPI_PTR *nvapi, NvPhysicalGpuHandle hPhysicalGpu, NV_GPU_PERF_POLICIES_STATUS_PARAMS_V1 *perfPolicies_status);
246
247 #endif // HAVE_HWMON
248
249 #endif // EXT_NVAPI_H