mirror of
https://github.com/GOSTSec/sgminer
synced 2025-01-25 14:04:25 +00:00
Add API commands: config, switchpool, gpu settings, save
This commit is contained in:
parent
0719d40704
commit
ec2c0b784f
33
README
33
README
@ -148,7 +148,6 @@ Options for both config file and command line:
|
|||||||
--sched-start <arg> Set a time of day in HH:MM to start mining (a once off without a stop time)
|
--sched-start <arg> Set a time of day in HH:MM to start mining (a once off without a stop time)
|
||||||
--sched-stop <arg> Set a time of day in HH:MM to stop mining (will quit without a start time)
|
--sched-stop <arg> Set a time of day in HH:MM to stop mining (will quit without a start time)
|
||||||
--shares <arg> Quit after mining N shares (default: unlimited)
|
--shares <arg> Quit after mining N shares (default: unlimited)
|
||||||
--socks-proxy <arg> Set socks4 proxy (host:port)
|
|
||||||
--submit-stale Submit shares even if they would normally be considered stale
|
--submit-stale Submit shares even if they would normally be considered stale
|
||||||
--syslog Use system log for output messages (default: standard error)
|
--syslog Use system log for output messages (default: standard error)
|
||||||
--text-only|-T Disable ncurses formatted screen output
|
--text-only|-T Disable ncurses formatted screen output
|
||||||
@ -574,6 +573,14 @@ The list of requests and replies are:
|
|||||||
version VERSION CGMiner=cgminer version
|
version VERSION CGMiner=cgminer version
|
||||||
API=API version
|
API=API version
|
||||||
|
|
||||||
|
config CONFIG Some miner configuration information:
|
||||||
|
GPU Count=N| <- the number of GPUs
|
||||||
|
CPU Count=N| <- the number of CPUs
|
||||||
|
Pool Count=N| <- the number of Pools
|
||||||
|
ADL=X| <- Y or N if ADL is compiled in the code
|
||||||
|
ADL in use=X| <- Y or N if any GPU has ADL
|
||||||
|
Strategy=Name| <- the current pool strategy
|
||||||
|
|
||||||
summary SUMMARY The status summary of the miner
|
summary SUMMARY The status summary of the miner
|
||||||
e.g. Elapsed=NNN,Found Blocks=N,Getworks=N,...|
|
e.g. Elapsed=NNN,Found Blocks=N,Getworks=N,...|
|
||||||
|
|
||||||
@ -582,16 +589,25 @@ The list of requests and replies are:
|
|||||||
|
|
||||||
devs DEVS Each available CPU and GPU with their details
|
devs DEVS Each available CPU and GPU with their details
|
||||||
e.g. GPU=0,Accepted=NN,MHS av=NNN,...,Intensity=D|
|
e.g. GPU=0,Accepted=NN,MHS av=NNN,...,Intensity=D|
|
||||||
|
Will not report CPUs if CPU mining is disabled
|
||||||
|
|
||||||
gpu|N GPU The details of a single GPU number N in the same
|
gpu|N GPU The details of a single GPU number N in the same
|
||||||
format and details as for DEVS
|
format and details as for DEVS
|
||||||
|
|
||||||
cpu|N CPU The details of a single CPU number N in the same
|
cpu|N CPU The details of a single CPU number N in the same
|
||||||
format and details as for DEVS
|
format and details as for DEVS
|
||||||
|
This is only available if CPU mining is enabled
|
||||||
|
Use 'cpucount' or 'config' first to see if there are any
|
||||||
|
|
||||||
gpucount GPUS Count=N| <- the number of GPUs
|
gpucount GPUS Count=N| <- the number of GPUs
|
||||||
|
|
||||||
cpucount CPUS Count=N| <- the number of CPUs
|
cpucount CPUS Count=N| <- the number of CPUs
|
||||||
|
Always returns 0 if CPU mining is disabled
|
||||||
|
|
||||||
|
switchpool|N none There is no reply section just the STATUS section
|
||||||
|
stating the results of switching pool N to the
|
||||||
|
highest priority (the pool is also enabled)
|
||||||
|
The Msg includes the pool URL
|
||||||
|
|
||||||
gpuenable|N none There is no reply section just the STATUS section
|
gpuenable|N none There is no reply section just the STATUS section
|
||||||
stating the results of the enable request
|
stating the results of the enable request
|
||||||
@ -602,6 +618,21 @@ The list of requests and replies are:
|
|||||||
gpurestart|N none There is no reply section just the STATUS section
|
gpurestart|N none There is no reply section just the STATUS section
|
||||||
stating the results of the restart request
|
stating the results of the restart request
|
||||||
|
|
||||||
|
gpuintensity|N,I none There is no reply section just the STATUS section
|
||||||
|
stating the results of setting GPU N intensity to I
|
||||||
|
|
||||||
|
gpumem|N,V none There is no reply section just the STATUS section
|
||||||
|
stating the results of setting GPU N memoryclock to V MHz
|
||||||
|
|
||||||
|
gpuengine|N,V none There is no reply section just the STATUS section
|
||||||
|
stating the results of setting GPU N clock to V MHz
|
||||||
|
|
||||||
|
gpufan|N,V none There is no reply section just the STATUS section
|
||||||
|
stating the results of setting GPU N fan speed to V%
|
||||||
|
|
||||||
|
gpuvddc|N,V none There is no reply section just the STATUS section
|
||||||
|
stating the results of setting GPU N vddc to V
|
||||||
|
|
||||||
quit none There is no status section but just a single "BYE|"
|
quit none There is no status section but just a single "BYE|"
|
||||||
reply before cgminer quits
|
reply before cgminer quits
|
||||||
|
|
||||||
|
10
adl.c
10
adl.c
@ -78,7 +78,7 @@ static ADL_OVERDRIVE5_FANSPEEDTODEFAULT_SET ADL_Overdrive5_FanSpeedToDefault_Set
|
|||||||
static int iNumberAdapters;
|
static int iNumberAdapters;
|
||||||
static LPAdapterInfo lpInfo = NULL;
|
static LPAdapterInfo lpInfo = NULL;
|
||||||
|
|
||||||
static int set_fanspeed(int gpu, int iFanSpeed);
|
int set_fanspeed(int gpu, int iFanSpeed);
|
||||||
static float __gpu_temp(struct gpu_adl *ga);
|
static float __gpu_temp(struct gpu_adl *ga);
|
||||||
|
|
||||||
static inline void lock_adl(void)
|
static inline void lock_adl(void)
|
||||||
@ -575,7 +575,7 @@ static void get_enginerange(int gpu, int *imin, int *imax)
|
|||||||
*imax = ga->lpOdParameters.sEngineClock.iMax / 100;
|
*imax = ga->lpOdParameters.sEngineClock.iMax / 100;
|
||||||
}
|
}
|
||||||
|
|
||||||
static int set_engineclock(int gpu, int iEngineClock)
|
int set_engineclock(int gpu, int iEngineClock)
|
||||||
{
|
{
|
||||||
ADLODPerformanceLevels *lpOdPerformanceLevels;
|
ADLODPerformanceLevels *lpOdPerformanceLevels;
|
||||||
int i, lev, ret = 1;
|
int i, lev, ret = 1;
|
||||||
@ -631,7 +631,7 @@ static void get_memoryrange(int gpu, int *imin, int *imax)
|
|||||||
*imax = ga->lpOdParameters.sMemoryClock.iMax / 100;
|
*imax = ga->lpOdParameters.sMemoryClock.iMax / 100;
|
||||||
}
|
}
|
||||||
|
|
||||||
static int set_memoryclock(int gpu, int iMemoryClock)
|
int set_memoryclock(int gpu, int iMemoryClock)
|
||||||
{
|
{
|
||||||
ADLODPerformanceLevels *lpOdPerformanceLevels;
|
ADLODPerformanceLevels *lpOdPerformanceLevels;
|
||||||
int i, lev, ret = 1;
|
int i, lev, ret = 1;
|
||||||
@ -694,7 +694,7 @@ static float curses_float(const char *query)
|
|||||||
return ret;
|
return ret;
|
||||||
}
|
}
|
||||||
|
|
||||||
static int set_vddc(int gpu, float fVddc)
|
int set_vddc(int gpu, float fVddc)
|
||||||
{
|
{
|
||||||
ADLODPerformanceLevels *lpOdPerformanceLevels;
|
ADLODPerformanceLevels *lpOdPerformanceLevels;
|
||||||
int i, iVddc, lev, ret = 1;
|
int i, iVddc, lev, ret = 1;
|
||||||
@ -746,7 +746,7 @@ static void get_fanrange(int gpu, int *imin, int *imax)
|
|||||||
*imax = ga->lpFanSpeedInfo.iMaxPercent;
|
*imax = ga->lpFanSpeedInfo.iMaxPercent;
|
||||||
}
|
}
|
||||||
|
|
||||||
static int set_fanspeed(int gpu, int iFanSpeed)
|
int set_fanspeed(int gpu, int iFanSpeed)
|
||||||
{
|
{
|
||||||
struct gpu_adl *ga;
|
struct gpu_adl *ga;
|
||||||
int ret = 1;
|
int ret = 1;
|
||||||
|
450
api.c
450
api.c
@ -144,12 +144,26 @@ static const char *UNAVAILABLE = " - API will not be available";
|
|||||||
//static const char *BLANK = "";
|
//static const char *BLANK = "";
|
||||||
static const char *COMMA = ",";
|
static const char *COMMA = ",";
|
||||||
static const char SEPARATOR = '|';
|
static const char SEPARATOR = '|';
|
||||||
|
static const char GPUSEP = ',';
|
||||||
|
|
||||||
|
static const char *APIVERSION = "1.0";
|
||||||
|
static const char *DEAD = "Dead";
|
||||||
|
static const char *SICK = "Sick";
|
||||||
|
static const char *NOSTART = "NoStart";
|
||||||
|
static const char *DISABLED = "Disabled";
|
||||||
|
static const char *ALIVE = "Alive";
|
||||||
|
#define _DYNAMIC "D"
|
||||||
|
static const char *DYNAMIC = _DYNAMIC;
|
||||||
|
|
||||||
|
static const char *YES = "Y";
|
||||||
|
static const char *NO = "N";
|
||||||
|
|
||||||
#define _DEVS "DEVS"
|
#define _DEVS "DEVS"
|
||||||
#define _POOLS "POOLS"
|
#define _POOLS "POOLS"
|
||||||
#define _SUMMARY "SUMMARY"
|
#define _SUMMARY "SUMMARY"
|
||||||
#define _STATUS "STATUS"
|
#define _STATUS "STATUS"
|
||||||
#define _VERSION "VERSION"
|
#define _VERSION "VERSION"
|
||||||
|
#define _MINECON "CONFIG"
|
||||||
|
|
||||||
#ifdef WANT_CPUMINE
|
#ifdef WANT_CPUMINE
|
||||||
#define _CPU "CPU"
|
#define _CPU "CPU"
|
||||||
@ -173,6 +187,7 @@ static const char ISJSON = '{';
|
|||||||
#define JSON_SUMMARY JSON1 _SUMMARY JSON2
|
#define JSON_SUMMARY JSON1 _SUMMARY JSON2
|
||||||
#define JSON_STATUS JSON1 _STATUS JSON2
|
#define JSON_STATUS JSON1 _STATUS JSON2
|
||||||
#define JSON_VERSION JSON1 _VERSION JSON2
|
#define JSON_VERSION JSON1 _VERSION JSON2
|
||||||
|
#define JSON_MINECON JSON1 _MINECON JSON2
|
||||||
#define JSON_GPU JSON1 _GPU JSON2
|
#define JSON_GPU JSON1 _GPU JSON2
|
||||||
|
|
||||||
#ifdef WANT_CPUMINE
|
#ifdef WANT_CPUMINE
|
||||||
@ -215,7 +230,27 @@ static const char *JSON_PARAMETER = "parameter";
|
|||||||
#define MSG_NUMCPU 21
|
#define MSG_NUMCPU 21
|
||||||
#define MSG_VERSION 22
|
#define MSG_VERSION 22
|
||||||
#define MSG_INVJSON 23
|
#define MSG_INVJSON 23
|
||||||
#define MSG_MISSCMD 24
|
#define MSG_MISCMD 24
|
||||||
|
#define MSG_MISPID 25
|
||||||
|
#define MSG_INVPID 26
|
||||||
|
#define MSG_SWITCHP 27
|
||||||
|
#define MSG_MISVAL 28
|
||||||
|
#define MSG_NOADL 29
|
||||||
|
#define MSG_NOGPUADL 30
|
||||||
|
#define MSG_INVINT 31
|
||||||
|
#define MSG_GPUINT 32
|
||||||
|
#define MSG_MINECON 33
|
||||||
|
#define MSG_GPUMERR 34
|
||||||
|
#define MSG_GPUMEM 35
|
||||||
|
#define MSG_GPUEERR 36
|
||||||
|
#define MSG_GPUENG 37
|
||||||
|
#define MSG_GPUVERR 38
|
||||||
|
#define MSG_GPUVDDC 39
|
||||||
|
#define MSG_GPUFERR 40
|
||||||
|
#define MSG_GPUFAN 41
|
||||||
|
#define MSG_MISFN 42
|
||||||
|
#define MSG_BADFN 43
|
||||||
|
#define MSG_SAVED 44
|
||||||
|
|
||||||
enum code_severity {
|
enum code_severity {
|
||||||
SEVERITY_ERR,
|
SEVERITY_ERR,
|
||||||
@ -231,12 +266,16 @@ enum code_parameters {
|
|||||||
PARAM_GPUMAX,
|
PARAM_GPUMAX,
|
||||||
PARAM_CPUMAX,
|
PARAM_CPUMAX,
|
||||||
PARAM_PMAX,
|
PARAM_PMAX,
|
||||||
|
PARAM_POOLMAX,
|
||||||
#ifdef WANT_CPUMINE
|
#ifdef WANT_CPUMINE
|
||||||
PARAM_GCMAX,
|
PARAM_GCMAX,
|
||||||
#else
|
#else
|
||||||
PARAM_GMAX,
|
PARAM_GMAX,
|
||||||
#endif
|
#endif
|
||||||
PARAM_CMD,
|
PARAM_CMD,
|
||||||
|
PARAM_POOL,
|
||||||
|
PARAM_STR,
|
||||||
|
PARAM_BOTH,
|
||||||
PARAM_NONE
|
PARAM_NONE
|
||||||
};
|
};
|
||||||
|
|
||||||
@ -276,28 +315,37 @@ struct CODES {
|
|||||||
{ SEVERITY_SUCC, MSG_NUMCPU, PARAM_NONE, "CPU count" },
|
{ SEVERITY_SUCC, MSG_NUMCPU, PARAM_NONE, "CPU count" },
|
||||||
{ SEVERITY_SUCC, MSG_VERSION, PARAM_NONE, "CGMiner versions" },
|
{ SEVERITY_SUCC, MSG_VERSION, PARAM_NONE, "CGMiner versions" },
|
||||||
{ SEVERITY_ERR, MSG_INVJSON, PARAM_NONE, "Invalid JSON" },
|
{ SEVERITY_ERR, MSG_INVJSON, PARAM_NONE, "Invalid JSON" },
|
||||||
{ SEVERITY_ERR, MSG_MISSCMD, PARAM_CMD, "Missing JSON '%s'" },
|
{ SEVERITY_ERR, MSG_MISCMD, PARAM_CMD, "Missing JSON '%s'" },
|
||||||
|
{ SEVERITY_ERR, MSG_MISPID, PARAM_NONE, "Missing pool id parameter" },
|
||||||
|
{ SEVERITY_ERR, MSG_INVPID, PARAM_POOLMAX, "Invalid pool id %d - range is 0 - %d" },
|
||||||
|
{ SEVERITY_SUCC, MSG_SWITCHP, PARAM_POOL, "Switching to pool %d:'%s'" },
|
||||||
|
{ SEVERITY_ERR, MSG_MISVAL, PARAM_NONE, "Missing comma after GPU number" },
|
||||||
|
{ SEVERITY_ERR, MSG_NOADL, PARAM_NONE, "ADL is not available" },
|
||||||
|
{ SEVERITY_ERR, MSG_NOGPUADL,PARAM_GPU, "GPU %d does not have ADL" },
|
||||||
|
{ SEVERITY_ERR, MSG_INVINT, PARAM_STR, "Invalid intensity (%s) - must be '" _DYNAMIC "' or range -10 - 10" },
|
||||||
|
{ SEVERITY_INFO, MSG_GPUINT, PARAM_BOTH, "GPU %d set new intensity to %s" },
|
||||||
|
{ SEVERITY_SUCC, MSG_MINECON, PARAM_NONE, "CGMiner config" },
|
||||||
|
{ SEVERITY_ERR, MSG_GPUMERR, PARAM_BOTH, "Setting GPU %d memoryclock to (%s) reported failure" },
|
||||||
|
{ SEVERITY_SUCC, MSG_GPUMEM, PARAM_BOTH, "Setting GPU %d memoryclock to (%s) reported succeess" },
|
||||||
|
{ SEVERITY_ERR, MSG_GPUEERR, PARAM_BOTH, "Setting GPU %d clock to (%s) reported failure" },
|
||||||
|
{ SEVERITY_SUCC, MSG_GPUENG, PARAM_BOTH, "Setting GPU %d clock to (%s) reported succeess" },
|
||||||
|
{ SEVERITY_ERR, MSG_GPUVERR, PARAM_BOTH, "Setting GPU %d vddc to (%s) reported failure" },
|
||||||
|
{ SEVERITY_SUCC, MSG_GPUVDDC, PARAM_BOTH, "Setting GPU %d vddc to (%s) reported succeess" },
|
||||||
|
{ SEVERITY_ERR, MSG_GPUFERR, PARAM_BOTH, "Setting GPU %d fan to (%s) reported failure" },
|
||||||
|
{ SEVERITY_SUCC, MSG_GPUFAN, PARAM_BOTH, "Setting GPU %d fan to (%s) reported succeess" },
|
||||||
|
{ SEVERITY_ERR, MSG_MISFN, PARAM_NONE, "Missing save filename parameter" },
|
||||||
|
{ SEVERITY_ERR, MSG_BADFN, PARAM_STR, "Can't open or create save file '%s'" },
|
||||||
|
{ SEVERITY_ERR, MSG_SAVED, PARAM_STR, "Configuration saved to file '%s'" },
|
||||||
{ SEVERITY_FAIL }
|
{ SEVERITY_FAIL }
|
||||||
};
|
};
|
||||||
|
|
||||||
static const char *APIVERSION = "0.8";
|
|
||||||
static const char *DEAD = "Dead";
|
|
||||||
static const char *SICK = "Sick";
|
|
||||||
static const char *NOSTART = "NoStart";
|
|
||||||
static const char *DISABLED = "Disabled";
|
|
||||||
static const char *ALIVE = "Alive";
|
|
||||||
static const char *DYNAMIC = "D";
|
|
||||||
|
|
||||||
static const char *YES = "Y";
|
|
||||||
static const char *NO = "N";
|
|
||||||
|
|
||||||
static int bye = 0;
|
static int bye = 0;
|
||||||
static bool ping = true;
|
static bool ping = true;
|
||||||
|
|
||||||
// All replies (except BYE) start with a message
|
// All replies (except BYE) start with a message
|
||||||
// thus for JSON, message() inserts JSON_START at the front
|
// thus for JSON, message() inserts JSON_START at the front
|
||||||
// and send_result() adds JSON_END at the end
|
// and send_result() adds JSON_END at the end
|
||||||
static char *message(int messageid, int gpuid, bool isjson)
|
static char *message(int messageid, int paramid, char *param2, bool isjson)
|
||||||
{
|
{
|
||||||
char severity;
|
char severity;
|
||||||
char *ptr;
|
char *ptr;
|
||||||
@ -333,17 +381,21 @@ static char *message(int messageid, int gpuid, bool isjson)
|
|||||||
|
|
||||||
switch(codes[i].params) {
|
switch(codes[i].params) {
|
||||||
case PARAM_GPU:
|
case PARAM_GPU:
|
||||||
sprintf(ptr, codes[i].description, gpuid);
|
|
||||||
break;
|
|
||||||
case PARAM_CPU:
|
case PARAM_CPU:
|
||||||
sprintf(ptr, codes[i].description, gpuid);
|
sprintf(ptr, codes[i].description, paramid);
|
||||||
|
break;
|
||||||
|
case PARAM_POOL:
|
||||||
|
sprintf(ptr, codes[i].description, paramid, pools[paramid]->rpc_url);
|
||||||
break;
|
break;
|
||||||
case PARAM_GPUMAX:
|
case PARAM_GPUMAX:
|
||||||
sprintf(ptr, codes[i].description, gpuid, nDevs - 1);
|
sprintf(ptr, codes[i].description, paramid, nDevs - 1);
|
||||||
break;
|
break;
|
||||||
case PARAM_PMAX:
|
case PARAM_PMAX:
|
||||||
sprintf(ptr, codes[i].description, total_pools);
|
sprintf(ptr, codes[i].description, total_pools);
|
||||||
break;
|
break;
|
||||||
|
case PARAM_POOLMAX:
|
||||||
|
sprintf(ptr, codes[i].description, paramid, total_pools - 1);
|
||||||
|
break;
|
||||||
#ifdef WANT_CPUMINE
|
#ifdef WANT_CPUMINE
|
||||||
case PARAM_GCMAX:
|
case PARAM_GCMAX:
|
||||||
if (opt_n_threads > 0)
|
if (opt_n_threads > 0)
|
||||||
@ -361,6 +413,12 @@ static char *message(int messageid, int gpuid, bool isjson)
|
|||||||
case PARAM_CMD:
|
case PARAM_CMD:
|
||||||
sprintf(ptr, codes[i].description, JSON_COMMAND);
|
sprintf(ptr, codes[i].description, JSON_COMMAND);
|
||||||
break;
|
break;
|
||||||
|
case PARAM_STR:
|
||||||
|
sprintf(ptr, codes[i].description, param2);
|
||||||
|
break;
|
||||||
|
case PARAM_BOTH:
|
||||||
|
sprintf(ptr, codes[i].description, paramid, param2);
|
||||||
|
break;
|
||||||
case PARAM_NONE:
|
case PARAM_NONE:
|
||||||
default:
|
default:
|
||||||
strcpy(ptr, codes[i].description);
|
strcpy(ptr, codes[i].description);
|
||||||
@ -387,19 +445,52 @@ static char *message(int messageid, int gpuid, bool isjson)
|
|||||||
return msg_buffer;
|
return msg_buffer;
|
||||||
}
|
}
|
||||||
|
|
||||||
void apiversion(SOCKETTYPE c, char *param, bool isjson)
|
static void apiversion(SOCKETTYPE c, char *param, bool isjson)
|
||||||
{
|
{
|
||||||
if (isjson)
|
if (isjson)
|
||||||
sprintf(io_buffer, "%s," JSON_VERSION "{\"CGMiner\":\"%s\",\"API\":\"%s\"}" JSON_CLOSE,
|
sprintf(io_buffer, "%s," JSON_VERSION "{\"CGMiner\":\"%s\",\"API\":\"%s\"}" JSON_CLOSE,
|
||||||
message(MSG_VERSION, 0, isjson),
|
message(MSG_VERSION, 0, NULL, isjson),
|
||||||
VERSION, APIVERSION);
|
VERSION, APIVERSION);
|
||||||
else
|
else
|
||||||
sprintf(io_buffer, "%s" _VERSION ",CGMiner=%s,API=%s%c",
|
sprintf(io_buffer, "%s" _VERSION ",CGMiner=%s,API=%s%c",
|
||||||
message(MSG_VERSION, 0, isjson),
|
message(MSG_VERSION, 0, NULL, isjson),
|
||||||
VERSION, APIVERSION, SEPARATOR);
|
VERSION, APIVERSION, SEPARATOR);
|
||||||
}
|
}
|
||||||
|
|
||||||
void gpustatus(int gpu, bool isjson)
|
static void minerconfig(SOCKETTYPE c, char *param, bool isjson)
|
||||||
|
{
|
||||||
|
char buf[BUFSIZ];
|
||||||
|
int cpucount = 0;
|
||||||
|
char *adlinuse = (char *)NO;
|
||||||
|
#ifdef HAVE_ADL
|
||||||
|
const char *adl = YES;
|
||||||
|
int i;
|
||||||
|
|
||||||
|
for (i = 0; i < nDevs; i++) {
|
||||||
|
if (gpus[i].has_adl) {
|
||||||
|
adlinuse = (char *)YES;
|
||||||
|
break;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
#else
|
||||||
|
const char *adl = NO;
|
||||||
|
#endif
|
||||||
|
|
||||||
|
#ifdef WANT_CPUMINE
|
||||||
|
cpucount = opt_n_threads > 0 ? num_processors : 0;
|
||||||
|
#endif
|
||||||
|
|
||||||
|
strcpy(io_buffer, message(MSG_MINECON, 0, NULL, isjson));
|
||||||
|
|
||||||
|
if (isjson)
|
||||||
|
sprintf(buf, "," JSON_MINECON "{\"GPU Count\":%d,\"CPU Count\":%d,\"Pool Count\":%d,\"ADL\":\"%s\",\"ADL in use\":\"%s\",\"Strategy\":\"%s\"}" JSON_CLOSE, nDevs, cpucount, total_pools, adl, adlinuse, strategies[pool_strategy].s);
|
||||||
|
else
|
||||||
|
sprintf(buf, _MINECON ",GPU Count=%d,CPU Count=%d,Pool Count=%d,ADL=%s,ADL in use=%s,Strategy=%s%c", nDevs, cpucount, total_pools, adl, adlinuse, strategies[pool_strategy].s, SEPARATOR);
|
||||||
|
|
||||||
|
strcat(io_buffer, buf);
|
||||||
|
}
|
||||||
|
|
||||||
|
static void gpustatus(int gpu, bool isjson)
|
||||||
{
|
{
|
||||||
char intensity[20];
|
char intensity[20];
|
||||||
char buf[BUFSIZ];
|
char buf[BUFSIZ];
|
||||||
@ -455,7 +546,7 @@ void gpustatus(int gpu, bool isjson)
|
|||||||
}
|
}
|
||||||
|
|
||||||
#ifdef WANT_CPUMINE
|
#ifdef WANT_CPUMINE
|
||||||
void cpustatus(int cpu, bool isjson)
|
static void cpustatus(int cpu, bool isjson)
|
||||||
{
|
{
|
||||||
char buf[BUFSIZ];
|
char buf[BUFSIZ];
|
||||||
|
|
||||||
@ -482,16 +573,16 @@ void cpustatus(int cpu, bool isjson)
|
|||||||
}
|
}
|
||||||
#endif
|
#endif
|
||||||
|
|
||||||
void devstatus(SOCKETTYPE c, char *param, bool isjson)
|
static void devstatus(SOCKETTYPE c, char *param, bool isjson)
|
||||||
{
|
{
|
||||||
int i;
|
int i;
|
||||||
|
|
||||||
if (nDevs == 0 && opt_n_threads == 0) {
|
if (nDevs == 0 && opt_n_threads == 0) {
|
||||||
strcpy(io_buffer, message(MSG_NODEVS, 0, isjson));
|
strcpy(io_buffer, message(MSG_NODEVS, 0, NULL, isjson));
|
||||||
return;
|
return;
|
||||||
}
|
}
|
||||||
|
|
||||||
strcpy(io_buffer, message(MSG_DEVS, 0, isjson));
|
strcpy(io_buffer, message(MSG_DEVS, 0, NULL, isjson));
|
||||||
|
|
||||||
if (isjson) {
|
if (isjson) {
|
||||||
strcat(io_buffer, COMMA);
|
strcat(io_buffer, COMMA);
|
||||||
@ -519,27 +610,27 @@ void devstatus(SOCKETTYPE c, char *param, bool isjson)
|
|||||||
strcat(io_buffer, JSON_CLOSE);
|
strcat(io_buffer, JSON_CLOSE);
|
||||||
}
|
}
|
||||||
|
|
||||||
void gpudev(SOCKETTYPE c, char *param, bool isjson)
|
static void gpudev(SOCKETTYPE c, char *param, bool isjson)
|
||||||
{
|
{
|
||||||
int id;
|
int id;
|
||||||
|
|
||||||
if (nDevs == 0) {
|
if (nDevs == 0) {
|
||||||
strcpy(io_buffer, message(MSG_GPUNON, 0, isjson));
|
strcpy(io_buffer, message(MSG_GPUNON, 0, NULL, isjson));
|
||||||
return;
|
return;
|
||||||
}
|
}
|
||||||
|
|
||||||
if (param == NULL || *param == '\0') {
|
if (param == NULL || *param == '\0') {
|
||||||
strcpy(io_buffer, message(MSG_MISID, 0, isjson));
|
strcpy(io_buffer, message(MSG_MISID, 0, NULL, isjson));
|
||||||
return;
|
return;
|
||||||
}
|
}
|
||||||
|
|
||||||
id = atoi(param);
|
id = atoi(param);
|
||||||
if (id < 0 || id >= nDevs) {
|
if (id < 0 || id >= nDevs) {
|
||||||
strcpy(io_buffer, message(MSG_INVGPU, id, isjson));
|
strcpy(io_buffer, message(MSG_INVGPU, id, NULL, isjson));
|
||||||
return;
|
return;
|
||||||
}
|
}
|
||||||
|
|
||||||
strcpy(io_buffer, message(MSG_GPUDEV, id, isjson));
|
strcpy(io_buffer, message(MSG_GPUDEV, id, NULL, isjson));
|
||||||
|
|
||||||
if (isjson) {
|
if (isjson) {
|
||||||
strcat(io_buffer, COMMA);
|
strcat(io_buffer, COMMA);
|
||||||
@ -553,27 +644,27 @@ void gpudev(SOCKETTYPE c, char *param, bool isjson)
|
|||||||
}
|
}
|
||||||
|
|
||||||
#ifdef WANT_CPUMINE
|
#ifdef WANT_CPUMINE
|
||||||
void cpudev(SOCKETTYPE c, char *param, bool isjson)
|
static void cpudev(SOCKETTYPE c, char *param, bool isjson)
|
||||||
{
|
{
|
||||||
int id;
|
int id;
|
||||||
|
|
||||||
if (opt_n_threads == 0) {
|
if (opt_n_threads == 0) {
|
||||||
strcpy(io_buffer, message(MSG_CPUNON, 0, isjson));
|
strcpy(io_buffer, message(MSG_CPUNON, 0, NULL, isjson));
|
||||||
return;
|
return;
|
||||||
}
|
}
|
||||||
|
|
||||||
if (param == NULL || *param == '\0') {
|
if (param == NULL || *param == '\0') {
|
||||||
strcpy(io_buffer, message(MSG_MISID, 0, isjson));
|
strcpy(io_buffer, message(MSG_MISID, 0, NULL, isjson));
|
||||||
return;
|
return;
|
||||||
}
|
}
|
||||||
|
|
||||||
id = atoi(param);
|
id = atoi(param);
|
||||||
if (id < 0 || id >= num_processors) {
|
if (id < 0 || id >= num_processors) {
|
||||||
strcpy(io_buffer, message(MSG_INVCPU, id, isjson));
|
strcpy(io_buffer, message(MSG_INVCPU, id, NULL, isjson));
|
||||||
return;
|
return;
|
||||||
}
|
}
|
||||||
|
|
||||||
strcpy(io_buffer, message(MSG_CPUDEV, id, isjson));
|
strcpy(io_buffer, message(MSG_CPUDEV, id, NULL, isjson));
|
||||||
|
|
||||||
if (isjson) {
|
if (isjson) {
|
||||||
strcat(io_buffer, COMMA);
|
strcat(io_buffer, COMMA);
|
||||||
@ -587,18 +678,18 @@ void cpudev(SOCKETTYPE c, char *param, bool isjson)
|
|||||||
}
|
}
|
||||||
#endif
|
#endif
|
||||||
|
|
||||||
void poolstatus(SOCKETTYPE c, char *param, bool isjson)
|
static void poolstatus(SOCKETTYPE c, char *param, bool isjson)
|
||||||
{
|
{
|
||||||
char buf[BUFSIZ];
|
char buf[BUFSIZ];
|
||||||
char *status, *lp;
|
char *status, *lp;
|
||||||
int i;
|
int i;
|
||||||
|
|
||||||
if (total_pools == 0) {
|
if (total_pools == 0) {
|
||||||
strcpy(io_buffer, message(MSG_NOPOOL, 0, isjson));
|
strcpy(io_buffer, message(MSG_NOPOOL, 0, NULL, isjson));
|
||||||
return;
|
return;
|
||||||
}
|
}
|
||||||
|
|
||||||
strcpy(io_buffer, message(MSG_POOL, 0, isjson));
|
strcpy(io_buffer, message(MSG_POOL, 0, NULL, isjson));
|
||||||
|
|
||||||
if (isjson) {
|
if (isjson) {
|
||||||
strcat(io_buffer, COMMA);
|
strcat(io_buffer, COMMA);
|
||||||
@ -649,7 +740,7 @@ void poolstatus(SOCKETTYPE c, char *param, bool isjson)
|
|||||||
strcat(io_buffer, JSON_CLOSE);
|
strcat(io_buffer, JSON_CLOSE);
|
||||||
}
|
}
|
||||||
|
|
||||||
void summary(SOCKETTYPE c, char *param, bool isjson)
|
static void summary(SOCKETTYPE c, char *param, bool isjson)
|
||||||
{
|
{
|
||||||
double utility, mhs;
|
double utility, mhs;
|
||||||
|
|
||||||
@ -665,14 +756,14 @@ void summary(SOCKETTYPE c, char *param, bool isjson)
|
|||||||
#ifdef WANT_CPUMINE
|
#ifdef WANT_CPUMINE
|
||||||
if (isjson)
|
if (isjson)
|
||||||
sprintf(io_buffer, "%s," JSON_SUMMARY "{\"Elapsed\":%.0f,\"Algorithm\":\"%s\",\"MHS av\":%.2f,\"Found Blocks\":%d,\"Getworks\":%d,\"Accepted\":%d,\"Rejected\":%d,\"Hardware Errors\":%d,\"Utility\":%.2f,\"Discarded\":%d,\"Stale\":%d,\"Get Failures\":%d,\"Local Work\":%u,\"Remote Failures\":%u,\"Network Blocks\":%u}" JSON_CLOSE,
|
sprintf(io_buffer, "%s," JSON_SUMMARY "{\"Elapsed\":%.0f,\"Algorithm\":\"%s\",\"MHS av\":%.2f,\"Found Blocks\":%d,\"Getworks\":%d,\"Accepted\":%d,\"Rejected\":%d,\"Hardware Errors\":%d,\"Utility\":%.2f,\"Discarded\":%d,\"Stale\":%d,\"Get Failures\":%d,\"Local Work\":%u,\"Remote Failures\":%u,\"Network Blocks\":%u}" JSON_CLOSE,
|
||||||
message(MSG_SUMM, 0, isjson),
|
message(MSG_SUMM, 0, NULL, isjson),
|
||||||
total_secs, algo, mhs, found_blocks,
|
total_secs, algo, mhs, found_blocks,
|
||||||
total_getworks, total_accepted, total_rejected,
|
total_getworks, total_accepted, total_rejected,
|
||||||
hw_errors, utility, total_discarded, total_stale,
|
hw_errors, utility, total_discarded, total_stale,
|
||||||
total_go, local_work, total_ro, new_blocks);
|
total_go, local_work, total_ro, new_blocks);
|
||||||
else
|
else
|
||||||
sprintf(io_buffer, "%s" _SUMMARY ",Elapsed=%.0f,Algorithm=%s,MHS av=%.2f,Found Blocks=%d,Getworks=%d,Accepted=%d,Rejected=%d,Hardware Errors=%d,Utility=%.2f,Discarded=%d,Stale=%d,Get Failures=%d,Local Work=%u,Remote Failures=%u,Network Blocks=%u%c",
|
sprintf(io_buffer, "%s" _SUMMARY ",Elapsed=%.0f,Algorithm=%s,MHS av=%.2f,Found Blocks=%d,Getworks=%d,Accepted=%d,Rejected=%d,Hardware Errors=%d,Utility=%.2f,Discarded=%d,Stale=%d,Get Failures=%d,Local Work=%u,Remote Failures=%u,Network Blocks=%u%c",
|
||||||
message(MSG_SUMM, 0, isjson),
|
message(MSG_SUMM, 0, NULL, isjson),
|
||||||
total_secs, algo, mhs, found_blocks,
|
total_secs, algo, mhs, found_blocks,
|
||||||
total_getworks, total_accepted, total_rejected,
|
total_getworks, total_accepted, total_rejected,
|
||||||
hw_errors, utility, total_discarded, total_stale,
|
hw_errors, utility, total_discarded, total_stale,
|
||||||
@ -680,14 +771,14 @@ void summary(SOCKETTYPE c, char *param, bool isjson)
|
|||||||
#else
|
#else
|
||||||
if (isjson)
|
if (isjson)
|
||||||
sprintf(io_buffer, "%s," JSON_SUMMARY "{\"Elapsed\":%.0f,\"MHS av\":%.2f,\"Found Blocks\":%d,\"Getworks\":%d,\"Accepted\":%d,\"Rejected\":%d,\"Hardware Errors\":%d,\"Utility\":%.2f,\"Discarded\":%d,\"Stale\":%d,\"Get Failures\":%d,\"Local Work\":%u,\"Remote Failures\":%u,\"Network Blocks\":%u}" JSON_CLOSE,
|
sprintf(io_buffer, "%s," JSON_SUMMARY "{\"Elapsed\":%.0f,\"MHS av\":%.2f,\"Found Blocks\":%d,\"Getworks\":%d,\"Accepted\":%d,\"Rejected\":%d,\"Hardware Errors\":%d,\"Utility\":%.2f,\"Discarded\":%d,\"Stale\":%d,\"Get Failures\":%d,\"Local Work\":%u,\"Remote Failures\":%u,\"Network Blocks\":%u}" JSON_CLOSE,
|
||||||
message(MSG_SUMM, 0, isjson),
|
message(MSG_SUMM, 0, NULL, isjson),
|
||||||
total_secs, mhs, found_blocks,
|
total_secs, mhs, found_blocks,
|
||||||
total_getworks, total_accepted, total_rejected,
|
total_getworks, total_accepted, total_rejected,
|
||||||
hw_errors, utility, total_discarded, total_stale,
|
hw_errors, utility, total_discarded, total_stale,
|
||||||
total_go, local_work, total_ro, new_blocks);
|
total_go, local_work, total_ro, new_blocks);
|
||||||
else
|
else
|
||||||
sprintf(io_buffer, "%s" _SUMMARY ",Elapsed=%.0f,MHS av=%.2f,Found Blocks=%d,Getworks=%d,Accepted=%d,Rejected=%d,Hardware Errors=%d,Utility=%.2f,Discarded=%d,Stale=%d,Get Failures=%d,Local Work=%u,Remote Failures=%u,Network Blocks=%u%c",
|
sprintf(io_buffer, "%s" _SUMMARY ",Elapsed=%.0f,MHS av=%.2f,Found Blocks=%d,Getworks=%d,Accepted=%d,Rejected=%d,Hardware Errors=%d,Utility=%.2f,Discarded=%d,Stale=%d,Get Failures=%d,Local Work=%u,Remote Failures=%u,Network Blocks=%u%c",
|
||||||
message(MSG_SUMM, 0, isjson),
|
message(MSG_SUMM, 0, NULL, isjson),
|
||||||
total_secs, mhs, found_blocks,
|
total_secs, mhs, found_blocks,
|
||||||
total_getworks, total_accepted, total_rejected,
|
total_getworks, total_accepted, total_rejected,
|
||||||
hw_errors, utility, total_discarded, total_stale,
|
hw_errors, utility, total_discarded, total_stale,
|
||||||
@ -695,7 +786,7 @@ void summary(SOCKETTYPE c, char *param, bool isjson)
|
|||||||
#endif
|
#endif
|
||||||
}
|
}
|
||||||
|
|
||||||
void gpuenable(SOCKETTYPE c, char *param, bool isjson)
|
static void gpuenable(SOCKETTYPE c, char *param, bool isjson)
|
||||||
{
|
{
|
||||||
struct thr_info *thr;
|
struct thr_info *thr;
|
||||||
int gpu;
|
int gpu;
|
||||||
@ -703,23 +794,23 @@ void gpuenable(SOCKETTYPE c, char *param, bool isjson)
|
|||||||
int i;
|
int i;
|
||||||
|
|
||||||
if (gpu_threads == 0) {
|
if (gpu_threads == 0) {
|
||||||
strcpy(io_buffer, message(MSG_GPUNON, 0, isjson));
|
strcpy(io_buffer, message(MSG_GPUNON, 0, NULL, isjson));
|
||||||
return;
|
return;
|
||||||
}
|
}
|
||||||
|
|
||||||
if (param == NULL || *param == '\0') {
|
if (param == NULL || *param == '\0') {
|
||||||
strcpy(io_buffer, message(MSG_MISID, 0, isjson));
|
strcpy(io_buffer, message(MSG_MISID, 0, NULL, isjson));
|
||||||
return;
|
return;
|
||||||
}
|
}
|
||||||
|
|
||||||
id = atoi(param);
|
id = atoi(param);
|
||||||
if (id < 0 || id >= nDevs) {
|
if (id < 0 || id >= nDevs) {
|
||||||
strcpy(io_buffer, message(MSG_INVGPU, id, isjson));
|
strcpy(io_buffer, message(MSG_INVGPU, id, NULL, isjson));
|
||||||
return;
|
return;
|
||||||
}
|
}
|
||||||
|
|
||||||
if (gpus[id].enabled) {
|
if (gpus[id].enabled) {
|
||||||
strcpy(io_buffer, message(MSG_ALRENA, id, isjson));
|
strcpy(io_buffer, message(MSG_ALRENA, id, NULL, isjson));
|
||||||
return;
|
return;
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -728,7 +819,7 @@ void gpuenable(SOCKETTYPE c, char *param, bool isjson)
|
|||||||
if (gpu == id) {
|
if (gpu == id) {
|
||||||
thr = &thr_info[i];
|
thr = &thr_info[i];
|
||||||
if (thr->cgpu->status != LIFE_WELL) {
|
if (thr->cgpu->status != LIFE_WELL) {
|
||||||
strcpy(io_buffer, message(MSG_GPUMRE, id, isjson));
|
strcpy(io_buffer, message(MSG_GPUMRE, id, NULL, isjson));
|
||||||
return;
|
return;
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -738,69 +829,69 @@ void gpuenable(SOCKETTYPE c, char *param, bool isjson)
|
|||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
strcpy(io_buffer, message(MSG_GPUREN, id, isjson));
|
strcpy(io_buffer, message(MSG_GPUREN, id, NULL, isjson));
|
||||||
}
|
}
|
||||||
|
|
||||||
void gpudisable(SOCKETTYPE c, char *param, bool isjson)
|
static void gpudisable(SOCKETTYPE c, char *param, bool isjson)
|
||||||
{
|
{
|
||||||
int id;
|
int id;
|
||||||
|
|
||||||
if (nDevs == 0) {
|
if (nDevs == 0) {
|
||||||
strcpy(io_buffer, message(MSG_GPUNON, 0, isjson));
|
strcpy(io_buffer, message(MSG_GPUNON, 0, NULL, isjson));
|
||||||
return;
|
return;
|
||||||
}
|
}
|
||||||
|
|
||||||
if (param == NULL || *param == '\0') {
|
if (param == NULL || *param == '\0') {
|
||||||
strcpy(io_buffer, message(MSG_MISID, 0, isjson));
|
strcpy(io_buffer, message(MSG_MISID, 0, NULL, isjson));
|
||||||
return;
|
return;
|
||||||
}
|
}
|
||||||
|
|
||||||
id = atoi(param);
|
id = atoi(param);
|
||||||
if (id < 0 || id >= nDevs) {
|
if (id < 0 || id >= nDevs) {
|
||||||
strcpy(io_buffer, message(MSG_INVGPU, id, isjson));
|
strcpy(io_buffer, message(MSG_INVGPU, id, NULL, isjson));
|
||||||
return;
|
return;
|
||||||
}
|
}
|
||||||
|
|
||||||
if (!gpus[id].enabled) {
|
if (!gpus[id].enabled) {
|
||||||
strcpy(io_buffer, message(MSG_ALRDIS, id, isjson));
|
strcpy(io_buffer, message(MSG_ALRDIS, id, NULL, isjson));
|
||||||
return;
|
return;
|
||||||
}
|
}
|
||||||
|
|
||||||
gpus[id].enabled = false;
|
gpus[id].enabled = false;
|
||||||
|
|
||||||
strcpy(io_buffer, message(MSG_GPUDIS, id, isjson));
|
strcpy(io_buffer, message(MSG_GPUDIS, id, NULL, isjson));
|
||||||
}
|
}
|
||||||
|
|
||||||
void gpurestart(SOCKETTYPE c, char *param, bool isjson)
|
static void gpurestart(SOCKETTYPE c, char *param, bool isjson)
|
||||||
{
|
{
|
||||||
int id;
|
int id;
|
||||||
|
|
||||||
if (nDevs == 0) {
|
if (nDevs == 0) {
|
||||||
strcpy(io_buffer, message(MSG_GPUNON, 0, isjson));
|
strcpy(io_buffer, message(MSG_GPUNON, 0, NULL, isjson));
|
||||||
return;
|
return;
|
||||||
}
|
}
|
||||||
|
|
||||||
if (param == NULL || *param == '\0') {
|
if (param == NULL || *param == '\0') {
|
||||||
strcpy(io_buffer, message(MSG_MISID, 0, isjson));
|
strcpy(io_buffer, message(MSG_MISID, 0, NULL, isjson));
|
||||||
return;
|
return;
|
||||||
}
|
}
|
||||||
|
|
||||||
id = atoi(param);
|
id = atoi(param);
|
||||||
if (id < 0 || id >= nDevs) {
|
if (id < 0 || id >= nDevs) {
|
||||||
strcpy(io_buffer, message(MSG_INVGPU, id, isjson));
|
strcpy(io_buffer, message(MSG_INVGPU, id, NULL, isjson));
|
||||||
return;
|
return;
|
||||||
}
|
}
|
||||||
|
|
||||||
reinit_device(&gpus[id]);
|
reinit_device(&gpus[id]);
|
||||||
|
|
||||||
strcpy(io_buffer, message(MSG_GPUREI, id, isjson));
|
strcpy(io_buffer, message(MSG_GPUREI, id, NULL, isjson));
|
||||||
}
|
}
|
||||||
|
|
||||||
void gpucount(SOCKETTYPE c, char *param, bool isjson)
|
static void gpucount(SOCKETTYPE c, char *param, bool isjson)
|
||||||
{
|
{
|
||||||
char buf[BUFSIZ];
|
char buf[BUFSIZ];
|
||||||
|
|
||||||
strcpy(io_buffer, message(MSG_NUMGPU, 0, isjson));
|
strcpy(io_buffer, message(MSG_NUMGPU, 0, NULL, isjson));
|
||||||
|
|
||||||
if (isjson)
|
if (isjson)
|
||||||
sprintf(buf, "," JSON_GPUS "{\"Count\":%d}" JSON_CLOSE, nDevs);
|
sprintf(buf, "," JSON_GPUS "{\"Count\":%d}" JSON_CLOSE, nDevs);
|
||||||
@ -810,7 +901,7 @@ void gpucount(SOCKETTYPE c, char *param, bool isjson)
|
|||||||
strcat(io_buffer, buf);
|
strcat(io_buffer, buf);
|
||||||
}
|
}
|
||||||
|
|
||||||
void cpucount(SOCKETTYPE c, char *param, bool isjson)
|
static void cpucount(SOCKETTYPE c, char *param, bool isjson)
|
||||||
{
|
{
|
||||||
char buf[BUFSIZ];
|
char buf[BUFSIZ];
|
||||||
int count = 0;
|
int count = 0;
|
||||||
@ -819,7 +910,7 @@ void cpucount(SOCKETTYPE c, char *param, bool isjson)
|
|||||||
count = opt_n_threads > 0 ? num_processors : 0;
|
count = opt_n_threads > 0 ? num_processors : 0;
|
||||||
#endif
|
#endif
|
||||||
|
|
||||||
strcpy(io_buffer, message(MSG_NUMCPU, 0, isjson));
|
strcpy(io_buffer, message(MSG_NUMCPU, 0, NULL, isjson));
|
||||||
|
|
||||||
if (isjson)
|
if (isjson)
|
||||||
sprintf(buf, "," JSON_CPUS "{\"Count\":%d}" JSON_CLOSE, count);
|
sprintf(buf, "," JSON_CPUS "{\"Count\":%d}" JSON_CLOSE, count);
|
||||||
@ -829,7 +920,167 @@ void cpucount(SOCKETTYPE c, char *param, bool isjson)
|
|||||||
strcat(io_buffer, buf);
|
strcat(io_buffer, buf);
|
||||||
}
|
}
|
||||||
|
|
||||||
void send_result(SOCKETTYPE c, bool isjson);
|
static void switchpool(SOCKETTYPE c, char *param, bool isjson)
|
||||||
|
{
|
||||||
|
struct pool *pool;
|
||||||
|
int id;
|
||||||
|
|
||||||
|
if (total_pools == 0) {
|
||||||
|
strcpy(io_buffer, message(MSG_NOPOOL, 0, NULL, isjson));
|
||||||
|
return;
|
||||||
|
}
|
||||||
|
|
||||||
|
if (param == NULL || *param == '\0') {
|
||||||
|
strcpy(io_buffer, message(MSG_MISPID, 0, NULL, isjson));
|
||||||
|
return;
|
||||||
|
}
|
||||||
|
|
||||||
|
id = atoi(param);
|
||||||
|
if (id < 0 || id >= total_pools) {
|
||||||
|
strcpy(io_buffer, message(MSG_INVPID, id, NULL, isjson));
|
||||||
|
return;
|
||||||
|
}
|
||||||
|
|
||||||
|
pool = pools[id];
|
||||||
|
pool->enabled = true;
|
||||||
|
switch_pools(pool);
|
||||||
|
|
||||||
|
strcpy(io_buffer, message(MSG_SWITCHP, id, NULL, isjson));
|
||||||
|
}
|
||||||
|
|
||||||
|
static bool splitgpuvalue(char *param, int *gpu, char **value, bool isjson)
|
||||||
|
{
|
||||||
|
int id;
|
||||||
|
char *gpusep;
|
||||||
|
|
||||||
|
if (nDevs == 0) {
|
||||||
|
strcpy(io_buffer, message(MSG_GPUNON, 0, NULL, isjson));
|
||||||
|
return false;
|
||||||
|
}
|
||||||
|
|
||||||
|
if (param == NULL || *param == '\0') {
|
||||||
|
strcpy(io_buffer, message(MSG_MISID, 0, NULL, isjson));
|
||||||
|
return false;
|
||||||
|
}
|
||||||
|
|
||||||
|
gpusep = strchr(param, GPUSEP);
|
||||||
|
if (gpusep == NULL) {
|
||||||
|
strcpy(io_buffer, message(MSG_MISVAL, 0, NULL, isjson));
|
||||||
|
return false;
|
||||||
|
}
|
||||||
|
|
||||||
|
*(gpusep++) = '\0';
|
||||||
|
|
||||||
|
id = atoi(param);
|
||||||
|
if (id < 0 || id >= nDevs) {
|
||||||
|
strcpy(io_buffer, message(MSG_INVGPU, id, NULL, isjson));
|
||||||
|
return false;
|
||||||
|
}
|
||||||
|
|
||||||
|
*gpu = id;
|
||||||
|
*value = gpusep;
|
||||||
|
|
||||||
|
return true;
|
||||||
|
}
|
||||||
|
|
||||||
|
static void gpuintensity(SOCKETTYPE c, char *param, bool isjson)
|
||||||
|
{
|
||||||
|
int id;
|
||||||
|
char *value;
|
||||||
|
int intensity;
|
||||||
|
char intensitystr[7];
|
||||||
|
|
||||||
|
if (!splitgpuvalue(param, &id, &value, isjson))
|
||||||
|
return;
|
||||||
|
|
||||||
|
if (!strncasecmp(value, DYNAMIC, 1)) {
|
||||||
|
gpus[id].dynamic = true;
|
||||||
|
strcpy(intensitystr, DYNAMIC);
|
||||||
|
}
|
||||||
|
else {
|
||||||
|
intensity = atoi(value);
|
||||||
|
if (intensity < -10 || intensity > 10) {
|
||||||
|
strcpy(io_buffer, message(MSG_INVINT, 0, value, isjson));
|
||||||
|
return;
|
||||||
|
}
|
||||||
|
|
||||||
|
gpus[id].dynamic = false;
|
||||||
|
gpus[id].intensity = intensity;
|
||||||
|
sprintf(intensitystr, "%d", intensity);
|
||||||
|
}
|
||||||
|
|
||||||
|
strcpy(io_buffer, message(MSG_GPUINT, id, intensitystr, isjson));
|
||||||
|
}
|
||||||
|
|
||||||
|
static void gpumem(SOCKETTYPE c, char *param, bool isjson)
|
||||||
|
{
|
||||||
|
int id;
|
||||||
|
char *value;
|
||||||
|
int clock;
|
||||||
|
|
||||||
|
if (!splitgpuvalue(param, &id, &value, isjson))
|
||||||
|
return;
|
||||||
|
|
||||||
|
clock = atoi(value);
|
||||||
|
|
||||||
|
if (set_memoryclock(id, clock))
|
||||||
|
strcpy(io_buffer, message(MSG_GPUMERR, id, value, isjson));
|
||||||
|
else
|
||||||
|
strcpy(io_buffer, message(MSG_GPUMEM, id, value, isjson));
|
||||||
|
}
|
||||||
|
|
||||||
|
static void gpuengine(SOCKETTYPE c, char *param, bool isjson)
|
||||||
|
{
|
||||||
|
int id;
|
||||||
|
char *value;
|
||||||
|
int clock;
|
||||||
|
|
||||||
|
if (!splitgpuvalue(param, &id, &value, isjson))
|
||||||
|
return;
|
||||||
|
|
||||||
|
clock = atoi(value);
|
||||||
|
|
||||||
|
if (set_engineclock(id, clock))
|
||||||
|
strcpy(io_buffer, message(MSG_GPUEERR, id, value, isjson));
|
||||||
|
else
|
||||||
|
strcpy(io_buffer, message(MSG_GPUENG, id, value, isjson));
|
||||||
|
}
|
||||||
|
|
||||||
|
static void gpufan(SOCKETTYPE c, char *param, bool isjson)
|
||||||
|
{
|
||||||
|
int id;
|
||||||
|
char *value;
|
||||||
|
int fan;
|
||||||
|
|
||||||
|
if (!splitgpuvalue(param, &id, &value, isjson))
|
||||||
|
return;
|
||||||
|
|
||||||
|
fan = atoi(value);
|
||||||
|
|
||||||
|
if (set_fanspeed(id, fan))
|
||||||
|
strcpy(io_buffer, message(MSG_GPUFERR, id, value, isjson));
|
||||||
|
else
|
||||||
|
strcpy(io_buffer, message(MSG_GPUFAN, id, value, isjson));
|
||||||
|
}
|
||||||
|
|
||||||
|
static void gpuvddc(SOCKETTYPE c, char *param, bool isjson)
|
||||||
|
{
|
||||||
|
int id;
|
||||||
|
char *value;
|
||||||
|
float vddc;
|
||||||
|
|
||||||
|
if (!splitgpuvalue(param, &id, &value, isjson))
|
||||||
|
return;
|
||||||
|
|
||||||
|
vddc = atof(value);
|
||||||
|
|
||||||
|
if (set_vddc(id, vddc))
|
||||||
|
strcpy(io_buffer, message(MSG_GPUVERR, id, value, isjson));
|
||||||
|
else
|
||||||
|
strcpy(io_buffer, message(MSG_GPUVDDC, id, value, isjson));
|
||||||
|
}
|
||||||
|
|
||||||
|
static void send_result(SOCKETTYPE c, bool isjson);
|
||||||
|
|
||||||
void doquit(SOCKETTYPE c, char *param, bool isjson)
|
void doquit(SOCKETTYPE c, char *param, bool isjson)
|
||||||
{
|
{
|
||||||
@ -844,28 +1095,57 @@ void doquit(SOCKETTYPE c, char *param, bool isjson)
|
|||||||
kill_work();
|
kill_work();
|
||||||
}
|
}
|
||||||
|
|
||||||
|
void dosave(SOCKETTYPE c, char *param, bool isjson)
|
||||||
|
{
|
||||||
|
FILE *fcfg;
|
||||||
|
|
||||||
|
if (param == NULL || *param == '\0') {
|
||||||
|
strcpy(io_buffer, message(MSG_MISFN, 0, NULL, isjson));
|
||||||
|
return;
|
||||||
|
}
|
||||||
|
|
||||||
|
fcfg = fopen(param, "w");
|
||||||
|
if (!fcfg) {
|
||||||
|
strcpy(io_buffer, message(MSG_BADFN, 0, param, isjson));
|
||||||
|
return;
|
||||||
|
}
|
||||||
|
|
||||||
|
write_config(fcfg);
|
||||||
|
fclose(fcfg);
|
||||||
|
|
||||||
|
strcpy(io_buffer, message(MSG_SAVED, 0, param, isjson));
|
||||||
|
}
|
||||||
|
|
||||||
struct CMDS {
|
struct CMDS {
|
||||||
char *name;
|
char *name;
|
||||||
void (*func)(SOCKETTYPE, char *, bool);
|
void (*func)(SOCKETTYPE, char *, bool);
|
||||||
} cmds[] = {
|
} cmds[] = {
|
||||||
{ "version", apiversion },
|
{ "version", apiversion },
|
||||||
{ "devs", devstatus },
|
{ "config", minerconfig },
|
||||||
{ "pools", poolstatus },
|
{ "devs", devstatus },
|
||||||
{ "summary", summary },
|
{ "pools", poolstatus },
|
||||||
{ "gpuenable", gpuenable },
|
{ "summary", summary },
|
||||||
{ "gpudisable", gpudisable },
|
{ "gpuenable", gpuenable },
|
||||||
{ "gpurestart", gpurestart },
|
{ "gpudisable", gpudisable },
|
||||||
{ "gpu", gpudev },
|
{ "gpurestart", gpurestart },
|
||||||
|
{ "gpu", gpudev },
|
||||||
#ifdef WANT_CPUMINE
|
#ifdef WANT_CPUMINE
|
||||||
{ "cpu", cpudev },
|
{ "cpu", cpudev },
|
||||||
#endif
|
#endif
|
||||||
{ "gpucount", gpucount },
|
{ "gpucount", gpucount },
|
||||||
{ "cpucount", cpucount },
|
{ "cpucount", cpucount },
|
||||||
{ "quit", doquit },
|
{ "switchpool", switchpool },
|
||||||
|
{ "gpuintensity", gpuintensity },
|
||||||
|
{ "gpumem", gpumem},
|
||||||
|
{ "gpuengine", gpuengine},
|
||||||
|
{ "gpufan", gpufan},
|
||||||
|
{ "gpuvddc", gpuvddc},
|
||||||
|
{ "save", dosave },
|
||||||
|
{ "quit", doquit },
|
||||||
{ NULL }
|
{ NULL }
|
||||||
};
|
};
|
||||||
|
|
||||||
void send_result(SOCKETTYPE c, bool isjson)
|
static void send_result(SOCKETTYPE c, bool isjson)
|
||||||
{
|
{
|
||||||
int n;
|
int n;
|
||||||
int len;
|
int len;
|
||||||
@ -890,7 +1170,7 @@ void send_result(SOCKETTYPE c, bool isjson)
|
|||||||
|
|
||||||
}
|
}
|
||||||
|
|
||||||
void tidyup()
|
static void tidyup()
|
||||||
{
|
{
|
||||||
bye = 1;
|
bye = 1;
|
||||||
|
|
||||||
@ -1052,20 +1332,20 @@ void api(void)
|
|||||||
json_config = json_loadb(buf, n, 0, &json_err);
|
json_config = json_loadb(buf, n, 0, &json_err);
|
||||||
|
|
||||||
if (!json_is_object(json_config)) {
|
if (!json_is_object(json_config)) {
|
||||||
strcpy(io_buffer, message(MSG_INVJSON, 0, isjson));
|
strcpy(io_buffer, message(MSG_INVJSON, 0, NULL, isjson));
|
||||||
send_result(c, isjson);
|
send_result(c, isjson);
|
||||||
did = true;
|
did = true;
|
||||||
}
|
}
|
||||||
else {
|
else {
|
||||||
json_val = json_object_get(json_config, JSON_COMMAND);
|
json_val = json_object_get(json_config, JSON_COMMAND);
|
||||||
if (json_val == NULL) {
|
if (json_val == NULL) {
|
||||||
strcpy(io_buffer, message(MSG_MISSCMD, 0, isjson));
|
strcpy(io_buffer, message(MSG_MISCMD, 0, NULL, isjson));
|
||||||
send_result(c, isjson);
|
send_result(c, isjson);
|
||||||
did = true;
|
did = true;
|
||||||
}
|
}
|
||||||
else {
|
else {
|
||||||
if (!json_is_string(json_val)) {
|
if (!json_is_string(json_val)) {
|
||||||
strcpy(io_buffer, message(MSG_INVCMD, 0, isjson));
|
strcpy(io_buffer, message(MSG_INVCMD, 0, NULL, isjson));
|
||||||
send_result(c, isjson);
|
send_result(c, isjson);
|
||||||
did = true;
|
did = true;
|
||||||
}
|
}
|
||||||
@ -1097,7 +1377,7 @@ void api(void)
|
|||||||
}
|
}
|
||||||
|
|
||||||
if (!did) {
|
if (!did) {
|
||||||
strcpy(io_buffer, message(MSG_INVCMD, 0, isjson));
|
strcpy(io_buffer, message(MSG_INVCMD, 0, NULL, isjson));
|
||||||
send_result(c, isjson);
|
send_result(c, isjson);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
21
main.c
21
main.c
@ -100,18 +100,7 @@ struct workio_cmd {
|
|||||||
bool lagging;
|
bool lagging;
|
||||||
};
|
};
|
||||||
|
|
||||||
enum pool_strategy {
|
struct strategies strategies[] = {
|
||||||
POOL_FAILOVER,
|
|
||||||
POOL_ROUNDROBIN,
|
|
||||||
POOL_ROTATE,
|
|
||||||
POOL_LOADBALANCE,
|
|
||||||
};
|
|
||||||
|
|
||||||
#define TOP_STRATEGY (POOL_LOADBALANCE)
|
|
||||||
|
|
||||||
struct strategies {
|
|
||||||
const char *s;
|
|
||||||
} strategies[] = {
|
|
||||||
{ "Failover" },
|
{ "Failover" },
|
||||||
{ "Round Robin" },
|
{ "Round Robin" },
|
||||||
{ "Rotate" },
|
{ "Rotate" },
|
||||||
@ -288,8 +277,8 @@ static float opt_donation = 0.0;
|
|||||||
static struct pool donationpool;
|
static struct pool donationpool;
|
||||||
|
|
||||||
int total_pools;
|
int total_pools;
|
||||||
static enum pool_strategy pool_strategy = POOL_FAILOVER;
|
enum pool_strategy pool_strategy = POOL_FAILOVER;
|
||||||
static int opt_rotate_period;
|
int opt_rotate_period;
|
||||||
static int total_urls, total_users, total_passes, total_userpasses;
|
static int total_urls, total_users, total_passes, total_userpasses;
|
||||||
|
|
||||||
static bool curses_active = false;
|
static bool curses_active = false;
|
||||||
@ -2798,7 +2787,7 @@ static struct pool *priority_pool(int choice)
|
|||||||
return ret;
|
return ret;
|
||||||
}
|
}
|
||||||
|
|
||||||
static void switch_pools(struct pool *selected)
|
void switch_pools(struct pool *selected)
|
||||||
{
|
{
|
||||||
struct pool *pool, *last_pool;
|
struct pool *pool, *last_pool;
|
||||||
int i, pool_no;
|
int i, pool_no;
|
||||||
@ -3146,7 +3135,7 @@ static void remove_pool(struct pool *pool)
|
|||||||
total_pools--;
|
total_pools--;
|
||||||
}
|
}
|
||||||
|
|
||||||
static void write_config(FILE *fcfg)
|
void write_config(FILE *fcfg)
|
||||||
{
|
{
|
||||||
int i;
|
int i;
|
||||||
|
|
||||||
|
24
miner.h
24
miner.h
@ -176,6 +176,21 @@ enum alive {
|
|||||||
LIFE_NOSTART
|
LIFE_NOSTART
|
||||||
};
|
};
|
||||||
|
|
||||||
|
|
||||||
|
enum pool_strategy {
|
||||||
|
POOL_FAILOVER,
|
||||||
|
POOL_ROUNDROBIN,
|
||||||
|
POOL_ROTATE,
|
||||||
|
POOL_LOADBALANCE,
|
||||||
|
};
|
||||||
|
|
||||||
|
#define TOP_STRATEGY (POOL_LOADBALANCE)
|
||||||
|
|
||||||
|
struct strategies {
|
||||||
|
const char *s;
|
||||||
|
};
|
||||||
|
|
||||||
|
|
||||||
#ifdef HAVE_ADL
|
#ifdef HAVE_ADL
|
||||||
struct gpu_adl {
|
struct gpu_adl {
|
||||||
ADLTemperature lpTemperature;
|
ADLTemperature lpTemperature;
|
||||||
@ -511,6 +526,10 @@ extern float gpu_temp(int gpu);
|
|||||||
extern int gpu_fanspeed(int gpu);
|
extern int gpu_fanspeed(int gpu);
|
||||||
extern int gpu_fanpercent(int gpu);
|
extern int gpu_fanpercent(int gpu);
|
||||||
extern bool gpu_stats(int gpu, float *temp, int *engineclock, int *memclock, float *vddc, int *activity, int *fanspeed, int *fanpercent, int *powertune);
|
extern bool gpu_stats(int gpu, float *temp, int *engineclock, int *memclock, float *vddc, int *activity, int *fanspeed, int *fanpercent, int *powertune);
|
||||||
|
extern int set_fanspeed(int gpu, int iFanSpeed);
|
||||||
|
extern int set_vddc(int gpu, float fVddc);
|
||||||
|
extern int set_engineclock(int gpu, int iEngineClock);
|
||||||
|
extern int set_memoryclock(int gpu, int iMemoryClock);
|
||||||
#endif
|
#endif
|
||||||
|
|
||||||
extern void api(void);
|
extern void api(void);
|
||||||
@ -539,6 +558,9 @@ extern int total_pools;
|
|||||||
extern struct pool *pools[MAX_POOLS];
|
extern struct pool *pools[MAX_POOLS];
|
||||||
extern const char *algo_names[];
|
extern const char *algo_names[];
|
||||||
extern enum sha256_algos opt_algo;
|
extern enum sha256_algos opt_algo;
|
||||||
|
extern struct strategies strategies[];
|
||||||
|
extern enum pool_strategy pool_strategy;
|
||||||
|
extern int opt_rotate_period;
|
||||||
extern double total_mhashes_done;
|
extern double total_mhashes_done;
|
||||||
extern unsigned int new_blocks;
|
extern unsigned int new_blocks;
|
||||||
extern unsigned int found_blocks;
|
extern unsigned int found_blocks;
|
||||||
@ -639,6 +661,8 @@ extern void wlogprint(const char *f, ...);
|
|||||||
extern int curses_int(const char *query);
|
extern int curses_int(const char *query);
|
||||||
extern char *curses_input(const char *query);
|
extern char *curses_input(const char *query);
|
||||||
extern void kill_work(void);
|
extern void kill_work(void);
|
||||||
|
extern void switch_pools(struct pool *selected);
|
||||||
|
extern void write_config(FILE *fcfg);
|
||||||
extern void log_curses(int prio, const char *f, va_list ap);
|
extern void log_curses(int prio, const char *f, va_list ap);
|
||||||
extern void clear_logwin(void);
|
extern void clear_logwin(void);
|
||||||
extern void vapplog(int prio, const char *fmt, va_list ap);
|
extern void vapplog(int prio, const char *fmt, va_list ap);
|
||||||
|
Loading…
x
Reference in New Issue
Block a user