driver-erupter.c 2.6 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104
  1. /*
  2. * Copyright 2013 Luke Dashjr
  3. *
  4. * This program is free software; you can redistribute it and/or modify it
  5. * under the terms of the GNU General Public License as published by the Free
  6. * Software Foundation; either version 3 of the License, or (at your option)
  7. * any later version. See COPYING for more details.
  8. */
  9. #include "config.h"
  10. #include "miner.h"
  11. #include "fpgautils.h"
  12. #include "icarus-common.h"
  13. #define ERUPTER_IO_SPEED 115200
  14. #define ERUPTER_HASH_TIME 0.0000000029761
  15. extern struct device_drv erupter_drv;
  16. extern struct device_drv erupter_drv_emerald;
  17. static bool _erupter_detect_one(const char *devpath, struct device_drv *drv)
  18. {
  19. struct ICARUS_INFO *info = calloc(1, sizeof(struct ICARUS_INFO));
  20. if (unlikely(!info))
  21. quit(1, "Failed to malloc ICARUS_INFO");
  22. *info = (struct ICARUS_INFO){
  23. .baud = ERUPTER_IO_SPEED,
  24. .Hs = ERUPTER_HASH_TIME,
  25. .timing_mode = MODE_DEFAULT,
  26. .continue_search = true,
  27. };
  28. if (!icarus_detect_custom(devpath, drv, info)) {
  29. free(info);
  30. return false;
  31. }
  32. return true;
  33. }
  34. static bool erupter_emerald_detect_one(const char *devpath)
  35. {
  36. // For detection via BEE:*
  37. return _erupter_detect_one(devpath, &erupter_drv_emerald);
  38. }
  39. static bool erupter_detect_one(const char *devpath)
  40. {
  41. struct device_drv *drv = &erupter_drv;
  42. // For autodetection
  43. if (unlikely(detectone_meta_info.product && strstr(detectone_meta_info.product, "Emerald")))
  44. drv = &erupter_drv_emerald;
  45. return _erupter_detect_one(devpath, drv);
  46. }
  47. static int erupter_emerald_detect_auto(void)
  48. {
  49. return serial_autodetect(erupter_emerald_detect_one, "Block", "Erupter", "Emerald");
  50. }
  51. static int erupter_detect_auto(void)
  52. {
  53. return serial_autodetect(erupter_detect_one, "Block", "Erupter");
  54. }
  55. static void erupter_drv_init();
  56. static void erupter_detect()
  57. {
  58. erupter_drv_init();
  59. // Actual serial detection is handled by Icarus driver
  60. serial_detect_auto_byname(&erupter_drv, erupter_detect_one, erupter_detect_auto);
  61. serial_detect_auto_byname(&erupter_drv_emerald, erupter_emerald_detect_one, erupter_emerald_detect_auto);
  62. }
  63. static bool erupter_identify(struct cgpu_info *erupter)
  64. {
  65. struct thr_info *thr = erupter->thr[0];
  66. struct icarus_state *state = thr->cgpu_data;
  67. state->identify = true;
  68. return true;
  69. }
  70. static void erupter_drv_init()
  71. {
  72. erupter_drv = icarus_drv;
  73. erupter_drv.dname = "erupter";
  74. erupter_drv.name = "BES";
  75. erupter_drv.drv_detect = erupter_detect;
  76. erupter_drv.identify_device = erupter_identify;
  77. erupter_drv_emerald = erupter_drv;
  78. erupter_drv_emerald.name = "BEE";
  79. }
  80. struct device_drv erupter_drv = {
  81. // Needed to get to erupter_drv_init at all
  82. .drv_detect = erupter_detect,
  83. };
  84. struct device_drv erupter_drv_emerald;