gc3355.c 11 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377378379380381382383384385386387388389390391392393394395396397398399400401402403404405406407408409410411412413414415416417418419420421422423424425426427428429430431432433434435436437438439440441442443444445446447448449450451452453454455456457458459460461462463464465466467468469470471472473474475476477478479480481482483484485486487488489490491492493494495496497498499500501502503504505506507508509510511512513514515516517518519520521522523524525526527528529530531532533534535536537538539540541542543544545546547548549550551552553554555556557558559560561562563564565566567568569570571572573574575576577578579580581582583584585586587588589590591592593594595596597598599600601602603604605606607608609610611612613614615616617618619620621622623624625626627628629630631632633634635636637638639640641642643644645646647648649650651652
  1. /*
  2. * Copyright 2014 Nate Woolls
  3. * Copyright 2014 Dualminer Team
  4. *
  5. * This program is free software; you can redistribute it and/or modify it
  6. * under the terms of the GNU General Public License as published by the Free
  7. * Software Foundation; either version 3 of the License, or (at your option)
  8. * any later version. See COPYING for more details.
  9. */
  10. #include "gc3355.h"
  11. #include <string.h>
  12. #include "miner.h"
  13. #include "driver-icarus.h"
  14. #include "logging.h"
  15. #include "lowl-vcom.h"
  16. #ifndef WIN32
  17. #include <sys/ioctl.h>
  18. #else
  19. #include <io.h>
  20. #endif
  21. #define DEFAULT_DELAY_TIME 2000
  22. #define HUBFANS_0_9V_sha2 "60"
  23. #define HUBFANS_1_2V_sha2 "0"
  24. #define DEFAULT_0_9V_sha2 "60"
  25. #define DEFAULT_1_2V_sha2 "0"
  26. static
  27. const char *pll_freq_1200M_cmd[] =
  28. {
  29. "55AAEF000500E085",
  30. "55AA0FFFB02800C0",
  31. "",
  32. };
  33. static
  34. const char *pll_freq_1100M_cmd[] =
  35. {
  36. "55AAEF0005006085",
  37. "55AA0FFF4C2500C0",
  38. "",
  39. };
  40. static
  41. const char *pll_freq_1000M_cmd[] =
  42. {
  43. "55AAEF000500E084",
  44. "55AA0FFFE82100C0",
  45. "",
  46. };
  47. static
  48. const char *pll_freq_950M_cmd[] =
  49. {
  50. "55AAEF000500A084",
  51. "55AA0FFF362000C0",
  52. "",
  53. };
  54. static
  55. const char *pll_freq_900M_cmd[] =
  56. {
  57. "55AAEF0005006084",
  58. "55AA0FFF841E00C0",
  59. "",
  60. };
  61. static
  62. const char *pll_freq_850M_cmd[] =
  63. {
  64. "55AAEF0005002084",
  65. "55AA0FFFD21C00C0",
  66. "",
  67. };
  68. static
  69. const char *pll_freq_800M_cmd[] =
  70. {
  71. "55AAEF000500E083",
  72. "55AA0FFF201B00C0",
  73. "",
  74. };
  75. static
  76. const char *pll_freq_750M_cmd[] =
  77. {
  78. "55AAEF000500A083",
  79. "55AA0FFF6E1900C0",
  80. "",
  81. };
  82. static
  83. const char *pll_freq_700M_cmd[] =
  84. {
  85. "55AAEF0005006083",
  86. "55AA0FFFBC1700C0",
  87. "",
  88. };
  89. static
  90. const char *pll_freq_650M_cmd[] =
  91. {
  92. "55AAEF0005002083",
  93. "55AA0FFF0A1600C0",
  94. "",
  95. };
  96. static
  97. const char *pll_freq_600M_cmd[] =
  98. {
  99. "55AAEF000500E082",
  100. "55AA0FFF581400C0",
  101. "",
  102. };
  103. static
  104. const char *pll_freq_550M_cmd[] =
  105. {
  106. "55AAEF000500A082",
  107. "55AA0FFFA61200C0",
  108. "",
  109. };
  110. static
  111. const char *pll_freq_500M_cmd[] =
  112. {
  113. "55AAEF0005006082",
  114. "55AA0FFFF41000C0",
  115. "",
  116. };
  117. static
  118. const char *pll_freq_400M_cmd[] =
  119. {
  120. "55AAEF000500E081",
  121. "55AA0FFF900D00C0",
  122. "",
  123. };
  124. static
  125. const char *sha2_gating[] =
  126. {
  127. "55AAEF0200000000",
  128. "55AAEF0300000000",
  129. "55AAEF0400000000",
  130. "55AAEF0500000000",
  131. "55AAEF0600000000",
  132. "",
  133. };
  134. static
  135. const char *sha2_single_open[] =
  136. {
  137. "55AAEF0200000001",
  138. "55AAEF0200000003",
  139. "55AAEF0200000007",
  140. "55AAEF020000000F",
  141. "55AAEF020000001F",
  142. "55AAEF020000003F",
  143. "55AAEF020000007F",
  144. "55AAEF02000000FF",
  145. "55AAEF02000001FF",
  146. "55AAEF02000003FF",
  147. "55AAEF02000007FF",
  148. "55AAEF0200000FFF",
  149. "55AAEF0200001FFF",
  150. "55AAEF0200003FFF",
  151. "55AAEF0200007FFF",
  152. "55AAEF020000FFFF",
  153. "55AAEF020001FFFF",
  154. "55AAEF020003FFFF",
  155. "55AAEF020007FFFF",
  156. "55AAEF02000FFFFF",
  157. "55AAEF02001FFFFF",
  158. "55AAEF02003FFFFF",
  159. "55AAEF02007FFFFF",
  160. "55AAEF0200FFFFFF",
  161. "55AAEF0201FFFFFF",
  162. "55AAEF0203FFFFFF",
  163. "55AAEF0207FFFFFF",
  164. "55AAEF020FFFFFFF",
  165. "55AAEF021FFFFFFF",
  166. "55AAEF023FFFFFFF",
  167. "55AAEF027FFFFFFF",
  168. "55AAEF02FFFFFFFF",
  169. "55AAEF0300000001",
  170. "55AAEF0300000003",
  171. "55AAEF0300000007",
  172. "55AAEF030000000F",
  173. "55AAEF030000001F",
  174. "55AAEF030000003F",
  175. "55AAEF030000007F",
  176. "55AAEF03000000FF",
  177. "55AAEF03000001FF",
  178. "55AAEF03000003FF",
  179. "55AAEF03000007FF",
  180. "55AAEF0300000FFF",
  181. "55AAEF0300001FFF",
  182. "55AAEF0300003FFF",
  183. "55AAEF0300007FFF",
  184. "55AAEF030000FFFF",
  185. "55AAEF030001FFFF",
  186. "55AAEF030003FFFF",
  187. "55AAEF030007FFFF",
  188. "55AAEF03000FFFFF",
  189. "55AAEF03001FFFFF",
  190. "55AAEF03003FFFFF",
  191. "55AAEF03007FFFFF",
  192. "55AAEF0300FFFFFF",
  193. "55AAEF0301FFFFFF",
  194. "55AAEF0303FFFFFF",
  195. "55AAEF0307FFFFFF",
  196. "55AAEF030FFFFFFF",
  197. "55AAEF031FFFFFFF",
  198. "55AAEF033FFFFFFF",
  199. "55AAEF037FFFFFFF",
  200. "55AAEF03FFFFFFFF",
  201. "55AAEF0400000001",
  202. "55AAEF0400000003",
  203. "55AAEF0400000007",
  204. "55AAEF040000000F",
  205. "55AAEF040000001F",
  206. "55AAEF040000003F",
  207. "55AAEF040000007F",
  208. "55AAEF04000000FF",
  209. "55AAEF04000001FF",
  210. "55AAEF04000003FF",
  211. "55AAEF04000007FF",
  212. "55AAEF0400000FFF",
  213. "55AAEF0400001FFF",
  214. "55AAEF0400003FFF",
  215. "55AAEF0400007FFF",
  216. "55AAEF040000FFFF",
  217. "55AAEF040001FFFF",
  218. "55AAEF040003FFFF",
  219. "55AAEF040007FFFF",
  220. "55AAEF04000FFFFF",
  221. "55AAEF04001FFFFF",
  222. "55AAEF04003FFFFF",
  223. "55AAEF04007FFFFF",
  224. "55AAEF0400FFFFFF",
  225. "55AAEF0401FFFFFF",
  226. "55AAEF0403FFFFFF",
  227. "55AAEF0407FFFFFF",
  228. "55AAEF040FFFFFFF",
  229. "55AAEF041FFFFFFF",
  230. "55AAEF043FFFFFFF",
  231. "55AAEF047FFFFFFF",
  232. "55AAEF04FFFFFFFF",
  233. "55AAEF0500000001",
  234. "55AAEF0500000003",
  235. "55AAEF0500000007",
  236. "55AAEF050000000F",
  237. "55AAEF050000001F",
  238. "55AAEF050000003F",
  239. "55AAEF050000007F",
  240. "55AAEF05000000FF",
  241. "55AAEF05000001FF",
  242. "55AAEF05000003FF",
  243. "55AAEF05000007FF",
  244. "55AAEF0500000FFF",
  245. "55AAEF0500001FFF",
  246. "55AAEF0500003FFF",
  247. "55AAEF0500007FFF",
  248. "55AAEF050000FFFF",
  249. "55AAEF050001FFFF",
  250. "55AAEF050003FFFF",
  251. "55AAEF050007FFFF",
  252. "55AAEF05000FFFFF",
  253. "55AAEF05001FFFFF",
  254. "55AAEF05003FFFFF",
  255. "55AAEF05007FFFFF",
  256. "55AAEF0500FFFFFF",
  257. "55AAEF0501FFFFFF",
  258. "55AAEF0503FFFFFF",
  259. "55AAEF0507FFFFFF",
  260. "55AAEF050FFFFFFF",
  261. "55AAEF051FFFFFFF",
  262. "55AAEF053FFFFFFF",
  263. "55AAEF057FFFFFFF",
  264. "55AAEF05FFFFFFFF",
  265. "55AAEF0600000001",
  266. "55AAEF0600000003",
  267. "55AAEF0600000007",
  268. "55AAEF060000000F",
  269. "55AAEF060000001F",
  270. "55AAEF060000003F",
  271. "55AAEF060000007F",
  272. "55AAEF06000000FF",
  273. "55AAEF06000001FF",
  274. "55AAEF06000003FF",
  275. "55AAEF06000007FF",
  276. "55AAEF0600000FFF",
  277. "55AAEF0600001FFF",
  278. "55AAEF0600003FFF",
  279. "55AAEF0600007FFF",
  280. "55AAEF060000FFFF",
  281. "55AAEF060001FFFF",
  282. "55AAEF060003FFFF",
  283. "55AAEF060007FFFF",
  284. "55AAEF06000FFFFF",
  285. "55AAEF06001FFFFF",
  286. "55AAEF06003FFFFF",
  287. "55AAEF06007FFFFF",
  288. "55AAEF0600FFFFFF",
  289. "55AAEF0601FFFFFF",
  290. "55AAEF0603FFFFFF",
  291. "55AAEF0607FFFFFF",
  292. "55AAEF060FFFFFFF",
  293. "55AAEF061FFFFFFF",
  294. "55AAEF063FFFFFFF",
  295. "55AAEF067FFFFFFF",
  296. "55AAEF06FFFFFFFF",
  297. "",
  298. };
  299. static
  300. const char *scrypt_only_init[] =
  301. {
  302. "55AAEF0200000000",
  303. "55AAEF0300000000",
  304. "55AAEF0400000000",
  305. "55AAEF0500000000",
  306. "55AAEF0600000000",
  307. "55AAEF3040000000",
  308. "55AA1F2810000000",
  309. "55AA1F2813000000",
  310. "",
  311. };
  312. char *opt_dualminer_sha2_gating = NULL;
  313. int opt_pll_freq = 0; // default is set in gc3355_pll_freq_init2
  314. int opt_sha2_number = 160;
  315. bool opt_hubfans = false;
  316. bool opt_dual_mode = false;
  317. void gc3355_dual_reset(int fd)
  318. {
  319. set_serial_dtr(fd, 1);
  320. cgsleep_ms(1000);
  321. set_serial_dtr(fd, 0);
  322. }
  323. static
  324. void gc3355_send_cmds(int fd, const char *cmds[])
  325. {
  326. int i = 0;
  327. unsigned char ob_bin[32];
  328. for(i = 0 ;; i++)
  329. {
  330. memset(ob_bin, 0, sizeof(ob_bin));
  331. if (cmds[i][0] == 0)
  332. break;
  333. hex2bin(ob_bin, cmds[i], strlen(cmds[i]) / 2);
  334. icarus_write(fd, ob_bin, 8);
  335. usleep(DEFAULT_DELAY_TIME);
  336. }
  337. }
  338. void gc3355_opt_scrypt_init(int fd)
  339. {
  340. const char *initscrypt_ob[] =
  341. {
  342. "55AA1F2810000000",
  343. "55AA1F2813000000",
  344. ""
  345. };
  346. gc3355_send_cmds(fd, initscrypt_ob);
  347. }
  348. static
  349. void gc3355_pll_freq_init2(int fd, int pll_freq)
  350. {
  351. switch(pll_freq)
  352. {
  353. case 400:
  354. {
  355. gc3355_send_cmds(fd, pll_freq_400M_cmd);
  356. break;
  357. }
  358. case 500:
  359. {
  360. gc3355_send_cmds(fd, pll_freq_500M_cmd);
  361. break;
  362. }
  363. case 550:
  364. {
  365. gc3355_send_cmds(fd, pll_freq_550M_cmd);
  366. break;
  367. }
  368. case 600:
  369. {
  370. gc3355_send_cmds(fd, pll_freq_600M_cmd);
  371. break;
  372. }
  373. case 650:
  374. {
  375. gc3355_send_cmds(fd, pll_freq_650M_cmd);
  376. break;
  377. }
  378. case 700:
  379. {
  380. gc3355_send_cmds(fd, pll_freq_700M_cmd);
  381. break;
  382. }
  383. case 750:
  384. {
  385. gc3355_send_cmds(fd, pll_freq_750M_cmd);
  386. break;
  387. }
  388. case 800:
  389. {
  390. gc3355_send_cmds(fd, pll_freq_800M_cmd);
  391. break;
  392. }
  393. case 850:
  394. {
  395. gc3355_send_cmds(fd, pll_freq_850M_cmd);
  396. break;
  397. }
  398. case 900:
  399. {
  400. gc3355_send_cmds(fd, pll_freq_900M_cmd);
  401. break;
  402. }
  403. case 950:
  404. {
  405. gc3355_send_cmds(fd, pll_freq_950M_cmd);
  406. break;
  407. }
  408. case 1000:
  409. {
  410. gc3355_send_cmds(fd, pll_freq_1000M_cmd);
  411. break;
  412. }
  413. case 1100:
  414. {
  415. gc3355_send_cmds(fd, pll_freq_1100M_cmd);
  416. break;
  417. }
  418. case 1200:
  419. {
  420. gc3355_send_cmds(fd, pll_freq_1200M_cmd);
  421. break;
  422. }
  423. default:
  424. {
  425. if (gc3355_get_cts_status(fd) == 1)
  426. //1.2v - Scrypt mode
  427. gc3355_send_cmds(fd, pll_freq_850M_cmd);
  428. else
  429. //0.9v - Scrypt + SHA mode
  430. gc3355_send_cmds(fd, pll_freq_550M_cmd);
  431. }
  432. }
  433. }
  434. void gc3355_open_sha2_unit(int fd, char *opt_sha2_gating)
  435. {
  436. unsigned char ob_bin[8];
  437. int i;
  438. //---sha2 unit---
  439. char sha2_gating[5][17] =
  440. {
  441. "55AAEF0200000000",
  442. "55AAEF0300000000",
  443. "55AAEF0400000000",
  444. "55AAEF0500000000",
  445. "55AAEF0600000000",
  446. };
  447. union
  448. {
  449. unsigned int i32[5];
  450. unsigned char c8[20] ;
  451. }sha2_group;
  452. int sha2_number=0;
  453. if (opt_sha2_gating== NULL)
  454. sha2_number = 70;
  455. else
  456. {
  457. if (atoi(opt_sha2_gating) <= 160 && atoi(opt_sha2_gating) >= 0)
  458. sha2_number = atoi(opt_sha2_gating);
  459. else
  460. sha2_number = 70;
  461. }
  462. for(i = 0; i < 5; i++)
  463. sha2_group.i32[i] = 0;
  464. for(i = 0; i < sha2_number; i++)
  465. sha2_group.i32[i / 32] += 1 << ( i % 32);
  466. for(i = 0; i < 20; i++)
  467. sprintf(&sha2_gating[i / 4][8 + (i % 4) * 2], "%02x", sha2_group.c8[i]);
  468. //---sha2 unit end---
  469. for(i = 0; i < 5; i++)
  470. {
  471. if (sha2_gating[i][0] == '\0')
  472. break;
  473. hex2bin(ob_bin, sha2_gating[i], sizeof(ob_bin));
  474. icarus_write(fd, ob_bin, 8);
  475. usleep(DEFAULT_DELAY_TIME);
  476. }
  477. opt_sha2_number = sha2_number;
  478. }
  479. static
  480. void gc3355_open_sha2_unit_one_by_one(int fd, char *opt_sha2_gating)
  481. {
  482. int unit_count = 0;
  483. unsigned char ob_bin[8];
  484. int i;
  485. unit_count = atoi(opt_sha2_gating);
  486. if (unit_count < 0)
  487. unit_count = 0;
  488. if (unit_count > 160)
  489. unit_count = 160;
  490. if (unit_count > 0 && unit_count <= 160)
  491. {
  492. for(i = 0; i <= unit_count; i++)
  493. {
  494. hex2bin(ob_bin, sha2_single_open[i], sizeof(ob_bin));
  495. icarus_write(fd, ob_bin, 8);
  496. usleep(DEFAULT_DELAY_TIME * 2);
  497. }
  498. opt_sha2_number = unit_count;
  499. }
  500. else if (unit_count == 0)
  501. gc3355_send_cmds(fd, sha2_gating);
  502. }
  503. void gc3355_opt_scrypt_only_init(int fd)
  504. {
  505. gc3355_send_cmds(fd, scrypt_only_init);
  506. gc3355_pll_freq_init2(fd, opt_pll_freq);
  507. }
  508. void gc3355_open_scrypt_unit(int fd, int status)
  509. {
  510. const char *scrypt_only_ob[] =
  511. {
  512. "55AA1F2810000000",
  513. "",
  514. };
  515. const char *scrypt_ob[] =
  516. {
  517. "55AA1F2814000000",
  518. "",
  519. };
  520. if (status == SCRYPT_UNIT_OPEN)
  521. {
  522. if (opt_dual_mode)
  523. gc3355_opt_scrypt_init(fd);
  524. else
  525. gc3355_opt_scrypt_only_init(fd);
  526. }
  527. else
  528. {
  529. if (opt_dual_mode)
  530. gc3355_send_cmds(fd, scrypt_ob);
  531. else
  532. gc3355_send_cmds(fd, scrypt_only_ob);
  533. }
  534. }
  535. void gc3355_dualminer_init(int fd)
  536. {
  537. const char *init_ob[] =
  538. {
  539. #if 1
  540. "55AAEF0200000000",
  541. "55AAEF0300000000",
  542. "55AAEF0400000000",
  543. "55AAEF0500000000",
  544. "55AAEF0600000000",
  545. #endif
  546. "55AAEF3020000000",
  547. "55AA1F2817000000",
  548. ""
  549. };
  550. const char *initscrypt_ob[] =
  551. {
  552. "55AA1F2814000000",
  553. "55AA1F2817000000",
  554. ""
  555. };
  556. if (opt_scrypt)
  557. gc3355_send_cmds(fd, initscrypt_ob);
  558. else
  559. gc3355_send_cmds(fd, init_ob);
  560. if (!opt_scrypt)
  561. gc3355_pll_freq_init2(fd, opt_pll_freq);
  562. }
  563. void gc3355_init(int fd, char *sha2_unit, bool is_scrypt_only)
  564. {
  565. if (gc3355_get_cts_status(fd) == 1)
  566. {
  567. //1.2v - Scrypt mode
  568. if (opt_scrypt)
  569. {
  570. if (is_scrypt_only)
  571. gc3355_opt_scrypt_only_init(fd);
  572. }
  573. else
  574. {
  575. if (opt_hubfans)
  576. ((sha2_unit == NULL) ? gc3355_open_sha2_unit_one_by_one(fd, HUBFANS_1_2V_sha2) : gc3355_open_sha2_unit_one_by_one(fd, sha2_unit));
  577. else
  578. ((sha2_unit == NULL) ? gc3355_open_sha2_unit_one_by_one(fd, DEFAULT_1_2V_sha2) : gc3355_open_sha2_unit_one_by_one(fd, sha2_unit));
  579. }
  580. }
  581. else
  582. {
  583. //0.9v - Scrypt + SHA mode
  584. if (opt_scrypt)
  585. {
  586. if (is_scrypt_only)
  587. gc3355_opt_scrypt_only_init(fd);
  588. }
  589. else
  590. {
  591. if (opt_hubfans)
  592. ((sha2_unit == NULL) ? gc3355_open_sha2_unit_one_by_one(fd, HUBFANS_0_9V_sha2) : gc3355_open_sha2_unit_one_by_one(fd, sha2_unit));
  593. else
  594. ((sha2_unit == NULL) ? gc3355_open_sha2_unit_one_by_one(fd, DEFAULT_0_9V_sha2) : gc3355_open_sha2_unit_one_by_one(fd, sha2_unit));
  595. }
  596. }
  597. }