1
0
mirror of https://github.com/GOSTSec/sgminer synced 2025-01-22 20:44:19 +00:00

Make target on stratum scale to any size by clearing sequential bits according to diff.

This commit is contained in:
Con Kolivas 2012-10-03 00:35:08 +10:00
parent a8a8ed6207
commit fdaabf59c6
2 changed files with 39 additions and 16 deletions

View File

@ -4477,12 +4477,13 @@ static void gen_hash(unsigned char *data, unsigned char *hash, int len)
static void gen_stratum_work(struct pool *pool, struct work *work) static void gen_stratum_work(struct pool *pool, struct work *work)
{ {
char header[257], hash1[129], *nonce2, *buf;
unsigned char *coinbase, merkle_root[33], merkle_sha[65], *merkle_hash; unsigned char *coinbase, merkle_root[33], merkle_sha[65], *merkle_hash;
int len, cb1_len, n1_len, cb2_len, i, j;
unsigned char rtarget[33], target[33];
char header[257], hash1[129], *nonce2;
uint32_t *data32, *swap32; uint32_t *data32, *swap32;
uint64_t diff, diff64; uint8_t *data8;
char target[65]; int diff;
int len, cb1_len, n1_len, cb2_len, i;
mutex_lock(&pool->pool_lock); mutex_lock(&pool->pool_lock);
@ -4551,18 +4552,25 @@ static void gen_stratum_work(struct pool *pool, struct work *work)
if (unlikely(!hex2bin(work->hash1, hash1, 64))) if (unlikely(!hex2bin(work->hash1, hash1, 64)))
quit(1, "Failed to convert hash1 in gen_stratum_work"); quit(1, "Failed to convert hash1 in gen_stratum_work");
/* Generate target as hex where 0x00000000FFFFFFFF is diff 1 */ /* Scale to any diff by setting number of bits according to diff */
diff64 = (1Ull << (31 + diff)) - 1; hex2bin(rtarget, "00000000ffffffffffffffffffffffffffffffffffffffffffffffffffffffff", 32);
diff64 = ~htobe64(diff64); data8 = (uint8_t *)(rtarget + 4);
sprintf(target, "ffffffffffffffffffffffffffffffffffffffffffffffff"); for (i = 1, j = 0; i < diff; i++, j++) {
buf = bin2hex((const unsigned char *)&diff64, 8); int byte = j / 8;
if (unlikely(!buf)) int bit = j % 8;
quit(1, "Failed to convert diff64 to buf in gen_stratum_work");
strcat(target, buf); data8[byte] &= ~(8 >> bit);
free(buf); }
applog(LOG_DEBUG, "Generated target %s", target); swab256(target, rtarget);
if (unlikely(!hex2bin(work->target, target, 32))) if (opt_debug) {
quit(1, "Failed to convert target to bin in gen_stratum_work"); char *htarget = bin2hex(target, 32);
if (likely(htarget)) {
applog(LOG_DEBUG, "Generated target %s", htarget);
free(htarget);
}
}
memcpy(work->target, target, 256);
work->pool = pool; work->pool = pool;
work->stratum = true; work->stratum = true;

15
miner.h
View File

@ -511,6 +511,21 @@ static inline void swap256(void *dest_p, const void *src_p)
dest[7] = src[0]; dest[7] = src[0];
} }
static inline void swab256(void *dest_p, const void *src_p)
{
uint32_t *dest = dest_p;
const uint32_t *src = src_p;
dest[0] = swab32(src[7]);
dest[1] = swab32(src[6]);
dest[2] = swab32(src[5]);
dest[3] = swab32(src[4]);
dest[4] = swab32(src[3]);
dest[5] = swab32(src[2]);
dest[6] = swab32(src[1]);
dest[7] = swab32(src[0]);
}
extern void quit(int status, const char *format, ...); extern void quit(int status, const char *format, ...);
static inline void mutex_lock(pthread_mutex_t *lock) static inline void mutex_lock(pthread_mutex_t *lock)