mirror of
https://github.com/GOSTSec/ccminer
synced 2025-01-10 23:08:02 +00:00
hashlog: enhance scan range store and debug dump
This commit is contained in:
parent
3356e6f8bf
commit
b98239ec2a
@ -508,8 +508,7 @@ static bool submit_upstream_work(CURL *curl, struct work *work)
|
|||||||
goto out;
|
goto out;
|
||||||
}
|
}
|
||||||
|
|
||||||
hashlog_remember_submit(work->job_id, nonce);
|
hashlog_remember_submit(work->job_id, nonce, work->scanned_from);
|
||||||
hashlog_remember_scan_range(work->job_id, work->scanned_from, work->scanned_to);
|
|
||||||
|
|
||||||
} else {
|
} else {
|
||||||
|
|
||||||
|
35
hashlog.cpp
35
hashlog.cpp
@ -1,3 +1,11 @@
|
|||||||
|
/**
|
||||||
|
* Hash log of submitted job nonces
|
||||||
|
* Prevent duplicate shares and could be used for RPC stats later
|
||||||
|
*
|
||||||
|
* Note: this source is C++ (requires std::map)
|
||||||
|
*
|
||||||
|
* tpruvot@github 2014
|
||||||
|
*/
|
||||||
#include <stdlib.h>
|
#include <stdlib.h>
|
||||||
#include <memory.h>
|
#include <memory.h>
|
||||||
#include <map>
|
#include <map>
|
||||||
@ -52,17 +60,17 @@ extern "C" uint32_t hashlog_already_submittted(char* jobid, uint32_t nonce)
|
|||||||
/**
|
/**
|
||||||
* Store submitted nonces of a job
|
* Store submitted nonces of a job
|
||||||
*/
|
*/
|
||||||
extern "C" void hashlog_remember_submit(char* jobid, uint32_t nonce)
|
extern "C" void hashlog_remember_submit(char* jobid, uint32_t nonce, uint32_t scanned_from)
|
||||||
{
|
{
|
||||||
uint64_t njobid = hextouint(jobid);
|
uint64_t njobid = hextouint(jobid);
|
||||||
uint64_t keyall = (njobid << 32);
|
uint64_t keyall = (njobid << 32);
|
||||||
uint64_t key = keyall + nonce;
|
uint64_t key = keyall + nonce;
|
||||||
hashlog_data data;
|
hashlog_data data;
|
||||||
|
|
||||||
data = tlastshares[keyall];
|
memset(&data, 0, sizeof(data));
|
||||||
data.tm_upd = data.tm_sent = (uint32_t) time(NULL);
|
data.scanned_from = scanned_from;
|
||||||
if (data.tm_add == 0)
|
data.scanned_to = nonce;
|
||||||
data.tm_add = data.tm_upd;
|
data.tm_add = data.tm_upd = data.tm_sent = (uint32_t) time(NULL);
|
||||||
tlastshares[key] = data;
|
tlastshares[key] = data;
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -92,12 +100,12 @@ extern "C" void hashlog_remember_scan_range(char* jobid, uint32_t scanned_from,
|
|||||||
data.last_from = scanned_from;
|
data.last_from = scanned_from;
|
||||||
|
|
||||||
if (scanned_from < scanned_to) {
|
if (scanned_from < scanned_to) {
|
||||||
if (data.scanned_from == 0)
|
|
||||||
data.scanned_from = scanned_from ? scanned_from : 1; // min 1
|
|
||||||
else if (scanned_from < data.scanned_from) // || scanned_to == (data.scanned_from - 1)
|
|
||||||
data.scanned_from = scanned_from;
|
|
||||||
if (data.scanned_to == 0 || scanned_from == data.scanned_to + 1)
|
if (data.scanned_to == 0 || scanned_from == data.scanned_to + 1)
|
||||||
data.scanned_to = scanned_to;
|
data.scanned_to = scanned_to;
|
||||||
|
if (data.scanned_from == 0)
|
||||||
|
data.scanned_from = scanned_from ? scanned_from : 1; // min 1
|
||||||
|
else if (scanned_from < data.scanned_from || scanned_to == (data.scanned_from - 1))
|
||||||
|
data.scanned_from = scanned_from;
|
||||||
}
|
}
|
||||||
|
|
||||||
data.tm_upd = (uint32_t) time(NULL);
|
data.tm_upd = (uint32_t) time(NULL);
|
||||||
@ -218,10 +226,11 @@ extern "C" void hashlog_dump_job(char* jobid)
|
|||||||
std::map<uint64_t, hashlog_data>::iterator i = tlastshares.begin();
|
std::map<uint64_t, hashlog_data>::iterator i = tlastshares.begin();
|
||||||
while (i != tlastshares.end()) {
|
while (i != tlastshares.end()) {
|
||||||
if ((keypfx & i->first) == keypfx) {
|
if ((keypfx & i->first) == keypfx) {
|
||||||
applog(LOG_BLUE, "job %s range : %x %x %s added %x upd %x", jobid,
|
if (i->first != keypfx)
|
||||||
i->second.scanned_from, i->second.scanned_to,
|
applog(LOG_DEBUG, CL_YLW "job %s, found %08x ", jobid, LO_DWORD(i->first));
|
||||||
i->second.tm_sent ? "sent" : "",
|
else
|
||||||
i->second.tm_add, i->second.tm_upd);/* */
|
applog(LOG_DEBUG, CL_YLW "job %s scanned range : %08x-%08x", jobid,
|
||||||
|
i->second.scanned_from, i->second.scanned_to);
|
||||||
}
|
}
|
||||||
i++;
|
i++;
|
||||||
}
|
}
|
||||||
|
2
miner.h
2
miner.h
@ -392,7 +392,7 @@ bool stratum_subscribe(struct stratum_ctx *sctx);
|
|||||||
bool stratum_authorize(struct stratum_ctx *sctx, const char *user, const char *pass);
|
bool stratum_authorize(struct stratum_ctx *sctx, const char *user, const char *pass);
|
||||||
bool stratum_handle_method(struct stratum_ctx *sctx, const char *s);
|
bool stratum_handle_method(struct stratum_ctx *sctx, const char *s);
|
||||||
|
|
||||||
void hashlog_remember_submit(char* jobid, uint32_t nounce);
|
void hashlog_remember_submit(char* jobid, uint32_t nounce, uint32_t scanned_from);
|
||||||
void hashlog_remember_scan_range(char* jobid, uint32_t scanned_from, uint32_t scanned_to);
|
void hashlog_remember_scan_range(char* jobid, uint32_t scanned_from, uint32_t scanned_to);
|
||||||
uint32_t hashlog_already_submittted(char* jobid, uint32_t nounce);
|
uint32_t hashlog_already_submittted(char* jobid, uint32_t nounce);
|
||||||
uint32_t hashlog_get_last_sent(char* jobid);
|
uint32_t hashlog_get_last_sent(char* jobid);
|
||||||
|
Loading…
Reference in New Issue
Block a user