mirror of
https://github.com/FeralInteractive/gamemode.git
synced 2025-06-07 08:07:20 +02:00
Allow nv_perl_level and nv_powermizer_mode to be set independently
This commit is contained in:
parent
834a18aab4
commit
54d7d3f259
@ -140,7 +140,9 @@ int game_mode_initialise_gpu(GameModeConfig *config, GameModeGPUInfo **info)
|
|||||||
}
|
}
|
||||||
|
|
||||||
/* Sanity check the performance level value as well */
|
/* Sanity check the performance level value as well */
|
||||||
if (new_info->nv_perf_level < 0 || new_info->nv_perf_level > 16) {
|
/* Allow an invalid perf level if we've got the powermizer mode set */
|
||||||
|
if (!(new_info->nv_perf_level == -1 && new_info->nv_powermizer_mode != -1) &&
|
||||||
|
(new_info->nv_perf_level < 0 || new_info->nv_perf_level > 16)) {
|
||||||
LOG_ERROR(
|
LOG_ERROR(
|
||||||
"NVIDIA Performance level value likely invalid (%ld), will not apply "
|
"NVIDIA Performance level value likely invalid (%ld), will not apply "
|
||||||
"optimisations!\n",
|
"optimisations!\n",
|
||||||
|
@ -456,6 +456,10 @@ int run_gpu_optimisation_tests(struct GameModeConfig *config)
|
|||||||
char original_amd_performance_level[CONFIG_VALUE_MAX];
|
char original_amd_performance_level[CONFIG_VALUE_MAX];
|
||||||
strncpy(original_amd_performance_level, gpuinfo->amd_performance_level, CONFIG_VALUE_MAX);
|
strncpy(original_amd_performance_level, gpuinfo->amd_performance_level, CONFIG_VALUE_MAX);
|
||||||
|
|
||||||
|
/* account for when powermizer is not set */
|
||||||
|
if( expected_nv_powermizer_mode == -1 )
|
||||||
|
expected_nv_powermizer_mode = original_nv_powermizer_mode;
|
||||||
|
|
||||||
/* Start gamemode and check the new values */
|
/* Start gamemode and check the new values */
|
||||||
gamemode_request_start();
|
gamemode_request_start();
|
||||||
|
|
||||||
|
@ -73,6 +73,7 @@ static int get_gpu_state_nv(struct GameModeGPUInfo *info)
|
|||||||
char buf[EXTERNAL_BUFFER_MAX] = { 0 };
|
char buf[EXTERNAL_BUFFER_MAX] = { 0 };
|
||||||
char *end;
|
char *end;
|
||||||
|
|
||||||
|
if (info->nv_perf_level != -1) {
|
||||||
/* Get the GPUGraphicsClockOffset parameter */
|
/* Get the GPUGraphicsClockOffset parameter */
|
||||||
snprintf(arg,
|
snprintf(arg,
|
||||||
128,
|
128,
|
||||||
@ -110,6 +111,7 @@ static int get_gpu_state_nv(struct GameModeGPUInfo *info)
|
|||||||
LOG_ERROR("Failed to parse output for \"%s\" output was \"%s\"!\n", arg, buf);
|
LOG_ERROR("Failed to parse output for \"%s\" output was \"%s\"!\n", arg, buf);
|
||||||
return -1;
|
return -1;
|
||||||
}
|
}
|
||||||
|
}
|
||||||
|
|
||||||
/* Get the GPUPowerMizerMode parameter */
|
/* Get the GPUPowerMizerMode parameter */
|
||||||
snprintf(arg, 128, NV_ATTRIBUTE_FORMAT, info->device, NV_POWERMIZER_MODE_ATTRIBUTE);
|
snprintf(arg, 128, NV_ATTRIBUTE_FORMAT, info->device, NV_POWERMIZER_MODE_ATTRIBUTE);
|
||||||
@ -143,6 +145,7 @@ static int set_gpu_state_nv(struct GameModeGPUInfo *info)
|
|||||||
|
|
||||||
char arg[128] = { 0 };
|
char arg[128] = { 0 };
|
||||||
|
|
||||||
|
if (info->nv_perf_level != -1) {
|
||||||
/* Set the GPUGraphicsClockOffset parameter */
|
/* Set the GPUGraphicsClockOffset parameter */
|
||||||
snprintf(arg,
|
snprintf(arg,
|
||||||
128,
|
128,
|
||||||
@ -170,11 +173,10 @@ static int set_gpu_state_nv(struct GameModeGPUInfo *info)
|
|||||||
LOG_ERROR("Failed to set %s!\n", arg);
|
LOG_ERROR("Failed to set %s!\n", arg);
|
||||||
return -1;
|
return -1;
|
||||||
}
|
}
|
||||||
|
}
|
||||||
|
|
||||||
/* Set the GPUPowerMizerMode parameter if requested */
|
/* Set the GPUPowerMizerMode parameter if requested */
|
||||||
if (info->nv_powermizer_mode == -1)
|
if (info->nv_powermizer_mode != -1) {
|
||||||
return 0;
|
|
||||||
|
|
||||||
snprintf(arg,
|
snprintf(arg,
|
||||||
128,
|
128,
|
||||||
NV_ATTRIBUTE_FORMAT "=%ld",
|
NV_ATTRIBUTE_FORMAT "=%ld",
|
||||||
@ -186,6 +188,7 @@ static int set_gpu_state_nv(struct GameModeGPUInfo *info)
|
|||||||
LOG_ERROR("Failed to set %s!\n", arg);
|
LOG_ERROR("Failed to set %s!\n", arg);
|
||||||
return -1;
|
return -1;
|
||||||
}
|
}
|
||||||
|
}
|
||||||
|
|
||||||
return 0;
|
return 0;
|
||||||
}
|
}
|
||||||
@ -310,7 +313,7 @@ static long get_generic_value(const char *val)
|
|||||||
{
|
{
|
||||||
char *end;
|
char *end;
|
||||||
long ret = strtol(val, &end, 10);
|
long ret = strtol(val, &end, 10);
|
||||||
if (ret < 0 || end == val) {
|
if (end == val) {
|
||||||
LOG_ERROR("Invalid value passed (%ld)!\n", ret);
|
LOG_ERROR("Invalid value passed (%ld)!\n", ret);
|
||||||
print_usage_and_exit();
|
print_usage_and_exit();
|
||||||
}
|
}
|
||||||
@ -329,12 +332,12 @@ int main(int argc, char *argv[])
|
|||||||
info.vendor = get_vendor(argv[1]);
|
info.vendor = get_vendor(argv[1]);
|
||||||
info.device = get_device(argv[2]);
|
info.device = get_device(argv[2]);
|
||||||
|
|
||||||
if (info.vendor == Vendor_NVIDIA && argc > 4)
|
|
||||||
info.nv_perf_level = get_generic_value(argv[4]);
|
|
||||||
|
|
||||||
/* Fetch the state and print it out */
|
/* Fetch the state and print it out */
|
||||||
switch (info.vendor) {
|
switch (info.vendor) {
|
||||||
case Vendor_NVIDIA:
|
case Vendor_NVIDIA:
|
||||||
|
info.nv_perf_level = -1;
|
||||||
|
if (argc > 4)
|
||||||
|
info.nv_perf_level = get_generic_value(argv[4]);
|
||||||
/* Get nvidia power level */
|
/* Get nvidia power level */
|
||||||
if (get_gpu_state_nv(&info) != 0)
|
if (get_gpu_state_nv(&info) != 0)
|
||||||
exit(EXIT_FAILURE);
|
exit(EXIT_FAILURE);
|
||||||
@ -361,12 +364,12 @@ int main(int argc, char *argv[])
|
|||||||
case Vendor_NVIDIA:
|
case Vendor_NVIDIA:
|
||||||
info.nv_core = get_generic_value(argv[4]);
|
info.nv_core = get_generic_value(argv[4]);
|
||||||
info.nv_mem = get_generic_value(argv[5]);
|
info.nv_mem = get_generic_value(argv[5]);
|
||||||
|
info.nv_perf_level = -1;
|
||||||
if (argc > 6)
|
if (argc > 6)
|
||||||
info.nv_perf_level = get_generic_value(argv[6]);
|
info.nv_perf_level = get_generic_value(argv[6]);
|
||||||
|
info.nv_powermizer_mode = -1;
|
||||||
if (argc > 7)
|
if (argc > 7)
|
||||||
info.nv_powermizer_mode = get_generic_value(argv[7]);
|
info.nv_powermizer_mode = get_generic_value(argv[7]);
|
||||||
else
|
|
||||||
info.nv_powermizer_mode = -1;
|
|
||||||
break;
|
break;
|
||||||
case Vendor_AMD:
|
case Vendor_AMD:
|
||||||
strncpy(info.amd_performance_level, argv[4], CONFIG_VALUE_MAX);
|
strncpy(info.amd_performance_level, argv[4], CONFIG_VALUE_MAX);
|
||||||
|
Loading…
x
Reference in New Issue
Block a user