mirror of
https://github.com/GOSTSec/ccminer
synced 2025-01-12 07:48:33 +00:00
timetravel: cleanup, remove unused algos
+ cubehash 80 midstate
This commit is contained in:
parent
ffd6cf38bf
commit
57f8f776fb
@ -259,16 +259,32 @@ void x11_cubehash512_cpu_init(int thr_id, uint32_t threads) { }
|
|||||||
|
|
||||||
/***************************************************/
|
/***************************************************/
|
||||||
|
|
||||||
#define WANT_CUBEHASH80
|
/**
|
||||||
#ifdef WANT_CUBEHASH80
|
* Timetravel and x16 CUBEHASH-80 CUDA implementation
|
||||||
|
* by tpruvot@github - Jan 2017 / May 2018
|
||||||
|
*/
|
||||||
|
|
||||||
__constant__
|
__constant__ static uint32_t c_midstate128[32];
|
||||||
static uint32_t c_PaddedMessage80[20];
|
__constant__ static uint32_t c_PaddedMessage80[20];
|
||||||
|
|
||||||
|
#undef SPH_C32
|
||||||
|
#undef SPH_C64
|
||||||
|
#undef SPH_T32
|
||||||
|
#undef SPH_T64
|
||||||
|
#include "sph/sph_cubehash.h"
|
||||||
|
|
||||||
__host__
|
__host__
|
||||||
void cubehash512_setBlock_80(int thr_id, uint32_t* endiandata)
|
void cubehash512_setBlock_80(int thr_id, uint32_t* endiandata)
|
||||||
{
|
{
|
||||||
|
sph_cubehash512_context ctx_cubehash;
|
||||||
|
sph_cubehash512_init(&ctx_cubehash);
|
||||||
|
sph_cubehash512(&ctx_cubehash, (void*)endiandata, 64);
|
||||||
|
#ifndef NO_MIDSTATE
|
||||||
|
cudaMemcpyToSymbol(c_midstate128, ctx_cubehash.state, 128, 0, cudaMemcpyHostToDevice);
|
||||||
|
cudaMemcpyToSymbol(c_PaddedMessage80, &endiandata[16], 16, 0, cudaMemcpyHostToDevice);
|
||||||
|
#else
|
||||||
cudaMemcpyToSymbol(c_PaddedMessage80, endiandata, sizeof(c_PaddedMessage80), 0, cudaMemcpyHostToDevice);
|
cudaMemcpyToSymbol(c_PaddedMessage80, endiandata, sizeof(c_PaddedMessage80), 0, cudaMemcpyHostToDevice);
|
||||||
|
#endif
|
||||||
}
|
}
|
||||||
|
|
||||||
__global__
|
__global__
|
||||||
@ -278,11 +294,11 @@ void cubehash512_gpu_hash_80(const uint32_t threads, const uint32_t startNounce,
|
|||||||
if (thread < threads)
|
if (thread < threads)
|
||||||
{
|
{
|
||||||
const uint32_t nonce = startNounce + thread;
|
const uint32_t nonce = startNounce + thread;
|
||||||
|
uint32_t message[8];
|
||||||
uint32_t x[2][2][2][2][2];
|
uint32_t x[2][2][2][2][2];
|
||||||
|
#ifdef NO_MIDSTATE
|
||||||
Init(x);
|
Init(x);
|
||||||
|
|
||||||
uint32_t message[8];
|
|
||||||
// first 32 bytes
|
// first 32 bytes
|
||||||
AS_UINT4(&message[0]) = AS_UINT4(&c_PaddedMessage80[0]);
|
AS_UINT4(&message[0]) = AS_UINT4(&c_PaddedMessage80[0]);
|
||||||
AS_UINT4(&message[4]) = AS_UINT4(&c_PaddedMessage80[4]);
|
AS_UINT4(&message[4]) = AS_UINT4(&c_PaddedMessage80[4]);
|
||||||
@ -293,8 +309,31 @@ void cubehash512_gpu_hash_80(const uint32_t threads, const uint32_t startNounce,
|
|||||||
AS_UINT4(&message[4]) = AS_UINT4(&c_PaddedMessage80[12]);
|
AS_UINT4(&message[4]) = AS_UINT4(&c_PaddedMessage80[12]);
|
||||||
Update32(x, message);
|
Update32(x, message);
|
||||||
|
|
||||||
// last 16 bytes + Padding
|
// last 16 bytes
|
||||||
AS_UINT4(&message[0]) = AS_UINT4(&c_PaddedMessage80[16]);
|
AS_UINT4(&message[0]) = AS_UINT4(&c_PaddedMessage80[16]);
|
||||||
|
#else
|
||||||
|
AS_UINT2(x[0][0][0][0]) = AS_UINT2(&c_midstate128[ 0]);
|
||||||
|
AS_UINT2(x[0][0][0][1]) = AS_UINT2(&c_midstate128[ 2]);
|
||||||
|
AS_UINT2(x[0][0][1][0]) = AS_UINT2(&c_midstate128[ 4]);
|
||||||
|
AS_UINT2(x[0][0][1][1]) = AS_UINT2(&c_midstate128[ 6]);
|
||||||
|
AS_UINT2(x[0][1][0][0]) = AS_UINT2(&c_midstate128[ 8]);
|
||||||
|
AS_UINT2(x[0][1][0][1]) = AS_UINT2(&c_midstate128[10]);
|
||||||
|
AS_UINT2(x[0][1][1][0]) = AS_UINT2(&c_midstate128[12]);
|
||||||
|
AS_UINT2(x[0][1][1][1]) = AS_UINT2(&c_midstate128[14]);
|
||||||
|
|
||||||
|
AS_UINT2(x[1][0][0][0]) = AS_UINT2(&c_midstate128[16]);
|
||||||
|
AS_UINT2(x[1][0][0][1]) = AS_UINT2(&c_midstate128[18]);
|
||||||
|
AS_UINT2(x[1][0][1][0]) = AS_UINT2(&c_midstate128[20]);
|
||||||
|
AS_UINT2(x[1][0][1][1]) = AS_UINT2(&c_midstate128[22]);
|
||||||
|
AS_UINT2(x[1][1][0][0]) = AS_UINT2(&c_midstate128[24]);
|
||||||
|
AS_UINT2(x[1][1][0][1]) = AS_UINT2(&c_midstate128[26]);
|
||||||
|
AS_UINT2(x[1][1][1][0]) = AS_UINT2(&c_midstate128[28]);
|
||||||
|
AS_UINT2(x[1][1][1][1]) = AS_UINT2(&c_midstate128[30]);
|
||||||
|
|
||||||
|
// last 16 bytes
|
||||||
|
AS_UINT4(&message[0]) = AS_UINT4(&c_PaddedMessage80[0]);
|
||||||
|
#endif
|
||||||
|
// nonce + Padding
|
||||||
message[3] = cuda_swab32(nonce);
|
message[3] = cuda_swab32(nonce);
|
||||||
message[4] = 0x80;
|
message[4] = 0x80;
|
||||||
message[5] = 0;
|
message[5] = 0;
|
||||||
@ -317,4 +356,3 @@ void cubehash512_cuda_hash_80(const int thr_id, const uint32_t threads, const ui
|
|||||||
cubehash512_gpu_hash_80 <<<grid, block>>> (threads, startNounce, (uint64_t*) d_hash);
|
cubehash512_gpu_hash_80 <<<grid, block>>> (threads, startNounce, (uint64_t*) d_hash);
|
||||||
}
|
}
|
||||||
|
|
||||||
#endif
|
|
@ -20,11 +20,6 @@ extern "C" {
|
|||||||
#include "sph/sph_keccak.h"
|
#include "sph/sph_keccak.h"
|
||||||
#include "sph/sph_luffa.h"
|
#include "sph/sph_luffa.h"
|
||||||
#include "sph/sph_cubehash.h"
|
#include "sph/sph_cubehash.h"
|
||||||
#if HASH_FUNC_COUNT > 8
|
|
||||||
#include "sph/sph_shavite.h"
|
|
||||||
#include "sph/sph_simd.h"
|
|
||||||
#include "sph/sph_echo.h"
|
|
||||||
#endif
|
|
||||||
}
|
}
|
||||||
|
|
||||||
#include "miner.h"
|
#include "miner.h"
|
||||||
@ -42,11 +37,6 @@ enum Algo {
|
|||||||
KECCAK,
|
KECCAK,
|
||||||
LUFFA,
|
LUFFA,
|
||||||
CUBEHASH,
|
CUBEHASH,
|
||||||
#if HASH_FUNC_COUNT > 8
|
|
||||||
SHAVITE,
|
|
||||||
SIMD,
|
|
||||||
ECHO,
|
|
||||||
#endif
|
|
||||||
MAX_ALGOS_COUNT
|
MAX_ALGOS_COUNT
|
||||||
};
|
};
|
||||||
|
|
||||||
@ -153,11 +143,6 @@ extern "C" void timetravel_hash(void *output, const void *input)
|
|||||||
sph_keccak512_context ctx_keccak;
|
sph_keccak512_context ctx_keccak;
|
||||||
sph_luffa512_context ctx_luffa1;
|
sph_luffa512_context ctx_luffa1;
|
||||||
sph_cubehash512_context ctx_cubehash1;
|
sph_cubehash512_context ctx_cubehash1;
|
||||||
#if HASH_FUNC_COUNT > 8
|
|
||||||
sph_shavite512_context ctx_shavite1;
|
|
||||||
sph_simd512_context ctx_simd1;
|
|
||||||
sph_echo512_context ctx_echo1;
|
|
||||||
#endif
|
|
||||||
|
|
||||||
if (s_sequence == UINT32_MAX) {
|
if (s_sequence == UINT32_MAX) {
|
||||||
uint32_t *data = (uint32_t*) input;
|
uint32_t *data = (uint32_t*) input;
|
||||||
@ -175,11 +160,6 @@ extern "C" void timetravel_hash(void *output, const void *input)
|
|||||||
const char elem = hashOrder[i];
|
const char elem = hashOrder[i];
|
||||||
uint8_t algo = elem >= 'A' ? elem - 'A' + 10 : elem - '0';
|
uint8_t algo = elem >= 'A' ? elem - 'A' + 10 : elem - '0';
|
||||||
|
|
||||||
if (i > 0) {
|
|
||||||
in = (void*) hash;
|
|
||||||
size = 64;
|
|
||||||
}
|
|
||||||
|
|
||||||
switch (algo) {
|
switch (algo) {
|
||||||
case BLAKE:
|
case BLAKE:
|
||||||
sph_blake512_init(&ctx_blake);
|
sph_blake512_init(&ctx_blake);
|
||||||
@ -195,7 +175,6 @@ extern "C" void timetravel_hash(void *output, const void *input)
|
|||||||
sph_groestl512_init(&ctx_groestl);
|
sph_groestl512_init(&ctx_groestl);
|
||||||
sph_groestl512(&ctx_groestl, in, size);
|
sph_groestl512(&ctx_groestl, in, size);
|
||||||
sph_groestl512_close(&ctx_groestl, hash);
|
sph_groestl512_close(&ctx_groestl, hash);
|
||||||
//applog_hex((void*)hash, 32);
|
|
||||||
break;
|
break;
|
||||||
case SKEIN:
|
case SKEIN:
|
||||||
sph_skein512_init(&ctx_skein);
|
sph_skein512_init(&ctx_skein);
|
||||||
@ -222,24 +201,10 @@ extern "C" void timetravel_hash(void *output, const void *input)
|
|||||||
sph_cubehash512(&ctx_cubehash1, in, size);
|
sph_cubehash512(&ctx_cubehash1, in, size);
|
||||||
sph_cubehash512_close(&ctx_cubehash1, hash);
|
sph_cubehash512_close(&ctx_cubehash1, hash);
|
||||||
break;
|
break;
|
||||||
#if HASH_FUNC_COUNT > 8
|
|
||||||
case SHAVITE:
|
|
||||||
sph_shavite512_init(&ctx_shavite1);
|
|
||||||
sph_shavite512(&ctx_shavite1, in, size);
|
|
||||||
sph_shavite512_close(&ctx_shavite1, hash);
|
|
||||||
break;
|
|
||||||
case SIMD:
|
|
||||||
sph_simd512_init(&ctx_simd1);
|
|
||||||
sph_simd512(&ctx_simd1, in, size);
|
|
||||||
sph_simd512_close(&ctx_simd1, hash);
|
|
||||||
break;
|
|
||||||
case ECHO:
|
|
||||||
sph_echo512_init(&ctx_echo1);
|
|
||||||
sph_echo512(&ctx_echo1, in, size);
|
|
||||||
sph_echo512_close(&ctx_echo1, hash);
|
|
||||||
break;
|
|
||||||
#endif
|
|
||||||
}
|
}
|
||||||
|
|
||||||
|
in = (void*) hash;
|
||||||
|
size = 64;
|
||||||
}
|
}
|
||||||
|
|
||||||
memcpy(output, hash, 32);
|
memcpy(output, hash, 32);
|
||||||
@ -330,13 +295,7 @@ extern "C" int scanhash_timetravel(int thr_id, struct work* work, uint32_t max_n
|
|||||||
qubit_luffa512_cpu_init(thr_id, throughput); // only constants (480 bytes)
|
qubit_luffa512_cpu_init(thr_id, throughput); // only constants (480 bytes)
|
||||||
x11_luffa512_cpu_init(thr_id, throughput);
|
x11_luffa512_cpu_init(thr_id, throughput);
|
||||||
x11_cubehash512_cpu_init(thr_id, throughput);
|
x11_cubehash512_cpu_init(thr_id, throughput);
|
||||||
#if HASH_FUNC_COUNT > 8
|
|
||||||
x11_shavite512_cpu_init(thr_id, throughput);
|
|
||||||
x11_echo512_cpu_init(thr_id, throughput);
|
|
||||||
if (x11_simd512_cpu_init(thr_id, throughput) != 0) {
|
|
||||||
return 0;
|
|
||||||
}
|
|
||||||
#endif
|
|
||||||
CUDA_CALL_OR_RET_X(cudaMalloc(&d_hash[thr_id], (size_t) 64 * throughput), -1);
|
CUDA_CALL_OR_RET_X(cudaMalloc(&d_hash[thr_id], (size_t) 64 * throughput), -1);
|
||||||
CUDA_CALL_OR_RET_X(cudaMemset(d_hash[thr_id], 0, (size_t) 64 * throughput), -1);
|
CUDA_CALL_OR_RET_X(cudaMemset(d_hash[thr_id], 0, (size_t) 64 * throughput), -1);
|
||||||
|
|
||||||
@ -471,20 +430,6 @@ extern "C" int scanhash_timetravel(int thr_id, struct work* work, uint32_t max_n
|
|||||||
x11_cubehash512_cpu_hash_64(thr_id, throughput, pdata[19], NULL, d_hash[thr_id], order++);
|
x11_cubehash512_cpu_hash_64(thr_id, throughput, pdata[19], NULL, d_hash[thr_id], order++);
|
||||||
TRACE("cube :");
|
TRACE("cube :");
|
||||||
break;
|
break;
|
||||||
#if HASH_FUNC_COUNT > 8
|
|
||||||
case SHAVITE:
|
|
||||||
x11_shavite512_cpu_hash_64(thr_id, throughput, pdata[19], NULL, d_hash[thr_id], order++);
|
|
||||||
TRACE("shavite:");
|
|
||||||
break;
|
|
||||||
case SIMD:
|
|
||||||
x11_simd512_cpu_hash_64(thr_id, throughput, pdata[19], NULL, d_hash[thr_id], order++);
|
|
||||||
TRACE("simd :");
|
|
||||||
break;
|
|
||||||
case ECHO:
|
|
||||||
x11_echo512_cpu_hash_64(thr_id, throughput, pdata[19], NULL, d_hash[thr_id], order++);
|
|
||||||
TRACE("echo :");
|
|
||||||
break;
|
|
||||||
#endif
|
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -544,9 +489,7 @@ extern "C" void free_timetravel(int thr_id)
|
|||||||
|
|
||||||
quark_blake512_cpu_free(thr_id);
|
quark_blake512_cpu_free(thr_id);
|
||||||
quark_groestl512_cpu_free(thr_id);
|
quark_groestl512_cpu_free(thr_id);
|
||||||
#if HASH_FUNC_COUNT > 8
|
|
||||||
x11_simd512_cpu_free(thr_id);
|
|
||||||
#endif
|
|
||||||
cuda_check_cpu_free(thr_id);
|
cuda_check_cpu_free(thr_id);
|
||||||
init[thr_id] = false;
|
init[thr_id] = false;
|
||||||
|
|
||||||
|
Loading…
Reference in New Issue
Block a user