mirror of
https://github.com/GOSTSec/ccminer
synced 2025-01-28 15:34:22 +00:00
api: export card labels and count, renames stats command
renammed to "threads", stats was too much generic
This commit is contained in:
parent
7a2fe83aaa
commit
3e43553735
30
api.cpp
30
api.cpp
@ -110,6 +110,9 @@ extern uint64_t global_hashrate;
|
|||||||
extern uint32_t accepted_count;
|
extern uint32_t accepted_count;
|
||||||
extern uint32_t rejected_count;
|
extern uint32_t rejected_count;
|
||||||
|
|
||||||
|
extern int device_map[8];
|
||||||
|
extern char *device_name[8];
|
||||||
|
|
||||||
#define gpu_threads opt_n_threads
|
#define gpu_threads opt_n_threads
|
||||||
|
|
||||||
/***************************************************************/
|
/***************************************************************/
|
||||||
@ -119,7 +122,8 @@ static void gpustatus(int thr_id)
|
|||||||
if (thr_id >= 0 && thr_id < gpu_threads) {
|
if (thr_id >= 0 && thr_id < gpu_threads) {
|
||||||
struct cgpu_info *cgpu = &thr_info[thr_id].gpu;
|
struct cgpu_info *cgpu = &thr_info[thr_id].gpu;
|
||||||
char buf[512]; *buf = '\0';
|
char buf[512]; *buf = '\0';
|
||||||
char pstate[8]; *pstate = '\0';
|
char pstate[8];
|
||||||
|
char* card;
|
||||||
|
|
||||||
cgpu->thr_id = thr_id;
|
cgpu->thr_id = thr_id;
|
||||||
|
|
||||||
@ -152,9 +156,11 @@ static void gpustatus(int thr_id)
|
|||||||
if (cgpu->gpu_pstate == -1)
|
if (cgpu->gpu_pstate == -1)
|
||||||
*pstate= '\0';
|
*pstate= '\0';
|
||||||
|
|
||||||
snprintf(buf, sizeof(buf), "GPU=%d;TEMP=%.1f;FAN=%d;FREQ=%d;"
|
card = device_name[device_map[thr_id]];
|
||||||
"PST=%s;KHS=%.2f;HWF=%d;I=%d|",
|
|
||||||
thr_id, cgpu->gpu_temp, cgpu->gpu_fan,
|
snprintf(buf, sizeof(buf), "GPU=%d;CARD=%s;TEMP=%.1f;FAN=%d;"
|
||||||
|
"FREQ=%d;PST=%s;KHS=%.2f;HWF=%d;I=%d|",
|
||||||
|
thr_id, card, cgpu->gpu_temp, cgpu->gpu_fan,
|
||||||
cgpu->gpu_clock, pstate, cgpu->khashes,
|
cgpu->gpu_clock, pstate, cgpu->khashes,
|
||||||
cgpu->hw_errors, cgpu->intensity);
|
cgpu->hw_errors, cgpu->intensity);
|
||||||
|
|
||||||
@ -179,9 +185,10 @@ static char *getsummary(char *params)
|
|||||||
|
|
||||||
*buffer = '\0';
|
*buffer = '\0';
|
||||||
sprintf(buffer, "NAME=%s;VER=%s;API=%s;"
|
sprintf(buffer, "NAME=%s;VER=%s;API=%s;"
|
||||||
"ALGO=%s;KHS=%.2f;ACC=%d;REJ=%d;ACCMN=%.3f;DIFF=%.6f;UPTIME=%.0f;TS=%u|",
|
"ALGO=%s;GPUS=%d;KHS=%.2f;ACC=%d;REJ=%d;"
|
||||||
|
"ACCMN=%.3f;DIFF=%.6f;UPTIME=%.0f;TS=%u|",
|
||||||
PACKAGE_NAME, PACKAGE_VERSION, APIVERSION,
|
PACKAGE_NAME, PACKAGE_VERSION, APIVERSION,
|
||||||
algo, (double)global_hashrate / 1000.0,
|
algo, gpu_threads, (double)global_hashrate / 1000.0,
|
||||||
accepted_count, rejected_count,
|
accepted_count, rejected_count,
|
||||||
accps, global_diff, uptime, (uint32_t) ts);
|
accps, global_diff, uptime, (uint32_t) ts);
|
||||||
return buffer;
|
return buffer;
|
||||||
@ -190,7 +197,7 @@ static char *getsummary(char *params)
|
|||||||
/**
|
/**
|
||||||
* Returns gpu/thread specific stats
|
* Returns gpu/thread specific stats
|
||||||
*/
|
*/
|
||||||
static char *getstats(char *params)
|
static char *getthreads(char *params)
|
||||||
{
|
{
|
||||||
*buffer = '\0';
|
*buffer = '\0';
|
||||||
for (int i = 0; i < gpu_threads; i++)
|
for (int i = 0; i < gpu_threads; i++)
|
||||||
@ -211,9 +218,10 @@ static char *gethistory(char *params)
|
|||||||
int records = stats_get_history(thr, data, ARRAY_SIZE(data));
|
int records = stats_get_history(thr, data, ARRAY_SIZE(data));
|
||||||
for (int i = 0; i < records; i++) {
|
for (int i = 0; i < records; i++) {
|
||||||
time_t ts = data[i].tm_stat;
|
time_t ts = data[i].tm_stat;
|
||||||
p += sprintf(p, "GPU=%d;KHS=%.2f;DIFF=%.6f;COUNT=%u;FOUND=%u;TS=%u|",
|
p += sprintf(p, "GPU=%d;KHS=%.2f;DIFF=%.6f;"
|
||||||
data[i].gpu_id, data[i].hashrate, data[i].difficulty, data[i].hashcount,
|
"COUNT=%u;FOUND=%u;TS=%u|",
|
||||||
data[i].hashfound, (uint32_t)ts);
|
data[i].gpu_id, data[i].hashrate, data[i].difficulty,
|
||||||
|
data[i].hashcount, data[i].hashfound, (uint32_t)ts);
|
||||||
}
|
}
|
||||||
return buffer;
|
return buffer;
|
||||||
}
|
}
|
||||||
@ -224,7 +232,7 @@ struct CMDS {
|
|||||||
char *(*func)(char *);
|
char *(*func)(char *);
|
||||||
} cmds[] = {
|
} cmds[] = {
|
||||||
{ "summary", getsummary },
|
{ "summary", getsummary },
|
||||||
{ "stats", getstats },
|
{ "threads", getthreads },
|
||||||
{ "histo", gethistory },
|
{ "histo", gethistory },
|
||||||
/* keep it the last */
|
/* keep it the last */
|
||||||
{ "help", gethelp },
|
{ "help", gethelp },
|
||||||
|
@ -7,6 +7,10 @@ $configs = array(
|
|||||||
//'EPSYTOUR'=>'epsytour.php', /* copy local.php file and edit target IP:PORT */
|
//'EPSYTOUR'=>'epsytour.php', /* copy local.php file and edit target IP:PORT */
|
||||||
);
|
);
|
||||||
|
|
||||||
|
// 5 seconds max.
|
||||||
|
set_time_limit(5);
|
||||||
|
error_reporting(0);
|
||||||
|
|
||||||
function getdataFromPears()
|
function getdataFromPears()
|
||||||
{
|
{
|
||||||
global $host, $configs;
|
global $host, $configs;
|
||||||
@ -22,7 +26,7 @@ function getdataFromPears()
|
|||||||
|
|
||||||
function ignoreField($key)
|
function ignoreField($key)
|
||||||
{
|
{
|
||||||
$ignored = array('API','VER');
|
$ignored = array('API','VER','GPU','CARD');
|
||||||
return in_array($key, $ignored);
|
return in_array($key, $ignored);
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -33,6 +37,7 @@ function translateField($key)
|
|||||||
$intl['VER'] = 'Version';
|
$intl['VER'] = 'Version';
|
||||||
|
|
||||||
$intl['ALGO'] = 'Algorithm';
|
$intl['ALGO'] = 'Algorithm';
|
||||||
|
$intl['GPUS'] = 'GPUs';
|
||||||
$intl['KHS'] = 'Hash rate (kH/s)';
|
$intl['KHS'] = 'Hash rate (kH/s)';
|
||||||
$intl['ACC'] = 'Accepted shares';
|
$intl['ACC'] = 'Accepted shares';
|
||||||
$intl['ACCMN'] = 'Accepted / mn';
|
$intl['ACCMN'] = 'Accepted / mn';
|
||||||
@ -84,9 +89,11 @@ function displayData($data)
|
|||||||
$htm .= '<tr><td class="key">'.translateField($key).'</td>'.
|
$htm .= '<tr><td class="key">'.translateField($key).'</td>'.
|
||||||
'<td class="val">'.translateValue($key, $val, $summary)."</td></tr>\n";
|
'<td class="val">'.translateValue($key, $val, $summary)."</td></tr>\n";
|
||||||
}
|
}
|
||||||
$totals[$summary['ALGO']] += floatval($summary['KHS']);
|
if (isset($summary['KHS']))
|
||||||
foreach ($stats['stats'] as $g=>$gpu) {
|
$totals[$summary['ALGO']] += floatval($summary['KHS']);
|
||||||
$htm .= '<tr><th class="gpu" colspan="2">'.$g."</th></tr>\n";
|
foreach ($stats['threads'] as $g=>$gpu) {
|
||||||
|
$card = isset($gpu['CARD']) ? $gpu['CARD'] : '';
|
||||||
|
$htm .= '<tr><th class="gpu" colspan="2">'.$g." $card</th></tr>\n";
|
||||||
foreach ($gpu as $key=>$val) {
|
foreach ($gpu as $key=>$val) {
|
||||||
if (!empty($val) && !ignoreField($key))
|
if (!empty($val) && !ignoreField($key))
|
||||||
$htm .= '<tr><td class="key">'.translateField($key).'</td>'.
|
$htm .= '<tr><td class="key">'.translateField($key).'</td>'.
|
||||||
|
@ -5,6 +5,10 @@
|
|||||||
defined('API_HOST') || define('API_HOST', '127.0.0.1');
|
defined('API_HOST') || define('API_HOST', '127.0.0.1');
|
||||||
defined('API_PORT') || define('API_PORT', 4068);
|
defined('API_PORT') || define('API_PORT', 4068);
|
||||||
|
|
||||||
|
// 3 seconds max.
|
||||||
|
set_time_limit(3);
|
||||||
|
error_reporting(0);
|
||||||
|
|
||||||
function getsock($port)
|
function getsock($port)
|
||||||
{
|
{
|
||||||
$socket = null;
|
$socket = null;
|
||||||
@ -106,10 +110,11 @@ function request($cmd)
|
|||||||
|
|
||||||
ob_start();
|
ob_start();
|
||||||
$summary = request('summary');
|
$summary = request('summary');
|
||||||
$stats = request('stats');
|
$threads = request('threads');
|
||||||
|
$histo = request('histo');
|
||||||
ob_end_clean();
|
ob_end_clean();
|
||||||
//echo ob_get_clean()."\n";
|
//echo ob_get_clean()."\n";
|
||||||
|
|
||||||
header("Content-Type: application/json");
|
header("Content-Type: application/json");
|
||||||
echo json_encode(compact('summary', 'stats'))."\n";
|
echo json_encode(compact('summary', 'threads', 'histo'))."\n";
|
||||||
?>
|
?>
|
||||||
|
Loading…
x
Reference in New Issue
Block a user