{
if (data.hm_adl)
{
- if (data.hm_device[device_id].od_version == 5)
+ if (fanpolicy == 1)
{
- ADLFanSpeedValue lpFanSpeedValue;
+ if (data.hm_device[device_id].od_version == 5)
+ {
+ ADLFanSpeedValue lpFanSpeedValue;
- memset (&lpFanSpeedValue, 0, sizeof (lpFanSpeedValue));
+ memset (&lpFanSpeedValue, 0, sizeof (lpFanSpeedValue));
- lpFanSpeedValue.iSize = sizeof (lpFanSpeedValue);
- lpFanSpeedValue.iSpeedType = ADL_DL_FANCTRL_SPEED_TYPE_PERCENT;
- lpFanSpeedValue.iFlags = (fanpolicy == 1) ? ADL_DL_FANCTRL_FLAG_USER_DEFINED_SPEED : 0;
- lpFanSpeedValue.iFanSpeed = fanspeed;
+ lpFanSpeedValue.iSize = sizeof (lpFanSpeedValue);
+ lpFanSpeedValue.iSpeedType = ADL_DL_FANCTRL_SPEED_TYPE_PERCENT;
+ lpFanSpeedValue.iFlags = ADL_DL_FANCTRL_FLAG_USER_DEFINED_SPEED;
+ lpFanSpeedValue.iFanSpeed = fanspeed;
- if (hm_ADL_Overdrive5_FanSpeed_Set (data.hm_adl, data.hm_device[device_id].adl, 0, &lpFanSpeedValue) != ADL_OK) return -1;
+ if (hm_ADL_Overdrive5_FanSpeed_Set (data.hm_adl, data.hm_device[device_id].adl, 0, &lpFanSpeedValue) != ADL_OK) return -1;
- return 0;
- }
- else // od_version == 6
- {
- ADLOD6FanSpeedValue fan_speed_value;
+ return 0;
+ }
+ else // od_version == 6
+ {
+ ADLOD6FanSpeedValue fan_speed_value;
- memset (&fan_speed_value, 0, sizeof (fan_speed_value));
+ memset (&fan_speed_value, 0, sizeof (fan_speed_value));
- fan_speed_value.iSpeedType = ADL_OD6_FANSPEED_TYPE_PERCENT;
- fan_speed_value.iFanSpeed = fanspeed;
+ fan_speed_value.iSpeedType = ADL_OD6_FANSPEED_TYPE_PERCENT;
+ fan_speed_value.iFanSpeed = fanspeed;
- if (hm_ADL_Overdrive6_FanSpeed_Set (data.hm_adl, data.hm_device[device_id].adl, &fan_speed_value) != ADL_OK) return -1;
+ if (hm_ADL_Overdrive6_FanSpeed_Set (data.hm_adl, data.hm_device[device_id].adl, &fan_speed_value) != ADL_OK) return -1;
- return 0;
+ return 0;
+ }
+ }
+ else
+ {
+ if (data.hm_device[device_id].od_version == 5)
+ {
+ if (hm_ADL_Overdrive5_FanSpeedToDefault_Set (data.hm_adl, data.hm_device[device_id].adl, 0) != ADL_OK) return -1;
+
+ return 0;
+ }
+ else // od_version == 6
+ {
+ if (hm_ADL_Overdrive6_FanSpeed_Reset (data.hm_adl, data.hm_device[device_id].adl) != ADL_OK) return -1;
+
+ return 0;
+ }
}
}
}
{
if (data.hm_nvapi)
{
- NV_GPU_COOLER_LEVELS CoolerLevels = { 0 };
+ if (fanpolicy == 1)
+ {
+ NV_GPU_COOLER_LEVELS CoolerLevels = { 0 };
- CoolerLevels.Version = GPU_COOLER_LEVELS_VER | sizeof (NV_GPU_COOLER_LEVELS);
+ CoolerLevels.Version = GPU_COOLER_LEVELS_VER | sizeof (NV_GPU_COOLER_LEVELS);
- CoolerLevels.Levels[0].Level = fanspeed;
- CoolerLevels.Levels[0].Policy = fanpolicy;
+ CoolerLevels.Levels[0].Level = fanspeed;
+ CoolerLevels.Levels[0].Policy = 1;
- if (hm_NvAPI_GPU_SetCoolerLevels (data.hm_nvapi, data.hm_device[device_id].nvapi, 0, &CoolerLevels) != NVAPI_OK) return -1;
+ if (hm_NvAPI_GPU_SetCoolerLevels (data.hm_nvapi, data.hm_device[device_id].nvapi, 0, &CoolerLevels) != NVAPI_OK) return -1;
- return 0;
+ return 0;
+ }
+ else
+ {
+ if (hm_NvAPI_GPU_RestoreCoolerSettings (data.hm_nvapi, data.hm_device[device_id].nvapi, 0) != NVAPI_OK) return -1;
+
+ return 0;
+ }
}
}
{
case CTRL_CLOSE_EVENT:
- myabort ();
+ myquit ();
SetConsoleCtrlHandler (NULL, TRUE);