#ifndef _ETHASH_CUDA_MINER_KERNEL_H_ #define _ETHASH_CUDA_MINER_KERNEL_H_ #include #include #include #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, 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