mirror of
https://github.com/GOSTSec/sgminer
synced 2025-01-09 06:18:06 +00:00
algorithm spaces/indentation fix
This commit is contained in:
parent
60a79024ad
commit
5ba1772d5a
290
algorithm.c
290
algorithm.c
@ -41,14 +41,14 @@ void sha256(const unsigned char *message, unsigned int len, unsigned char *diges
|
|||||||
|
|
||||||
void gen_hash(const unsigned char *data, unsigned int len, unsigned char *hash)
|
void gen_hash(const unsigned char *data, unsigned int len, unsigned char *hash)
|
||||||
{
|
{
|
||||||
unsigned char hash1[32];
|
unsigned char hash1[32];
|
||||||
sph_sha256_context ctx_sha2;
|
sph_sha256_context ctx_sha2;
|
||||||
|
|
||||||
sph_sha256_init(&ctx_sha2);
|
sph_sha256_init(&ctx_sha2);
|
||||||
sph_sha256(&ctx_sha2, data, len);
|
sph_sha256(&ctx_sha2, data, len);
|
||||||
sph_sha256_close(&ctx_sha2, hash1);
|
sph_sha256_close(&ctx_sha2, hash1);
|
||||||
sph_sha256(&ctx_sha2, hash1, 32);
|
sph_sha256(&ctx_sha2, hash1, 32);
|
||||||
sph_sha256_close(&ctx_sha2, hash);
|
sph_sha256_close(&ctx_sha2, hash);
|
||||||
}
|
}
|
||||||
|
|
||||||
#define CL_SET_BLKARG(blkvar) status |= clSetKernelArg(*kernel, num++, sizeof(uint), (void *)&blk->blkvar)
|
#define CL_SET_BLKARG(blkvar) status |= clSetKernelArg(*kernel, num++, sizeof(uint), (void *)&blk->blkvar)
|
||||||
@ -59,7 +59,7 @@ static void append_scrypt_compiler_options(struct _build_kernel_data *data, stru
|
|||||||
{
|
{
|
||||||
char buf[255];
|
char buf[255];
|
||||||
sprintf(buf, " -D LOOKUP_GAP=%d -D CONCURRENT_THREADS=%u -D NFACTOR=%d",
|
sprintf(buf, " -D LOOKUP_GAP=%d -D CONCURRENT_THREADS=%u -D NFACTOR=%d",
|
||||||
cgpu->lookup_gap, (unsigned int)cgpu->thread_concurrency, algorithm->nfactor);
|
cgpu->lookup_gap, (unsigned int)cgpu->thread_concurrency, algorithm->nfactor);
|
||||||
strcat(data->compiler_options, buf);
|
strcat(data->compiler_options, buf);
|
||||||
|
|
||||||
sprintf(buf, "lg%utc%unf%u", cgpu->lookup_gap, (unsigned int)cgpu->thread_concurrency, algorithm->nfactor);
|
sprintf(buf, "lg%utc%unf%u", cgpu->lookup_gap, (unsigned int)cgpu->thread_concurrency, algorithm->nfactor);
|
||||||
@ -70,7 +70,7 @@ static void append_hamsi_compiler_options(struct _build_kernel_data *data, struc
|
|||||||
{
|
{
|
||||||
char buf[255];
|
char buf[255];
|
||||||
sprintf(buf, " -D SPH_HAMSI_EXPAND_BIG=%d",
|
sprintf(buf, " -D SPH_HAMSI_EXPAND_BIG=%d",
|
||||||
opt_hamsi_expand_big);
|
opt_hamsi_expand_big);
|
||||||
strcat(data->compiler_options, buf);
|
strcat(data->compiler_options, buf);
|
||||||
|
|
||||||
sprintf(buf, "big%u", (unsigned int)opt_hamsi_expand_big);
|
sprintf(buf, "big%u", (unsigned int)opt_hamsi_expand_big);
|
||||||
@ -79,57 +79,57 @@ static void append_hamsi_compiler_options(struct _build_kernel_data *data, struc
|
|||||||
|
|
||||||
static cl_int queue_scrypt_kernel(struct __clState *clState, struct _dev_blk_ctx *blk, __maybe_unused cl_uint threads)
|
static cl_int queue_scrypt_kernel(struct __clState *clState, struct _dev_blk_ctx *blk, __maybe_unused cl_uint threads)
|
||||||
{
|
{
|
||||||
unsigned char *midstate = blk->work->midstate;
|
unsigned char *midstate = blk->work->midstate;
|
||||||
cl_kernel *kernel = &clState->kernel;
|
cl_kernel *kernel = &clState->kernel;
|
||||||
unsigned int num = 0;
|
unsigned int num = 0;
|
||||||
cl_uint le_target;
|
cl_uint le_target;
|
||||||
cl_int status = 0;
|
cl_int status = 0;
|
||||||
|
|
||||||
le_target = *(cl_uint *)(blk->work->device_target + 28);
|
le_target = *(cl_uint *)(blk->work->device_target + 28);
|
||||||
memcpy(clState->cldata, blk->work->data, 80);
|
memcpy(clState->cldata, blk->work->data, 80);
|
||||||
status = clEnqueueWriteBuffer(clState->commandQueue, clState->CLbuffer0, true, 0, 80, clState->cldata, 0, NULL,NULL);
|
status = clEnqueueWriteBuffer(clState->commandQueue, clState->CLbuffer0, true, 0, 80, clState->cldata, 0, NULL,NULL);
|
||||||
|
|
||||||
CL_SET_ARG(clState->CLbuffer0);
|
CL_SET_ARG(clState->CLbuffer0);
|
||||||
CL_SET_ARG(clState->outputBuffer);
|
CL_SET_ARG(clState->outputBuffer);
|
||||||
CL_SET_ARG(clState->padbuffer8);
|
CL_SET_ARG(clState->padbuffer8);
|
||||||
CL_SET_VARG(4, &midstate[0]);
|
CL_SET_VARG(4, &midstate[0]);
|
||||||
CL_SET_VARG(4, &midstate[16]);
|
CL_SET_VARG(4, &midstate[16]);
|
||||||
CL_SET_ARG(le_target);
|
CL_SET_ARG(le_target);
|
||||||
|
|
||||||
return status;
|
return status;
|
||||||
}
|
}
|
||||||
|
|
||||||
static cl_int queue_maxcoin_kernel(struct __clState *clState, struct _dev_blk_ctx *blk, __maybe_unused cl_uint threads)
|
static cl_int queue_maxcoin_kernel(struct __clState *clState, struct _dev_blk_ctx *blk, __maybe_unused cl_uint threads)
|
||||||
{
|
{
|
||||||
cl_kernel *kernel = &clState->kernel;
|
cl_kernel *kernel = &clState->kernel;
|
||||||
unsigned int num = 0;
|
unsigned int num = 0;
|
||||||
cl_int status = 0;
|
cl_int status = 0;
|
||||||
|
|
||||||
flip80(clState->cldata, blk->work->data);
|
flip80(clState->cldata, blk->work->data);
|
||||||
status = clEnqueueWriteBuffer(clState->commandQueue, clState->CLbuffer0, true, 0, 80, clState->cldata, 0, NULL,NULL);
|
status = clEnqueueWriteBuffer(clState->commandQueue, clState->CLbuffer0, true, 0, 80, clState->cldata, 0, NULL,NULL);
|
||||||
|
|
||||||
CL_SET_ARG(clState->CLbuffer0);
|
CL_SET_ARG(clState->CLbuffer0);
|
||||||
CL_SET_ARG(clState->outputBuffer);
|
CL_SET_ARG(clState->outputBuffer);
|
||||||
|
|
||||||
return status;
|
return status;
|
||||||
}
|
}
|
||||||
|
|
||||||
static cl_int queue_sph_kernel(struct __clState *clState, struct _dev_blk_ctx *blk, __maybe_unused cl_uint threads)
|
static cl_int queue_sph_kernel(struct __clState *clState, struct _dev_blk_ctx *blk, __maybe_unused cl_uint threads)
|
||||||
{
|
{
|
||||||
cl_kernel *kernel = &clState->kernel;
|
cl_kernel *kernel = &clState->kernel;
|
||||||
unsigned int num = 0;
|
unsigned int num = 0;
|
||||||
cl_ulong le_target;
|
cl_ulong le_target;
|
||||||
cl_int status = 0;
|
cl_int status = 0;
|
||||||
|
|
||||||
le_target = *(cl_ulong *)(blk->work->device_target + 24);
|
le_target = *(cl_ulong *)(blk->work->device_target + 24);
|
||||||
flip80(clState->cldata, blk->work->data);
|
flip80(clState->cldata, blk->work->data);
|
||||||
status = clEnqueueWriteBuffer(clState->commandQueue, clState->CLbuffer0, true, 0, 80, clState->cldata, 0, NULL,NULL);
|
status = clEnqueueWriteBuffer(clState->commandQueue, clState->CLbuffer0, true, 0, 80, clState->cldata, 0, NULL,NULL);
|
||||||
|
|
||||||
CL_SET_ARG(clState->CLbuffer0);
|
CL_SET_ARG(clState->CLbuffer0);
|
||||||
CL_SET_ARG(clState->outputBuffer);
|
CL_SET_ARG(clState->outputBuffer);
|
||||||
CL_SET_ARG(le_target);
|
CL_SET_ARG(le_target);
|
||||||
|
|
||||||
return status;
|
return status;
|
||||||
}
|
}
|
||||||
|
|
||||||
static cl_int queue_darkcoin_mod_kernel(struct __clState *clState, struct _dev_blk_ctx *blk, __maybe_unused cl_uint threads)
|
static cl_int queue_darkcoin_mod_kernel(struct __clState *clState, struct _dev_blk_ctx *blk, __maybe_unused cl_uint threads)
|
||||||
@ -264,7 +264,6 @@ static cl_int queue_marucoin_mod_kernel(struct __clState *clState, struct _dev_b
|
|||||||
return status;
|
return status;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
static cl_int queue_marucoin_mod_old_kernel(struct __clState *clState, struct _dev_blk_ctx *blk, __maybe_unused cl_uint threads)
|
static cl_int queue_marucoin_mod_old_kernel(struct __clState *clState, struct _dev_blk_ctx *blk, __maybe_unused cl_uint threads)
|
||||||
{
|
{
|
||||||
cl_kernel *kernel;
|
cl_kernel *kernel;
|
||||||
@ -328,139 +327,146 @@ static cl_int queue_marucoin_mod_old_kernel(struct __clState *clState, struct _d
|
|||||||
}
|
}
|
||||||
|
|
||||||
typedef struct _algorithm_settings_t {
|
typedef struct _algorithm_settings_t {
|
||||||
const char *name; /* Human-readable identifier */
|
const char *name; /* Human-readable identifier */
|
||||||
double diff_multiplier1;
|
double diff_multiplier1;
|
||||||
double diff_multiplier2;
|
double diff_multiplier2;
|
||||||
double share_diff_multiplier;
|
double share_diff_multiplier;
|
||||||
uint32_t xintensity_shift;
|
uint32_t xintensity_shift;
|
||||||
uint32_t intensity_shift;
|
uint32_t intensity_shift;
|
||||||
uint32_t found_idx;
|
uint32_t found_idx;
|
||||||
unsigned long long diff_nonce;
|
unsigned long long diff_nonce;
|
||||||
unsigned long long diff_numerator;
|
unsigned long long diff_numerator;
|
||||||
uint32_t diff1targ;
|
uint32_t diff1targ;
|
||||||
size_t n_extra_kernels;
|
size_t n_extra_kernels;
|
||||||
long rw_buffer_size;
|
long rw_buffer_size;
|
||||||
cl_command_queue_properties cq_properties;
|
cl_command_queue_properties cq_properties;
|
||||||
void (*regenhash)(struct work *);
|
void (*regenhash)(struct work *);
|
||||||
cl_int (*queue_kernel)(struct __clState *, struct _dev_blk_ctx *, cl_uint);
|
cl_int (*queue_kernel)(struct __clState *, struct _dev_blk_ctx *, cl_uint);
|
||||||
void (*gen_hash)(const unsigned char *, unsigned int, unsigned char *);
|
void (*gen_hash)(const unsigned char *, unsigned int, unsigned char *);
|
||||||
void (*set_compile_options)(build_kernel_data *, struct cgpu_info *, algorithm_t *);
|
void (*set_compile_options)(build_kernel_data *, struct cgpu_info *, algorithm_t *);
|
||||||
} algorithm_settings_t;
|
} algorithm_settings_t;
|
||||||
|
|
||||||
static algorithm_settings_t algos[] = {
|
static algorithm_settings_t algos[] = {
|
||||||
// kernels starting from this will have difficulty calculated by using litecoin algorithm
|
// kernels starting from this will have difficulty calculated by using litecoin algorithm
|
||||||
#define A_SCRYPT(a) \
|
#define A_SCRYPT(a) \
|
||||||
{ a, 1, 65536, 65536, 0, 0, 0xFF, 0x0000ffff00000000ULL, 0xFFFFFFFFULL, 0x0000ffffUL, 0, -1, CL_QUEUE_OUT_OF_ORDER_EXEC_MODE_ENABLE, scrypt_regenhash, queue_scrypt_kernel, gen_hash, append_scrypt_compiler_options}
|
{ a, 1, 65536, 65536, 0, 0, 0xFF, 0x0000ffff00000000ULL, 0xFFFFFFFFULL, 0x0000ffffUL, 0, -1, CL_QUEUE_OUT_OF_ORDER_EXEC_MODE_ENABLE, scrypt_regenhash, queue_scrypt_kernel, gen_hash, append_scrypt_compiler_options}
|
||||||
A_SCRYPT( "ckolivas" ),
|
A_SCRYPT( "ckolivas" ),
|
||||||
A_SCRYPT( "alexkarnew" ),
|
A_SCRYPT( "alexkarnew" ),
|
||||||
A_SCRYPT( "alexkarnold" ),
|
A_SCRYPT( "alexkarnold" ),
|
||||||
A_SCRYPT( "bufius" ),
|
A_SCRYPT( "bufius" ),
|
||||||
A_SCRYPT( "psw" ),
|
A_SCRYPT( "psw" ),
|
||||||
A_SCRYPT( "zuikkis" ),
|
A_SCRYPT( "zuikkis" ),
|
||||||
#undef A_SCRYPT
|
#undef A_SCRYPT
|
||||||
|
|
||||||
// kernels starting from this will have difficulty calculated by using quarkcoin algorithm
|
// kernels starting from this will have difficulty calculated by using quarkcoin algorithm
|
||||||
#define A_QUARK(a, b) \
|
#define A_QUARK(a, b) \
|
||||||
{ a, 256, 256, 256, 0, 0, 0xFF, 0x000000ffff000000ULL, 0xFFFFFFULL, 0x0000ffffUL, 0, 0, CL_QUEUE_OUT_OF_ORDER_EXEC_MODE_ENABLE, b, queue_sph_kernel, gen_hash, NULL}
|
{ a, 256, 256, 256, 0, 0, 0xFF, 0x000000ffff000000ULL, 0xFFFFFFULL, 0x0000ffffUL, 0, 0, CL_QUEUE_OUT_OF_ORDER_EXEC_MODE_ENABLE, b, queue_sph_kernel, gen_hash, NULL}
|
||||||
A_QUARK( "quarkcoin", quarkcoin_regenhash),
|
A_QUARK( "quarkcoin", quarkcoin_regenhash),
|
||||||
A_QUARK( "qubitcoin", qubitcoin_regenhash),
|
A_QUARK( "qubitcoin", qubitcoin_regenhash),
|
||||||
A_QUARK( "animecoin", animecoin_regenhash),
|
A_QUARK( "animecoin", animecoin_regenhash),
|
||||||
A_QUARK( "sifcoin", sifcoin_regenhash),
|
A_QUARK( "sifcoin", sifcoin_regenhash),
|
||||||
#undef A_QUARK
|
#undef A_QUARK
|
||||||
|
|
||||||
// kernels starting from this will have difficulty calculated by using bitcoin algorithm
|
// kernels starting from this will have difficulty calculated by using bitcoin algorithm
|
||||||
#define A_DARK(a, b) \
|
#define A_DARK(a, b) \
|
||||||
{ a, 1, 1, 1, 0, 0, 0xFF, 0x00000000ffff0000ULL, 0xFFFFULL, 0x0000ffffUL, 0, 0, CL_QUEUE_OUT_OF_ORDER_EXEC_MODE_ENABLE, b, queue_sph_kernel, gen_hash, NULL}
|
{ a, 1, 1, 1, 0, 0, 0xFF, 0x00000000ffff0000ULL, 0xFFFFULL, 0x0000ffffUL, 0, 0, CL_QUEUE_OUT_OF_ORDER_EXEC_MODE_ENABLE, b, queue_sph_kernel, gen_hash, NULL}
|
||||||
A_DARK( "darkcoin", darkcoin_regenhash),
|
A_DARK( "darkcoin", darkcoin_regenhash),
|
||||||
A_DARK( "inkcoin", inkcoin_regenhash),
|
A_DARK( "inkcoin", inkcoin_regenhash),
|
||||||
A_DARK( "myriadcoin-groestl", myriadcoin_groestl_regenhash),
|
A_DARK( "myriadcoin-groestl", myriadcoin_groestl_regenhash),
|
||||||
#undef A_DARK
|
#undef A_DARK
|
||||||
|
|
||||||
{ "twecoin", 1, 1, 1, 0, 0, 0xFF, 0x00000000ffff0000ULL, 0xFFFFULL, 0x0000ffffUL, 0, 0, CL_QUEUE_OUT_OF_ORDER_EXEC_MODE_ENABLE, twecoin_regenhash, queue_sph_kernel, sha256, NULL},
|
{ "twecoin", 1, 1, 1, 0, 0, 0xFF, 0x00000000ffff0000ULL, 0xFFFFULL, 0x0000ffffUL, 0, 0, CL_QUEUE_OUT_OF_ORDER_EXEC_MODE_ENABLE, twecoin_regenhash, queue_sph_kernel, sha256, NULL},
|
||||||
{ "maxcoin", 1, 256, 1, 4, 15, 0x0F, 0x00000000ffff0000ULL, 0xFFFFULL, 0x000000ffUL, 0, 0, CL_QUEUE_OUT_OF_ORDER_EXEC_MODE_ENABLE, maxcoin_regenhash, queue_maxcoin_kernel, sha256, NULL},
|
{ "maxcoin", 1, 256, 1, 4, 15, 0x0F, 0x00000000ffff0000ULL, 0xFFFFULL, 0x000000ffUL, 0, 0, CL_QUEUE_OUT_OF_ORDER_EXEC_MODE_ENABLE, maxcoin_regenhash, queue_maxcoin_kernel, sha256, NULL},
|
||||||
{ "darkcoin-mod", 1, 1, 1, 0, 0, 0xFF, 0x00000000ffff0000ULL, 0xFFFFULL, 0x0000ffffUL, 10, 8 * 16 * 4194304, 0, darkcoin_regenhash, queue_darkcoin_mod_kernel, gen_hash, NULL},
|
{ "darkcoin-mod", 1, 1, 1, 0, 0, 0xFF, 0x00000000ffff0000ULL, 0xFFFFULL, 0x0000ffffUL, 10, 8 * 16 * 4194304, 0, darkcoin_regenhash, queue_darkcoin_mod_kernel, gen_hash, NULL},
|
||||||
|
|
||||||
{ "marucoin", 1, 1, 1, 0, 0, 0xFF, 0x00000000ffff0000ULL, 0xFFFFULL, 0x0000ffffUL, 0, 0, CL_QUEUE_OUT_OF_ORDER_EXEC_MODE_ENABLE, marucoin_regenhash, queue_sph_kernel, gen_hash, append_hamsi_compiler_options},
|
{ "marucoin", 1, 1, 1, 0, 0, 0xFF, 0x00000000ffff0000ULL, 0xFFFFULL, 0x0000ffffUL, 0, 0, CL_QUEUE_OUT_OF_ORDER_EXEC_MODE_ENABLE, marucoin_regenhash, queue_sph_kernel, gen_hash, append_hamsi_compiler_options},
|
||||||
{ "marucoin-mod", 1, 1, 1, 0, 0, 0xFF, 0x00000000ffff0000ULL, 0xFFFFULL, 0x0000ffffUL, 12, 8 * 16 * 4194304, 0, marucoin_regenhash, queue_marucoin_mod_kernel, gen_hash, append_hamsi_compiler_options},
|
{ "marucoin-mod", 1, 1, 1, 0, 0, 0xFF, 0x00000000ffff0000ULL, 0xFFFFULL, 0x0000ffffUL, 12, 8 * 16 * 4194304, 0, marucoin_regenhash, queue_marucoin_mod_kernel, gen_hash, append_hamsi_compiler_options},
|
||||||
{ "marucoin-modold", 1, 1, 1, 0, 0, 0xFF, 0x00000000ffff0000ULL, 0xFFFFULL, 0x0000ffffUL, 10, 8 * 16 * 4194304, 0, marucoin_regenhash, queue_marucoin_mod_old_kernel, gen_hash, append_hamsi_compiler_options},
|
{ "marucoin-modold", 1, 1, 1, 0, 0, 0xFF, 0x00000000ffff0000ULL, 0xFFFFULL, 0x0000ffffUL, 10, 8 * 16 * 4194304, 0, marucoin_regenhash, queue_marucoin_mod_old_kernel, gen_hash, append_hamsi_compiler_options},
|
||||||
|
|
||||||
// kernels starting from this will have difficulty calculated by using fuguecoin algorithm
|
// kernels starting from this will have difficulty calculated by using fuguecoin algorithm
|
||||||
#define A_FUGUE(a, b) \
|
#define A_FUGUE(a, b) \
|
||||||
{ a, 1, 256, 256, 0, 0, 0xFF, 0x00000000ffff0000ULL, 0xFFFFULL, 0x0000ffffUL, 0, 0, CL_QUEUE_OUT_OF_ORDER_EXEC_MODE_ENABLE, b, queue_sph_kernel, sha256, NULL}
|
{ a, 1, 256, 256, 0, 0, 0xFF, 0x00000000ffff0000ULL, 0xFFFFULL, 0x0000ffffUL, 0, 0, CL_QUEUE_OUT_OF_ORDER_EXEC_MODE_ENABLE, b, queue_sph_kernel, sha256, NULL}
|
||||||
A_FUGUE( "fuguecoin", fuguecoin_regenhash),
|
A_FUGUE( "fuguecoin", fuguecoin_regenhash),
|
||||||
A_FUGUE( "groestlcoin", groestlcoin_regenhash),
|
A_FUGUE( "groestlcoin", groestlcoin_regenhash),
|
||||||
#undef A_FUGUE
|
#undef A_FUGUE
|
||||||
|
|
||||||
// Terminator (do not remove)
|
// Terminator (do not remove)
|
||||||
{ NULL, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, NULL, NULL, NULL, NULL}
|
{ NULL, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, NULL, NULL, NULL, NULL}
|
||||||
};
|
};
|
||||||
|
|
||||||
void copy_algorithm_settings(algorithm_t* dest, const char* algo) {
|
void copy_algorithm_settings(algorithm_t* dest, const char* algo)
|
||||||
algorithm_settings_t* src;
|
{
|
||||||
|
algorithm_settings_t* src;
|
||||||
|
|
||||||
// Find algorithm settings and copy
|
// Find algorithm settings and copy
|
||||||
for (src = algos; src->name; src++) {
|
for (src = algos; src->name; src++) {
|
||||||
if (strcmp(src->name, algo) == 0) {
|
if (strcmp(src->name, algo) == 0) {
|
||||||
strcpy(dest->name, src->name);
|
strcpy(dest->name, src->name);
|
||||||
|
|
||||||
dest->diff_multiplier1 = src->diff_multiplier1;
|
dest->diff_multiplier1 = src->diff_multiplier1;
|
||||||
dest->diff_multiplier2 = src->diff_multiplier2;
|
dest->diff_multiplier2 = src->diff_multiplier2;
|
||||||
dest->share_diff_multiplier = src->share_diff_multiplier;
|
dest->share_diff_multiplier = src->share_diff_multiplier;
|
||||||
dest->xintensity_shift = src->xintensity_shift;
|
dest->xintensity_shift = src->xintensity_shift;
|
||||||
dest->intensity_shift = src->intensity_shift;
|
dest->intensity_shift = src->intensity_shift;
|
||||||
dest->found_idx = src->found_idx;
|
dest->found_idx = src->found_idx;
|
||||||
dest->diff_nonce = src->diff_nonce;
|
dest->diff_nonce = src->diff_nonce;
|
||||||
dest->diff_numerator = src->diff_numerator;
|
dest->diff_numerator = src->diff_numerator;
|
||||||
dest->diff1targ = src->diff1targ;
|
dest->diff1targ = src->diff1targ;
|
||||||
dest->n_extra_kernels = src->n_extra_kernels;
|
dest->n_extra_kernels = src->n_extra_kernels;
|
||||||
dest->rw_buffer_size = src->rw_buffer_size;
|
dest->rw_buffer_size = src->rw_buffer_size;
|
||||||
dest->cq_properties = src->cq_properties;
|
dest->cq_properties = src->cq_properties;
|
||||||
dest->regenhash = src->regenhash;
|
dest->regenhash = src->regenhash;
|
||||||
dest->queue_kernel = src->queue_kernel;
|
dest->queue_kernel = src->queue_kernel;
|
||||||
dest->gen_hash = src->gen_hash;
|
dest->gen_hash = src->gen_hash;
|
||||||
dest->set_compile_options = src->set_compile_options;
|
dest->set_compile_options = src->set_compile_options;
|
||||||
break;
|
break;
|
||||||
}
|
|
||||||
}
|
}
|
||||||
|
}
|
||||||
|
|
||||||
// if not found
|
// if not found
|
||||||
if (src->name == NULL) {
|
if (src->name == NULL) {
|
||||||
applog(LOG_WARNING, "Algorithm %s not found, using %s.", algo, algos->name);
|
applog(LOG_WARNING, "Algorithm %s not found, using %s.", algo, algos->name);
|
||||||
copy_algorithm_settings(dest, algos->name);
|
copy_algorithm_settings(dest, algos->name);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
void set_algorithm(algorithm_t* algo, const char* newname_alias) {
|
void set_algorithm(algorithm_t* algo, const char* newname_alias)
|
||||||
const char* newname;
|
{
|
||||||
uint8_t nfactor = 10;
|
const char* newname;
|
||||||
|
uint8_t nfactor = 10;
|
||||||
|
|
||||||
// scrypt is default ckolivas kernel
|
// scrypt is default ckolivas kernel
|
||||||
if (strcmp(newname_alias, "scrypt") == 0)
|
if (strcmp(newname_alias, "scrypt") == 0) {
|
||||||
newname = "ckolivas";
|
newname = "ckolivas";
|
||||||
// Adaptive N-factor Scrypt is default ckolivas kernel with nfactor 11
|
}
|
||||||
else if ((strcmp(newname_alias, "adaptive-n-factor") == 0) ||
|
// Adaptive N-factor Scrypt is default ckolivas kernel with nfactor 11
|
||||||
(strcmp(newname_alias, "adaptive-nfactor") == 0) ||
|
else if ((strcmp(newname_alias, "adaptive-n-factor") == 0) ||
|
||||||
(strcmp(newname_alias, "nscrypt") == 0) ||
|
(strcmp(newname_alias, "adaptive-nfactor") == 0) ||
|
||||||
(strcmp(newname_alias, "adaptive-nscrypt") == 0) ||
|
(strcmp(newname_alias, "nscrypt") == 0) ||
|
||||||
(strcmp(newname_alias, "adaptive-n-scrypt") == 0)) {
|
(strcmp(newname_alias, "adaptive-nscrypt") == 0) ||
|
||||||
newname = "ckolivas";
|
(strcmp(newname_alias, "adaptive-n-scrypt") == 0)) {
|
||||||
nfactor = 11;
|
newname = "ckolivas";
|
||||||
|
nfactor = 11;
|
||||||
// Not an alias
|
// Not an alias
|
||||||
} else
|
}
|
||||||
newname = newname_alias;
|
else {
|
||||||
|
newname = newname_alias;
|
||||||
|
}
|
||||||
|
|
||||||
copy_algorithm_settings(algo, newname);
|
copy_algorithm_settings(algo, newname);
|
||||||
|
|
||||||
// Doesn't matter for non-scrypt algorithms
|
// Doesn't matter for non-scrypt algorithms
|
||||||
set_algorithm_nfactor(algo, nfactor);
|
set_algorithm_nfactor(algo, nfactor);
|
||||||
}
|
}
|
||||||
|
|
||||||
void set_algorithm_nfactor(algorithm_t* algo, const uint8_t nfactor) {
|
void set_algorithm_nfactor(algorithm_t* algo, const uint8_t nfactor)
|
||||||
algo->nfactor = nfactor;
|
{
|
||||||
algo->n = (1 << nfactor);
|
algo->nfactor = nfactor;
|
||||||
|
algo->n = (1 << nfactor);
|
||||||
}
|
}
|
||||||
|
|
||||||
bool cmp_algorithm(algorithm_t* algo1, algorithm_t* algo2) {
|
bool cmp_algorithm(algorithm_t* algo1, algorithm_t* algo2)
|
||||||
return (strcmp(algo1->name, algo2->name) == 0) &&
|
{
|
||||||
(algo1->nfactor == algo2->nfactor);
|
return (strcmp(algo1->name, algo2->name) == 0) &&
|
||||||
|
(algo1->nfactor == algo2->nfactor);
|
||||||
}
|
}
|
||||||
|
38
algorithm.h
38
algorithm.h
@ -22,25 +22,25 @@ struct work;
|
|||||||
* a specific coin.
|
* a specific coin.
|
||||||
*/
|
*/
|
||||||
typedef struct _algorithm_t {
|
typedef struct _algorithm_t {
|
||||||
char name[20]; /* Human-readable identifier */
|
char name[20]; /* Human-readable identifier */
|
||||||
uint32_t n; /* N (CPU/Memory tradeoff parameter) */
|
uint32_t n; /* N (CPU/Memory tradeoff parameter) */
|
||||||
uint8_t nfactor; /* Factor of N above (n = 2^nfactor) */
|
uint8_t nfactor; /* Factor of N above (n = 2^nfactor) */
|
||||||
double diff_multiplier1;
|
double diff_multiplier1;
|
||||||
double diff_multiplier2;
|
double diff_multiplier2;
|
||||||
double share_diff_multiplier;
|
double share_diff_multiplier;
|
||||||
uint32_t xintensity_shift;
|
uint32_t xintensity_shift;
|
||||||
uint32_t intensity_shift;
|
uint32_t intensity_shift;
|
||||||
uint32_t found_idx;
|
uint32_t found_idx;
|
||||||
unsigned long long diff_nonce;
|
unsigned long long diff_nonce;
|
||||||
unsigned long long diff_numerator;
|
unsigned long long diff_numerator;
|
||||||
uint32_t diff1targ;
|
uint32_t diff1targ;
|
||||||
size_t n_extra_kernels;
|
size_t n_extra_kernels;
|
||||||
long rw_buffer_size;
|
long rw_buffer_size;
|
||||||
cl_command_queue_properties cq_properties;
|
cl_command_queue_properties cq_properties;
|
||||||
void (*regenhash)(struct work *);
|
void (*regenhash)(struct work *);
|
||||||
cl_int (*queue_kernel)(struct __clState *, struct _dev_blk_ctx *, cl_uint);
|
cl_int (*queue_kernel)(struct __clState *, struct _dev_blk_ctx *, cl_uint);
|
||||||
void (*gen_hash)(const unsigned char *, unsigned int, unsigned char *);
|
void (*gen_hash)(const unsigned char *, unsigned int, unsigned char *);
|
||||||
void (*set_compile_options)(struct _build_kernel_data *, struct cgpu_info *, struct _algorithm_t *);
|
void (*set_compile_options)(struct _build_kernel_data *, struct cgpu_info *, struct _algorithm_t *);
|
||||||
} algorithm_t;
|
} algorithm_t;
|
||||||
|
|
||||||
/* Set default parameters based on name. */
|
/* Set default parameters based on name. */
|
||||||
|
Loading…
Reference in New Issue
Block a user