Skip to content

Commit

Permalink
Merge pull request #290 from AchcarLucas/improvement-getNextExtranonce2
Browse files Browse the repository at this point in the history
Improvement getNextExtranonce2 and create getRandomExtranonce2
  • Loading branch information
BitMaker-hub authored May 25, 2024
2 parents 6c5d340 + b843726 commit 0a22a19
Showing 1 changed file with 28 additions and 12 deletions.
40 changes: 28 additions & 12 deletions src/utils.cpp
Original file line number Diff line number Diff line change
Expand Up @@ -136,21 +136,37 @@ bool checkValid(unsigned char* hash, unsigned char* target) {
return valid;
}

/**
* get random extranonce2
*/
void getRandomExtranonce2(int extranonce2_size, char *extranonce2) {
uint8_t b0, b1, b2, b3;

b0 = rand() % 256;
b1 = rand() % 256;
b2 = rand() % 256;
b3 = rand() % 256;

unsigned long extranonce2_number = b3 << 24 | b2 << 16 | b1 << 8 | b0;

char format[] = "%00x";

sprintf(&format[1], "%02dx", extranonce2_size * 2);
sprintf(extranonce2, format, extranonce2_number);
}

/**
* get linear extranonce2
*/
void getNextExtranonce2(int extranonce2_size, char *extranonce2) {

unsigned long extranonce2_number = strtoul(extranonce2, NULL, 10);

extranonce2_number++;

memset(extranonce2, '0', 2 * extranonce2_size);
if (extranonce2_number > long(pow(10, 2 * extranonce2_size))) {
return;
}

char next_extranounce2[2 * extranonce2_size + 1];
memset(extranonce2, '0', 2 * extranonce2_size);
ultoa(extranonce2_number, next_extranounce2, 10);
memcpy(extranonce2 + (2 * extranonce2_size) - long(log10(extranonce2_number)) - 1 , next_extranounce2, strlen(next_extranounce2));
extranonce2[2 * extranonce2_size] = 0;

char format[] = "%00x";

sprintf(&format[1], "%02dx", extranonce2_size * 2);
sprintf(extranonce2, format, extranonce2_number);
}

miner_data init_miner_data(void){
Expand Down

0 comments on commit 0a22a19

Please sign in to comment.