miner.h 15 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377378379380381382383384385386387388389390391392393394395396397398399400401402403404405406407408409410411412413414415416417418419420421422423424425426427428429430431432433434435436437438439440441442443444445446447448449450451452453454455456457458459460461462463464465466467468469470471472473474475476477478479480481482483484485486487488489490491492493494495496497498499500501502503504505506507508509510511512513514515516517518519520521522523524525526527528529530531532533534535536537538539540541542543544545546547548549550551552553554555556557558559560561562563564565566567568569570571572573574575576577578579580581582583584585586587588589590591592593594595596597598599600601602603604605606607608609610611612613614615616617618619620621622623624625626627628629630631632633634635636637638639640641642643644645646647648649650651652653654655656657658659660661662663664665666667668669670671672673674675676677678679680681682683684685
  1. #ifndef __MINER_H__
  2. #define __MINER_H__
  3. #include "config.h"
  4. #include <stdbool.h>
  5. #include <stdint.h>
  6. #include <sys/time.h>
  7. #include <pthread.h>
  8. #include <jansson.h>
  9. #include <curl/curl.h>
  10. #include "elist.h"
  11. #include "uthash.h"
  12. #include "logging.h"
  13. #ifdef HAVE_OPENCL
  14. #ifdef __APPLE_CC__
  15. #include <OpenCL/opencl.h>
  16. #else
  17. #include <CL/cl.h>
  18. #endif
  19. #endif /* HAVE_OPENCL */
  20. #ifdef STDC_HEADERS
  21. # include <stdlib.h>
  22. # include <stddef.h>
  23. #else
  24. # ifdef HAVE_STDLIB_H
  25. # include <stdlib.h>
  26. # endif
  27. #endif
  28. #ifdef HAVE_ALLOCA_H
  29. # include <alloca.h>
  30. #elif defined __GNUC__
  31. # ifndef WIN32
  32. # define alloca __builtin_alloca
  33. # else
  34. # include <malloc.h>
  35. # endif
  36. #elif defined _AIX
  37. # define alloca __alloca
  38. #elif defined _MSC_VER
  39. # include <malloc.h>
  40. # define alloca _alloca
  41. #else
  42. # ifndef HAVE_ALLOCA
  43. # ifdef __cplusplus
  44. extern "C"
  45. # endif
  46. void *alloca (size_t);
  47. # endif
  48. #endif
  49. #if defined (__linux)
  50. #ifndef LINUX
  51. #define LINUX
  52. #endif
  53. #endif
  54. #ifdef HAVE_ADL
  55. #include "ADL_SDK/adl_sdk.h"
  56. #endif
  57. #ifdef HAVE_LIBUSB
  58. #include <libusb-1.0/libusb.h>
  59. #endif
  60. #ifdef USE_ZTEX
  61. #include "libztex.h"
  62. #endif
  63. #if !defined(WIN32) && ((__GNUC__ > 4) || (__GNUC__ == 4 && __GNUC_MINOR__ >= 3))
  64. #define bswap_16 __builtin_bswap16
  65. #define bswap_32 __builtin_bswap32
  66. #define bswap_64 __builtin_bswap64
  67. #else
  68. #if HAVE_BYTESWAP_H
  69. #include <byteswap.h>
  70. #elif defined(USE_SYS_ENDIAN_H)
  71. #include <sys/endian.h>
  72. #elif defined(__APPLE__)
  73. #include <libkern/OSByteOrder.h>
  74. #define bswap_16 OSSwapInt16
  75. #define bswap_32 OSSwapInt32
  76. #define bswap_64 OSSwapInt64
  77. #else
  78. #define bswap_16(value) \
  79. ((((value) & 0xff) << 8) | ((value) >> 8))
  80. #define bswap_32(value) \
  81. (((uint32_t)bswap_16((uint16_t)((value) & 0xffff)) << 16) | \
  82. (uint32_t)bswap_16((uint16_t)((value) >> 16)))
  83. #define bswap_64(value) \
  84. (((uint64_t)bswap_32((uint32_t)((value) & 0xffffffff)) \
  85. << 32) | \
  86. (uint64_t)bswap_32((uint32_t)((value) >> 32)))
  87. #endif
  88. #endif /* !defined(__GLXBYTEORDER_H__) */
  89. /* This assumes htobe32 is a macro in endian.h */
  90. #ifndef htobe32
  91. # if __BYTE_ORDER == __LITTLE_ENDIAN
  92. # define be32toh(x) bswap_32(x)
  93. # define htobe32(x) bswap_32(x)
  94. # elif __BYTE_ORDER == __BIG_ENDIAN
  95. # define be32toh(x) (x)
  96. # define htobe32(x) (x)
  97. #else
  98. #error UNKNOWN BYTE ORDER
  99. #endif
  100. #endif
  101. #undef unlikely
  102. #undef likely
  103. #if defined(__GNUC__) && (__GNUC__ > 2) && defined(__OPTIMIZE__)
  104. #define unlikely(expr) (__builtin_expect(!!(expr), 0))
  105. #define likely(expr) (__builtin_expect(!!(expr), 1))
  106. #else
  107. #define unlikely(expr) (expr)
  108. #define likely(expr) (expr)
  109. #endif
  110. #define __maybe_unused __attribute__((unused))
  111. #if defined(__i386__)
  112. #define WANT_CRYPTOPP_ASM32
  113. #endif
  114. #ifndef ARRAY_SIZE
  115. #define ARRAY_SIZE(arr) (sizeof(arr) / sizeof((arr)[0]))
  116. #endif
  117. enum alive {
  118. LIFE_WELL,
  119. LIFE_SICK,
  120. LIFE_DEAD,
  121. LIFE_NOSTART
  122. };
  123. enum pool_strategy {
  124. POOL_FAILOVER,
  125. POOL_ROUNDROBIN,
  126. POOL_ROTATE,
  127. POOL_LOADBALANCE,
  128. };
  129. #define TOP_STRATEGY (POOL_LOADBALANCE)
  130. struct strategies {
  131. const char *s;
  132. };
  133. struct cgpu_info;
  134. #ifdef HAVE_ADL
  135. struct gpu_adl {
  136. ADLTemperature lpTemperature;
  137. int iAdapterIndex;
  138. int lpAdapterID;
  139. int iBusNumber;
  140. char strAdapterName[256];
  141. ADLPMActivity lpActivity;
  142. ADLODParameters lpOdParameters;
  143. ADLODPerformanceLevels *DefPerfLev;
  144. ADLFanSpeedInfo lpFanSpeedInfo;
  145. ADLFanSpeedValue lpFanSpeedValue;
  146. ADLFanSpeedValue DefFanSpeedValue;
  147. int iEngineClock;
  148. int iMemoryClock;
  149. int iVddc;
  150. int iPercentage;
  151. bool autofan;
  152. bool autoengine;
  153. bool managed; /* Were the values ever changed on this card */
  154. int lastengine;
  155. int lasttemp;
  156. int targetfan;
  157. int targettemp;
  158. int overtemp;
  159. int minspeed;
  160. int maxspeed;
  161. int gpu;
  162. bool has_fanspeed;
  163. struct gpu_adl *twin;
  164. };
  165. #endif
  166. struct thr_info;
  167. struct work;
  168. struct device_api {
  169. char*dname;
  170. char*name;
  171. // API-global functions
  172. void (*api_detect)();
  173. // Device-specific functions
  174. void (*reinit_device)(struct cgpu_info*);
  175. void (*get_statline_before)(char*, struct cgpu_info*);
  176. void (*get_statline)(char*, struct cgpu_info*);
  177. // Thread-specific functions
  178. bool (*thread_prepare)(struct thr_info*);
  179. uint64_t (*can_limit_work)(struct thr_info*);
  180. bool (*thread_init)(struct thr_info*);
  181. void (*free_work)(struct thr_info*, struct work*);
  182. bool (*prepare_work)(struct thr_info*, struct work*);
  183. uint64_t (*scanhash)(struct thr_info*, struct work*, uint64_t);
  184. void (*thread_shutdown)(struct thr_info*);
  185. };
  186. enum dev_enable {
  187. DEV_ENABLED,
  188. DEV_DISABLED,
  189. DEV_RECOVER,
  190. };
  191. enum cl_kernels {
  192. KL_NONE,
  193. KL_POCLBM,
  194. KL_PHATK,
  195. KL_DIAKGCN,
  196. KL_DIABLO,
  197. };
  198. enum dev_reason {
  199. REASON_THREAD_FAIL_INIT,
  200. REASON_THREAD_ZERO_HASH,
  201. REASON_THREAD_FAIL_QUEUE,
  202. REASON_DEV_SICK_IDLE_60,
  203. REASON_DEV_DEAD_IDLE_600,
  204. REASON_DEV_NOSTART,
  205. REASON_DEV_OVER_HEAT,
  206. REASON_DEV_THERMAL_CUTOFF,
  207. };
  208. #define REASON_NONE "None"
  209. #define REASON_THREAD_FAIL_INIT_STR "Thread failed to init"
  210. #define REASON_THREAD_ZERO_HASH_STR "Thread got zero hashes"
  211. #define REASON_THREAD_FAIL_QUEUE_STR "Thread failed to queue work"
  212. #define REASON_DEV_SICK_IDLE_60_STR "Device idle for 60s"
  213. #define REASON_DEV_DEAD_IDLE_600_STR "Device dead - idle for 600s"
  214. #define REASON_DEV_NOSTART_STR "Device failed to start"
  215. #define REASON_DEV_OVER_HEAT_STR "Device over heated"
  216. #define REASON_DEV_THERMAL_CUTOFF_STR "Device reached thermal cutoff"
  217. #define REASON_UNKNOWN_STR "Unknown reason - code bug"
  218. struct cgpu_info {
  219. int cgminer_id;
  220. struct device_api *api;
  221. int device_id;
  222. char *name;
  223. char *device_path;
  224. FILE *device_file;
  225. union {
  226. #ifdef USE_ZTEX
  227. struct libztex_device *device_ztex;
  228. #endif
  229. int device_fd;
  230. };
  231. enum dev_enable deven;
  232. int accepted;
  233. int rejected;
  234. int hw_errors;
  235. double rolling;
  236. double total_mhashes;
  237. double utility;
  238. enum alive status;
  239. char init[40];
  240. struct timeval last_message_tv;
  241. int threads;
  242. struct thr_info *thread;
  243. unsigned int max_hashes;
  244. bool mapped;
  245. int virtual_gpu;
  246. int virtual_adl;
  247. int intensity;
  248. bool dynamic;
  249. char *kname;
  250. #ifdef HAVE_OPENCL
  251. cl_uint vwidth;
  252. size_t work_size;
  253. enum cl_kernels kernel;
  254. #endif
  255. float temp;
  256. int cutofftemp;
  257. #ifdef HAVE_ADL
  258. bool has_adl;
  259. struct gpu_adl adl;
  260. int gpu_engine;
  261. int min_engine;
  262. int gpu_fan;
  263. int min_fan;
  264. int gpu_memclock;
  265. int gpu_memdiff;
  266. int gpu_powertune;
  267. float gpu_vddc;
  268. #endif
  269. int last_share_pool;
  270. time_t last_share_pool_time;
  271. time_t device_last_well;
  272. time_t device_last_not_well;
  273. enum dev_reason device_not_well_reason;
  274. int thread_fail_init_count;
  275. int thread_zero_hash_count;
  276. int thread_fail_queue_count;
  277. int dev_sick_idle_60_count;
  278. int dev_dead_idle_600_count;
  279. int dev_nostart_count;
  280. int dev_over_heat_count; // It's a warning but worth knowing
  281. int dev_thermal_cutoff_count;
  282. };
  283. extern bool add_cgpu(struct cgpu_info*);
  284. struct thread_q {
  285. struct list_head q;
  286. bool frozen;
  287. pthread_mutex_t mutex;
  288. pthread_cond_t cond;
  289. };
  290. struct thr_info {
  291. int id;
  292. int device_thread;
  293. pthread_t pth;
  294. struct thread_q *q;
  295. struct cgpu_info *cgpu;
  296. void *cgpu_data;
  297. struct timeval last;
  298. struct timeval sick;
  299. bool pause;
  300. bool getwork;
  301. double rolling;
  302. };
  303. extern int thr_info_create(struct thr_info *thr, pthread_attr_t *attr, void *(*start) (void *), void *arg);
  304. extern void thr_info_cancel(struct thr_info *thr);
  305. extern void thr_info_freeze(struct thr_info *thr);
  306. struct string_elist {
  307. char *string;
  308. bool free_me;
  309. struct list_head list;
  310. };
  311. static inline void string_elist_add(const char *s, struct list_head *head)
  312. {
  313. struct string_elist *n;
  314. n = calloc(1, sizeof(*n));
  315. n->string = strdup(s);
  316. n->free_me = true;
  317. list_add_tail(&n->list, head);
  318. }
  319. static inline void string_elist_del(struct string_elist *item)
  320. {
  321. if (item->free_me)
  322. free(item->string);
  323. list_del(&item->list);
  324. }
  325. static inline uint32_t swab32(uint32_t v)
  326. {
  327. return bswap_32(v);
  328. }
  329. static inline void swap256(void *dest_p, const void *src_p)
  330. {
  331. uint32_t *dest = dest_p;
  332. const uint32_t *src = src_p;
  333. dest[0] = src[7];
  334. dest[1] = src[6];
  335. dest[2] = src[5];
  336. dest[3] = src[4];
  337. dest[4] = src[3];
  338. dest[5] = src[2];
  339. dest[6] = src[1];
  340. dest[7] = src[0];
  341. }
  342. extern void quit(int status, const char *format, ...);
  343. static inline void mutex_lock(pthread_mutex_t *lock)
  344. {
  345. if (unlikely(pthread_mutex_lock(lock)))
  346. quit(1, "WTF MUTEX ERROR ON LOCK!");
  347. }
  348. static inline void mutex_unlock(pthread_mutex_t *lock)
  349. {
  350. if (unlikely(pthread_mutex_unlock(lock)))
  351. quit(1, "WTF MUTEX ERROR ON UNLOCK!");
  352. }
  353. static inline void wr_lock(pthread_rwlock_t *lock)
  354. {
  355. if (unlikely(pthread_rwlock_wrlock(lock)))
  356. quit(1, "WTF WRLOCK ERROR ON LOCK!");
  357. }
  358. static inline void rd_lock(pthread_rwlock_t *lock)
  359. {
  360. if (unlikely(pthread_rwlock_rdlock(lock)))
  361. quit(1, "WTF RDLOCK ERROR ON LOCK!");
  362. }
  363. static inline void rw_unlock(pthread_rwlock_t *lock)
  364. {
  365. if (unlikely(pthread_rwlock_unlock(lock)))
  366. quit(1, "WTF RWLOCK ERROR ON UNLOCK!");
  367. }
  368. static inline void rd_unlock(pthread_rwlock_t *lock)
  369. {
  370. rw_unlock(lock);
  371. }
  372. static inline void wr_unlock(pthread_rwlock_t *lock)
  373. {
  374. rw_unlock(lock);
  375. }
  376. static inline void mutex_init(pthread_mutex_t *lock)
  377. {
  378. if (unlikely(pthread_mutex_init(lock, NULL)))
  379. quit(1, "Failed to pthread_mutex_init");
  380. }
  381. static inline void rwlock_init(pthread_rwlock_t *lock)
  382. {
  383. if (unlikely(pthread_rwlock_init(lock, NULL)))
  384. quit(1, "Failed to pthread_rwlock_init");
  385. }
  386. struct pool;
  387. extern bool opt_protocol;
  388. extern char *opt_kernel_path;
  389. extern char *opt_socks_proxy;
  390. extern char *cgminer_path;
  391. extern bool opt_autofan;
  392. extern bool opt_autoengine;
  393. extern bool use_curses;
  394. extern char *opt_api_allow;
  395. extern char *opt_api_description;
  396. extern int opt_api_port;
  397. extern bool opt_api_listen;
  398. extern bool opt_api_network;
  399. extern bool opt_delaynet;
  400. extern bool opt_restart;
  401. extern pthread_rwlock_t netacc_lock;
  402. extern const uint32_t sha256_init_state[];
  403. extern json_t *json_rpc_call(CURL *curl, const char *url, const char *userpass,
  404. const char *rpc_req, bool, bool, bool *,
  405. struct pool *pool, bool);
  406. extern char *bin2hex(const unsigned char *p, size_t len);
  407. extern bool hex2bin(unsigned char *p, const char *hexstr, size_t len);
  408. typedef bool (*sha256_func)(int thr_id, const unsigned char *pmidstate,
  409. unsigned char *pdata,
  410. unsigned char *phash1, unsigned char *phash,
  411. const unsigned char *ptarget,
  412. uint32_t max_nonce,
  413. uint32_t *last_nonce,
  414. uint32_t nonce);
  415. extern int
  416. timeval_subtract (struct timeval *result, struct timeval *x, struct timeval *y);
  417. extern bool fulltest(const unsigned char *hash, const unsigned char *target);
  418. extern int opt_scantime;
  419. struct work_restart {
  420. volatile unsigned long restart;
  421. char padding[128 - sizeof(unsigned long)];
  422. };
  423. extern void thread_reportin(struct thr_info *thr);
  424. extern void kill_work(void);
  425. extern void reinit_device(struct cgpu_info *cgpu);
  426. #ifdef HAVE_ADL
  427. extern bool gpu_stats(int gpu, float *temp, int *engineclock, int *memclock, float *vddc, int *activity, int *fanspeed, int *fanpercent, int *powertune);
  428. extern int set_fanspeed(int gpu, int iFanSpeed);
  429. extern int set_vddc(int gpu, float fVddc);
  430. extern int set_engineclock(int gpu, int iEngineClock);
  431. extern int set_memoryclock(int gpu, int iMemoryClock);
  432. #endif
  433. extern void api(int thr_id);
  434. extern struct pool *current_pool(void);
  435. extern int active_pools(void);
  436. extern int add_pool_details(bool live, char *url, char *user, char *pass);
  437. #define ADD_POOL_MAXIMUM 1
  438. #define ADD_POOL_OK 0
  439. #define MAX_GPUDEVICES 16
  440. #define MAX_DEVICES 64
  441. #define MAX_POOLS (32)
  442. #define MIN_INTENSITY -10
  443. #define _MIN_INTENSITY_STR "-10"
  444. #define MAX_INTENSITY 14
  445. #define _MAX_INTENSITY_STR "14"
  446. extern struct list_head scan_devices;
  447. extern int nDevs;
  448. extern int opt_n_threads;
  449. extern int num_processors;
  450. extern int hw_errors;
  451. extern bool use_syslog;
  452. extern struct thr_info *thr_info;
  453. extern int longpoll_thr_id;
  454. extern struct work_restart *work_restart;
  455. extern struct cgpu_info gpus[MAX_GPUDEVICES];
  456. extern int gpu_threads;
  457. extern double total_secs;
  458. extern int mining_threads;
  459. extern struct cgpu_info *cpus;
  460. extern int total_devices;
  461. extern struct cgpu_info *devices[];
  462. extern int total_pools;
  463. extern struct pool *pools[MAX_POOLS];
  464. extern const char *algo_names[];
  465. extern enum sha256_algos opt_algo;
  466. extern struct strategies strategies[];
  467. extern enum pool_strategy pool_strategy;
  468. extern int opt_rotate_period;
  469. extern double total_mhashes_done;
  470. extern unsigned int new_blocks;
  471. extern unsigned int found_blocks;
  472. extern int total_accepted, total_rejected;
  473. extern int total_getworks, total_stale, total_discarded;
  474. extern unsigned int local_work;
  475. extern unsigned int total_go, total_ro;
  476. extern const int opt_cutofftemp;
  477. extern int opt_log_interval;
  478. #ifdef HAVE_OPENCL
  479. typedef struct {
  480. cl_uint ctx_a; cl_uint ctx_b; cl_uint ctx_c; cl_uint ctx_d;
  481. cl_uint ctx_e; cl_uint ctx_f; cl_uint ctx_g; cl_uint ctx_h;
  482. cl_uint cty_a; cl_uint cty_b; cl_uint cty_c; cl_uint cty_d;
  483. cl_uint cty_e; cl_uint cty_f; cl_uint cty_g; cl_uint cty_h;
  484. cl_uint merkle; cl_uint ntime; cl_uint nbits; cl_uint nonce;
  485. cl_uint fW0; cl_uint fW1; cl_uint fW2; cl_uint fW3; cl_uint fW15;
  486. cl_uint fW01r; cl_uint fcty_e; cl_uint fcty_e2;
  487. cl_uint W16; cl_uint W17; cl_uint W2;
  488. cl_uint PreVal4; cl_uint T1;
  489. cl_uint C1addK5; cl_uint D1A; cl_uint W2A; cl_uint W17_2;
  490. cl_uint PreVal4addT1; cl_uint T1substate0;
  491. cl_uint PreVal4_2;
  492. cl_uint PreVal0;
  493. cl_uint PreW18;
  494. cl_uint PreW19;
  495. cl_uint PreW31;
  496. cl_uint PreW32;
  497. /* For diakgcn */
  498. cl_uint B1addK6, PreVal0addK7, W16addK16, W17addK17;
  499. cl_uint zeroA, zeroB;
  500. cl_uint oneA, twoA, threeA, fourA, fiveA, sixA, sevenA;
  501. } dev_blk_ctx;
  502. #else
  503. typedef struct {
  504. uint32_t nonce;
  505. } dev_blk_ctx;
  506. #endif
  507. struct pool {
  508. int pool_no;
  509. int prio;
  510. int accepted, rejected;
  511. bool submit_fail;
  512. bool idle;
  513. bool lagging;
  514. bool probed;
  515. bool enabled;
  516. bool submit_old;
  517. char *hdr_path;
  518. char *lp_url;
  519. bool lp_sent;
  520. bool is_lp;
  521. unsigned int getwork_requested;
  522. unsigned int stale_shares;
  523. unsigned int discarded_work;
  524. unsigned int getfail_occasions;
  525. unsigned int remotefail_occasions;
  526. struct timeval tv_idle;
  527. char *rpc_url;
  528. char *rpc_userpass;
  529. char *rpc_user, *rpc_pass;
  530. pthread_mutex_t pool_lock;
  531. };
  532. struct work {
  533. unsigned char data[128];
  534. unsigned char hash1[64];
  535. unsigned char midstate[32];
  536. unsigned char target[32];
  537. unsigned char hash[32];
  538. int rolls;
  539. uint32_t output[1];
  540. uint32_t valid;
  541. dev_blk_ctx blk;
  542. struct thr_info *thr;
  543. int thr_id;
  544. struct pool *pool;
  545. struct timeval tv_staged;
  546. bool mined;
  547. bool clone;
  548. bool cloned;
  549. bool rolltime;
  550. bool longpoll;
  551. unsigned int work_block;
  552. int id;
  553. UT_hash_handle hh;
  554. time_t share_found_time;
  555. };
  556. extern void get_datestamp(char *, struct timeval *);
  557. bool submit_nonce(struct thr_info *thr, struct work *work, uint32_t nonce);
  558. extern void tailsprintf(char *f, const char *fmt, ...);
  559. extern void wlogprint(const char *f, ...);
  560. extern int curses_int(const char *query);
  561. extern char *curses_input(const char *query);
  562. extern void kill_work(void);
  563. extern void switch_pools(struct pool *selected);
  564. extern void remove_pool(struct pool *pool);
  565. extern void write_config(FILE *fcfg);
  566. extern void log_curses(int prio, const char *f, va_list ap);
  567. extern void clear_logwin(void);
  568. extern bool pool_tclear(struct pool *pool, bool *var);
  569. extern struct thread_q *tq_new(void);
  570. extern void tq_free(struct thread_q *tq);
  571. extern bool tq_push(struct thread_q *tq, void *data);
  572. extern void *tq_pop(struct thread_q *tq, const struct timespec *abstime);
  573. extern void tq_freeze(struct thread_q *tq);
  574. extern void tq_thaw(struct thread_q *tq);
  575. extern bool successful_connect;
  576. extern void adl(void);
  577. extern void app_restart(void);
  578. #endif /* __MINER_H__ */