|
|
|
#ifndef _ETHASH_CUDA_MINER_KERNEL_H_
|
|
|
|
#define _ETHASH_CUDA_MINER_KERNEL_H_
|
|
|
|
|
|
|
|
#include <stdio.h>
|
|
|
|
#include <stdint.h>
|
|
|
|
#include <cuda_runtime.h>
|
|
|
|
|
|
|
|
#define SEARCH_RESULT_BUFFER_SIZE 64
|
|
|
|
#define ACCESSES 64
|
|
|
|
#define THREADS_PER_HASH (128 / 16)
|
|
|
|
|
|
|
|
typedef struct
|
|
|
|
{
|
|
|
|
uint4 uint4s[32 / sizeof(uint4)];
|
|
|
|
} hash32_t;
|
|
|
|
|
|
|
|
typedef struct
|
|
|
|
{
|
|
|
|
uint4 uint4s[128 / sizeof(uint4)];
|
|
|
|
} hash128_t;
|
|
|
|
|
|
|
|
typedef union {
|
|
|
|
uint32_t words[64 / sizeof(uint32_t)];
|
|
|
|
uint2 uint2s[64 / sizeof(uint2)];
|
|
|
|
uint4 uint4s[64 / sizeof(uint4)];
|
|
|
|
} hash64_t;
|
|
|
|
|
|
|
|
typedef union {
|
|
|
|
uint32_t words[200 / sizeof(uint32_t)];
|
|
|
|
uint2 uint2s[200 / sizeof(uint2)];
|
|
|
|
uint4 uint4s[200 / sizeof(uint4)];
|
|
|
|
} hash200_t;
|
|
|
|
|
|
|
|
void set_constants(
|
|
|
|
hash128_t* _dag,
|
|
|
|
uint32_t _dag_size,
|
|
|
|
hash64_t * _light,
|
|
|
|
uint32_t _light_size
|
|
|
|
);
|
|
|
|
|
|
|
|
void set_header(
|
|
|
|
hash32_t _header
|
|
|
|
);
|
|
|
|
|
|
|
|
void set_target(
|
|
|
|
uint64_t _target
|
|
|
|
);
|
|
|
|
|
|
|
|
void run_ethash_search(
|
|
|
|
uint32_t search_batch_size,
|
|
|
|
uint32_t workgroup_size,
|
|
|
|
uint32_t sharedbytes,
|
|
|
|
cudaStream_t stream,
|
|
|
|
volatile uint32_t* g_output,
|
|
|
|
uint64_t start_nonce
|
|
|
|
);
|
|
|
|
|
|
|
|
void ethash_generate_dag(
|
|
|
|
uint64_t dag_size,
|
|
|
|
uint32_t blocks,
|
|
|
|
uint32_t threads,
|
|
|
|
cudaStream_t stream
|
|
|
|
);
|
|
|
|
|
|
|
|
|
|
|
|
#define CUDA_SAFE_CALL(call) \
|
|
|
|
do { \
|
|
|
|
cudaError_t err = call; \
|
|
|
|
if (cudaSuccess != err) { \
|
|
|
|
const char * errorString = cudaGetErrorString(err); \
|
|
|
|
fprintf(stderr, \
|
|
|
|
"CUDA error in func '%s' at line %i : %s.\n", \
|
|
|
|
__FUNCTION__, __LINE__, errorString); \
|
|
|
|
throw std::runtime_error(errorString); \
|
|
|
|
} \
|
|
|
|
} while (0)
|
|
|
|
|
|
|
|
#endif
|