|
|
|
@ -330,7 +330,9 @@ static const char *ckdb_seq_names[] = {
|
|
|
|
|
|
|
|
|
|
struct stratifier_data { |
|
|
|
|
char pubkeytxnbin[25]; |
|
|
|
|
int pubkeytxnlen; |
|
|
|
|
char donkeytxnbin[25]; |
|
|
|
|
int donkeytxnlen; |
|
|
|
|
|
|
|
|
|
pool_stats_t stats; |
|
|
|
|
/* Protects changes to pool stats */ |
|
|
|
@ -542,18 +544,18 @@ static void generate_coinbase(const ckpool_t *ckp, workbase_t *wb)
|
|
|
|
|
*u64 = htole64(g64); |
|
|
|
|
wb->coinb2len += 8; |
|
|
|
|
|
|
|
|
|
wb->coinb2bin[wb->coinb2len++] = 25; |
|
|
|
|
memcpy(wb->coinb2bin + wb->coinb2len, sdata->pubkeytxnbin, 25); |
|
|
|
|
wb->coinb2len += 25; |
|
|
|
|
wb->coinb2bin[wb->coinb2len++] = sdata->pubkeytxnlen; |
|
|
|
|
memcpy(wb->coinb2bin + wb->coinb2len, sdata->pubkeytxnbin, sdata->pubkeytxnlen); |
|
|
|
|
wb->coinb2len += sdata->pubkeytxnlen; |
|
|
|
|
|
|
|
|
|
if (ckp->donvalid) { |
|
|
|
|
u64 = (uint64_t *)&wb->coinb2bin[wb->coinb2len]; |
|
|
|
|
*u64 = htole64(d64); |
|
|
|
|
wb->coinb2len += 8; |
|
|
|
|
|
|
|
|
|
wb->coinb2bin[wb->coinb2len++] = 25; |
|
|
|
|
memcpy(wb->coinb2bin + wb->coinb2len, sdata->donkeytxnbin, 25); |
|
|
|
|
wb->coinb2len += 25; |
|
|
|
|
wb->coinb2bin[wb->coinb2len++] = sdata->donkeytxnlen; |
|
|
|
|
memcpy(wb->coinb2bin + wb->coinb2len, sdata->donkeytxnbin, sdata->donkeytxnlen); |
|
|
|
|
wb->coinb2len += sdata->donkeytxnlen; |
|
|
|
|
} |
|
|
|
|
|
|
|
|
|
wb->coinb2len += 4; // Blank lock
|
|
|
|
@ -4456,6 +4458,13 @@ static void read_poolstats(ckpool_t *ckp)
|
|
|
|
|
} |
|
|
|
|
} |
|
|
|
|
|
|
|
|
|
/* Braindead check to see if this btcaddress is an M of N script address which
|
|
|
|
|
* is currently unsupported as a generation address. */ |
|
|
|
|
static bool script_address(const char *btcaddress) |
|
|
|
|
{ |
|
|
|
|
return btcaddress[0] == '3'; |
|
|
|
|
} |
|
|
|
|
|
|
|
|
|
int stratifier(proc_instance_t *pi) |
|
|
|
|
{ |
|
|
|
|
pthread_t pth_blockupdate, pth_statsupdate, pth_heartbeat; |
|
|
|
@ -4486,13 +4495,25 @@ int stratifier(proc_instance_t *pi)
|
|
|
|
|
|
|
|
|
|
/* Store this for use elsewhere */ |
|
|
|
|
hex2bin(scriptsig_header_bin, scriptsig_header, 41); |
|
|
|
|
if (script_address(ckp->btcaddress)) { |
|
|
|
|
address_to_scripttxn(sdata->pubkeytxnbin, ckp->btcaddress); |
|
|
|
|
sdata->pubkeytxnlen = 23; |
|
|
|
|
} else { |
|
|
|
|
address_to_pubkeytxn(sdata->pubkeytxnbin, ckp->btcaddress); |
|
|
|
|
sdata->pubkeytxnlen = 25; |
|
|
|
|
} |
|
|
|
|
|
|
|
|
|
if (test_address(ckp, ckp->donaddress)) { |
|
|
|
|
ckp->donvalid = true; |
|
|
|
|
if (script_address(ckp->donaddress)) { |
|
|
|
|
sdata->donkeytxnlen = 23; |
|
|
|
|
address_to_scripttxn(sdata->donkeytxnbin, ckp->donaddress); |
|
|
|
|
} else { |
|
|
|
|
sdata->donkeytxnlen = 25; |
|
|
|
|
address_to_pubkeytxn(sdata->donkeytxnbin, ckp->donaddress); |
|
|
|
|
} |
|
|
|
|
} |
|
|
|
|
} |
|
|
|
|
|
|
|
|
|
randomiser = ((int64_t)time(NULL)) << 32; |
|
|
|
|
/* Set the initial id to time as high bits so as to not send the same
|
|
|
|
|