mirror of
https://github.com/GOSTSec/sgminer
synced 2025-01-22 12:34:27 +00:00
Implement setting the GPU engine clock speed of all devices or each device as a comma separated value.
This commit is contained in:
parent
12a167a3f1
commit
ec8808d004
14
adl.c
14
adl.c
@ -75,7 +75,7 @@ static LPAdapterInfo lpInfo = NULL;
|
|||||||
|
|
||||||
void init_adl(int nDevs)
|
void init_adl(int nDevs)
|
||||||
{
|
{
|
||||||
int i, devices = 0, last_adapter = -1;
|
int i, devices = 0, last_adapter = -1, gpu = 0;
|
||||||
|
|
||||||
#if defined (LINUX)
|
#if defined (LINUX)
|
||||||
hDLL = dlopen( "libatiadlxx.so", RTLD_LAZY|RTLD_GLOBAL);
|
hDLL = dlopen( "libatiadlxx.so", RTLD_LAZY|RTLD_GLOBAL);
|
||||||
@ -177,6 +177,7 @@ void init_adl(int nDevs)
|
|||||||
applog(LOG_ERR, "ADL found more devices than opencl");
|
applog(LOG_ERR, "ADL found more devices than opencl");
|
||||||
return;
|
return;
|
||||||
}
|
}
|
||||||
|
gpu = devices - 1;
|
||||||
last_adapter = lpAdapterID;
|
last_adapter = lpAdapterID;
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -190,7 +191,7 @@ void init_adl(int nDevs)
|
|||||||
|
|
||||||
/* From here on we know this device is a discrete device and
|
/* From here on we know this device is a discrete device and
|
||||||
* should support ADL */
|
* should support ADL */
|
||||||
ga = &gpus[devices - 1].adl;
|
ga = &gpus[gpu].adl;
|
||||||
ga->iAdapterIndex = iAdapterIndex;
|
ga->iAdapterIndex = iAdapterIndex;
|
||||||
ga->lpAdapterID = lpAdapterID;
|
ga->lpAdapterID = lpAdapterID;
|
||||||
ga->lpStatus = lpStatus;
|
ga->lpStatus = lpStatus;
|
||||||
@ -218,6 +219,13 @@ void init_adl(int nDevs)
|
|||||||
ADL_Overdrive5_ODPerformanceLevels_Get(iAdapterIndex, 0, lpOdPerformanceLevels);
|
ADL_Overdrive5_ODPerformanceLevels_Get(iAdapterIndex, 0, lpOdPerformanceLevels);
|
||||||
/* Save these values as the defaults in case we wish to reset to defaults */
|
/* Save these values as the defaults in case we wish to reset to defaults */
|
||||||
ga->DefPerfLev = lpOdPerformanceLevels;
|
ga->DefPerfLev = lpOdPerformanceLevels;
|
||||||
|
|
||||||
|
if (gpus[gpu].gpu_engine) {
|
||||||
|
applog(LOG_INFO, "Setting GPU %d engine clock to %d", gpu, gpus[gpu].gpu_engine);
|
||||||
|
lpOdPerformanceLevels->aLevels[lev].iEngineClock = gpus[gpu].gpu_engine * 100;
|
||||||
|
ADL_Overdrive5_ODPerformanceLevels_Set(iAdapterIndex, lpOdPerformanceLevels);
|
||||||
|
ADL_Overdrive5_ODPerformanceLevels_Get(iAdapterIndex, 0, lpOdPerformanceLevels);
|
||||||
|
}
|
||||||
ga->iEngineClock = lpOdPerformanceLevels->aLevels[lev].iEngineClock;
|
ga->iEngineClock = lpOdPerformanceLevels->aLevels[lev].iEngineClock;
|
||||||
ga->iMemoryClock = lpOdPerformanceLevels->aLevels[lev].iMemoryClock;
|
ga->iMemoryClock = lpOdPerformanceLevels->aLevels[lev].iMemoryClock;
|
||||||
ga->iVddc = lpOdPerformanceLevels->aLevels[lev].iVddc;
|
ga->iVddc = lpOdPerformanceLevels->aLevels[lev].iVddc;
|
||||||
@ -243,7 +251,7 @@ void init_adl(int nDevs)
|
|||||||
if (opt_autoengine)
|
if (opt_autoengine)
|
||||||
ga->autoengine = true;
|
ga->autoengine = true;
|
||||||
|
|
||||||
gpus[devices - 1].has_adl = true;
|
gpus[gpu].has_adl = true;
|
||||||
}
|
}
|
||||||
|
|
||||||
adl_active = true;
|
adl_active = true;
|
||||||
|
44
main.c
44
main.c
@ -1111,6 +1111,36 @@ static char *set_schedtime(const char *arg, struct schedtime *st)
|
|||||||
return NULL;
|
return NULL;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
#ifdef HAVE_ADL
|
||||||
|
static char *set_gpu_engine(char *arg)
|
||||||
|
{
|
||||||
|
int i, val = 0, device = 0;
|
||||||
|
char *saveptr = NULL, *nextptr;
|
||||||
|
|
||||||
|
nextptr = strtok_r(arg, ",", &saveptr);
|
||||||
|
if (nextptr == NULL)
|
||||||
|
return "Invalid parameters for set gpu engine";
|
||||||
|
val = atoi(nextptr);
|
||||||
|
if (val <= 0 || val >= 9999)
|
||||||
|
return "Invalid value passed to set_gpu_engine";
|
||||||
|
|
||||||
|
gpus[device++].gpu_engine = val;
|
||||||
|
|
||||||
|
while ((nextptr = strtok_r(NULL, ",", &saveptr)) != NULL) {
|
||||||
|
val = atoi(nextptr);
|
||||||
|
if (val <= 0 || val >= 9999)
|
||||||
|
return "Invalid value passed to set_gpu_engine";
|
||||||
|
|
||||||
|
gpus[device++].gpu_engine = val;
|
||||||
|
}
|
||||||
|
for (i = device; i < 16; i++)
|
||||||
|
gpus[i].gpu_engine = val;
|
||||||
|
|
||||||
|
return NULL;
|
||||||
|
}
|
||||||
|
|
||||||
|
#endif
|
||||||
|
|
||||||
/* These options are available from config file or commandline */
|
/* These options are available from config file or commandline */
|
||||||
static struct opt_table opt_config_table[] = {
|
static struct opt_table opt_config_table[] = {
|
||||||
OPT_WITH_ARG("--algo|-a",
|
OPT_WITH_ARG("--algo|-a",
|
||||||
@ -1171,6 +1201,11 @@ static struct opt_table opt_config_table[] = {
|
|||||||
OPT_WITH_ARG("--gpu-threads|-g",
|
OPT_WITH_ARG("--gpu-threads|-g",
|
||||||
set_int_1_to_10, opt_show_intval, &opt_g_threads,
|
set_int_1_to_10, opt_show_intval, &opt_g_threads,
|
||||||
"Number of threads per GPU (1 - 10)"),
|
"Number of threads per GPU (1 - 10)"),
|
||||||
|
#ifdef HAVE_ADL
|
||||||
|
OPT_WITH_ARG("--gpu-engine",
|
||||||
|
set_gpu_engine, NULL, NULL,
|
||||||
|
"Set the GPU engine (over)clock in Mhz - one value for all or separate by commas for per card."),
|
||||||
|
#endif
|
||||||
OPT_WITH_ARG("--intensity|-I",
|
OPT_WITH_ARG("--intensity|-I",
|
||||||
forced_int_1010, NULL, &scan_intensity,
|
forced_int_1010, NULL, &scan_intensity,
|
||||||
"Intensity of GPU scanning (-10 -> 10, default: dynamic to maintain desktop interactivity)"),
|
"Intensity of GPU scanning (-10 -> 10, default: dynamic to maintain desktop interactivity)"),
|
||||||
@ -1485,7 +1520,7 @@ static WINDOW *mainwin, *statuswin, *logwin;
|
|||||||
static double total_secs = 0.1;
|
static double total_secs = 0.1;
|
||||||
static char statusline[256];
|
static char statusline[256];
|
||||||
static int cpucursor, gpucursor, logstart, logcursor;
|
static int cpucursor, gpucursor, logstart, logcursor;
|
||||||
struct cgpu_info *gpus;
|
struct cgpu_info gpus[16]; /* Maximum number apparently possible */
|
||||||
static struct cgpu_info *cpus;
|
static struct cgpu_info *cpus;
|
||||||
|
|
||||||
static inline void unlock_curses(void)
|
static inline void unlock_curses(void)
|
||||||
@ -4975,11 +5010,6 @@ int main (int argc, char *argv[])
|
|||||||
if (unlikely(!cpus))
|
if (unlikely(!cpus))
|
||||||
quit(1, "Failed to calloc cpus");
|
quit(1, "Failed to calloc cpus");
|
||||||
}
|
}
|
||||||
if (gpu_threads) {
|
|
||||||
gpus = calloc(nDevs, sizeof(struct cgpu_info));
|
|
||||||
if (unlikely(!gpus))
|
|
||||||
quit(1, "Failed to calloc gpus");
|
|
||||||
}
|
|
||||||
|
|
||||||
stage_thr_id = mining_threads + 3;
|
stage_thr_id = mining_threads + 3;
|
||||||
thr = &thr_info[stage_thr_id];
|
thr = &thr_info[stage_thr_id];
|
||||||
@ -5196,8 +5226,6 @@ int main (int argc, char *argv[])
|
|||||||
clear_adl(nDevs);
|
clear_adl(nDevs);
|
||||||
#endif
|
#endif
|
||||||
|
|
||||||
if (gpu_threads)
|
|
||||||
free(gpus);
|
|
||||||
if (opt_n_threads)
|
if (opt_n_threads)
|
||||||
free(cpus);
|
free(cpus);
|
||||||
|
|
||||||
|
3
miner.h
3
miner.h
@ -198,6 +198,7 @@ struct cgpu_info {
|
|||||||
#ifdef HAVE_ADL
|
#ifdef HAVE_ADL
|
||||||
bool has_adl;
|
bool has_adl;
|
||||||
struct gpu_adl adl;
|
struct gpu_adl adl;
|
||||||
|
int gpu_engine;
|
||||||
#endif
|
#endif
|
||||||
};
|
};
|
||||||
|
|
||||||
@ -368,7 +369,7 @@ extern bool use_syslog;
|
|||||||
extern struct thr_info *thr_info;
|
extern struct thr_info *thr_info;
|
||||||
extern int longpoll_thr_id;
|
extern int longpoll_thr_id;
|
||||||
extern struct work_restart *work_restart;
|
extern struct work_restart *work_restart;
|
||||||
extern struct cgpu_info *gpus;
|
extern struct cgpu_info gpus[16];
|
||||||
|
|
||||||
#ifdef HAVE_OPENCL
|
#ifdef HAVE_OPENCL
|
||||||
typedef struct {
|
typedef struct {
|
||||||
|
Loading…
x
Reference in New Issue
Block a user