mirror of
https://github.com/GOSTSec/ccminer
synced 2025-01-27 23:14:27 +00:00
neoscrypt: improve perfs and fix the Titan default intensity
This commit is contained in:
parent
78dad7dd65
commit
d8a64d4bd2
@ -1319,7 +1319,6 @@ static void Blake2Shost(uint32_t * inout, const uint32_t * inkey)
|
|||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
#define SHIFT 128U
|
|
||||||
#define TPB 32
|
#define TPB 32
|
||||||
#define TPB2 64
|
#define TPB2 64
|
||||||
|
|
||||||
@ -1346,7 +1345,7 @@ __launch_bounds__(TPB, 1)
|
|||||||
void neoscrypt_gpu_hash_chacha1()
|
void neoscrypt_gpu_hash_chacha1()
|
||||||
{
|
{
|
||||||
const uint32_t thread = (blockDim.y * blockIdx.x + threadIdx.y);
|
const uint32_t thread = (blockDim.y * blockIdx.x + threadIdx.y);
|
||||||
const uint32_t shift = SHIFT * 8U * (thread & 8191);
|
const uint32_t threads = (gridDim.x * blockDim.y);
|
||||||
const uint32_t shiftTr = 8U * thread;
|
const uint32_t shiftTr = 8U * thread;
|
||||||
|
|
||||||
uint4 X[4];
|
uint4 X[4];
|
||||||
@ -1361,7 +1360,7 @@ void neoscrypt_gpu_hash_chacha1()
|
|||||||
#pragma nounroll
|
#pragma nounroll
|
||||||
for (int i = 0; i < 128; i++)
|
for (int i = 0; i < 128; i++)
|
||||||
{
|
{
|
||||||
uint32_t offset = shift + i * 8U;
|
uint32_t offset = 8U * (thread + threads * i);
|
||||||
for (int j = 0; j < 4; j++)
|
for (int j = 0; j < 4; j++)
|
||||||
((uint4*)(W + offset))[j * 4 + threadIdx.x] = X[j];
|
((uint4*)(W + offset))[j * 4 + threadIdx.x] = X[j];
|
||||||
neoscrypt_chacha(X);
|
neoscrypt_chacha(X);
|
||||||
@ -1370,7 +1369,7 @@ void neoscrypt_gpu_hash_chacha1()
|
|||||||
#pragma nounroll
|
#pragma nounroll
|
||||||
for (int t = 0; t < 128; t++)
|
for (int t = 0; t < 128; t++)
|
||||||
{
|
{
|
||||||
uint32_t offset = shift + (WarpShuffle(X[3].x, 0, 4) & 0x7F) * 8U;
|
uint32_t offset = 8U * (thread + threads * (WarpShuffle(X[3].x, 0, 4) & 0x7F));
|
||||||
for (int j = 0; j < 4; j++)
|
for (int j = 0; j < 4; j++)
|
||||||
X[j] ^= ((uint4*)(W + offset))[j * 4 + threadIdx.x];
|
X[j] ^= ((uint4*)(W + offset))[j * 4 + threadIdx.x];
|
||||||
neoscrypt_chacha(X);
|
neoscrypt_chacha(X);
|
||||||
@ -1391,7 +1390,7 @@ __launch_bounds__(TPB, 1)
|
|||||||
void neoscrypt_gpu_hash_salsa1()
|
void neoscrypt_gpu_hash_salsa1()
|
||||||
{
|
{
|
||||||
const uint32_t thread = (blockDim.y * blockIdx.x + threadIdx.y);
|
const uint32_t thread = (blockDim.y * blockIdx.x + threadIdx.y);
|
||||||
const uint32_t shift = SHIFT * 8U * (thread & 8191);
|
const uint32_t threads = (gridDim.x * blockDim.y);
|
||||||
const uint32_t shiftTr = 8U * thread;
|
const uint32_t shiftTr = 8U * thread;
|
||||||
|
|
||||||
uint4 Z[4];
|
uint4 Z[4];
|
||||||
@ -1406,7 +1405,7 @@ void neoscrypt_gpu_hash_salsa1()
|
|||||||
#pragma nounroll
|
#pragma nounroll
|
||||||
for (int i = 0; i < 128; i++)
|
for (int i = 0; i < 128; i++)
|
||||||
{
|
{
|
||||||
uint32_t offset = shift + i * 8U;
|
uint32_t offset = 8U * (thread + threads * i);
|
||||||
for (int j = 0; j < 4; j++)
|
for (int j = 0; j < 4; j++)
|
||||||
((uint4*)(W + offset))[j * 4 + threadIdx.x] = Z[j];
|
((uint4*)(W + offset))[j * 4 + threadIdx.x] = Z[j];
|
||||||
neoscrypt_salsa(Z);
|
neoscrypt_salsa(Z);
|
||||||
@ -1415,7 +1414,7 @@ void neoscrypt_gpu_hash_salsa1()
|
|||||||
#pragma nounroll
|
#pragma nounroll
|
||||||
for (int t = 0; t < 128; t++)
|
for (int t = 0; t < 128; t++)
|
||||||
{
|
{
|
||||||
uint32_t offset = shift + (WarpShuffle(Z[3].x, 0, 4) & 0x7F) * 8U;
|
uint32_t offset = 8U * (thread + threads * (WarpShuffle(Z[3].x, 0, 4) & 0x7F));
|
||||||
for (int j = 0; j < 4; j++)
|
for (int j = 0; j < 4; j++)
|
||||||
Z[j] ^= ((uint4*)(W + offset))[j * 4 + threadIdx.x];
|
Z[j] ^= ((uint4*)(W + offset))[j * 4 + threadIdx.x];
|
||||||
neoscrypt_salsa(Z);
|
neoscrypt_salsa(Z);
|
||||||
@ -1474,7 +1473,7 @@ void neoscrypt_init(int thr_id, uint32_t threads)
|
|||||||
cuda_get_arch(thr_id);
|
cuda_get_arch(thr_id);
|
||||||
|
|
||||||
CUDA_SAFE_CALL(cudaMalloc(&d_NNonce[thr_id], 2 * sizeof(uint32_t)));
|
CUDA_SAFE_CALL(cudaMalloc(&d_NNonce[thr_id], 2 * sizeof(uint32_t)));
|
||||||
CUDA_SAFE_CALL(cudaMalloc(&hash1, 32 * 128 * sizeof(uint64_t) * min(8192, threads)));
|
CUDA_SAFE_CALL(cudaMalloc(&hash1, 32 * 128 * sizeof(uint64_t) * threads));
|
||||||
CUDA_SAFE_CALL(cudaMalloc(&Trans1, 32 * sizeof(uint64_t) * threads));
|
CUDA_SAFE_CALL(cudaMalloc(&Trans1, 32 * sizeof(uint64_t) * threads));
|
||||||
CUDA_SAFE_CALL(cudaMalloc(&Trans2, 32 * sizeof(uint64_t) * threads));
|
CUDA_SAFE_CALL(cudaMalloc(&Trans2, 32 * sizeof(uint64_t) * threads));
|
||||||
CUDA_SAFE_CALL(cudaMalloc(&Trans3, 32 * sizeof(uint64_t) * threads));
|
CUDA_SAFE_CALL(cudaMalloc(&Trans3, 32 * sizeof(uint64_t) * threads));
|
||||||
|
@ -22,6 +22,7 @@ int scanhash_neoscrypt(int thr_id, struct work* work, uint32_t max_nonce, unsign
|
|||||||
int dev_id = device_map[thr_id];
|
int dev_id = device_map[thr_id];
|
||||||
int intensity = is_windows() ? 18 : 19;
|
int intensity = is_windows() ? 18 : 19;
|
||||||
if (strstr(device_name[dev_id], "GTX 10")) intensity = 21; // >= 20 need more than 2GB
|
if (strstr(device_name[dev_id], "GTX 10")) intensity = 21; // >= 20 need more than 2GB
|
||||||
|
if (strstr(device_name[dev_id], "TITAN")) intensity = 21;
|
||||||
|
|
||||||
uint32_t throughput = cuda_default_throughput(thr_id, 1U << intensity);
|
uint32_t throughput = cuda_default_throughput(thr_id, 1U << intensity);
|
||||||
throughput = throughput / 32; /* set for max intensity ~= 20 */
|
throughput = throughput / 32; /* set for max intensity ~= 20 */
|
||||||
|
Loading…
x
Reference in New Issue
Block a user