icarus-common.h 2.9 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125
  1. /*
  2. * Copyright 2012-2013 Luke Dashjr
  3. * Copyright 2012 Xiangfu
  4. * Copyright 2012 Andrew Smith
  5. *
  6. * This program is free software; you can redistribute it and/or modify it
  7. * under the terms of the GNU General Public License as published by the Free
  8. * Software Foundation; either version 3 of the License, or (at your option)
  9. * any later version. See COPYING for more details.
  10. */
  11. #ifndef ICARUS_COMMON_H
  12. #define ICARUS_COMMON_H
  13. #include <stdbool.h>
  14. #include <stdint.h>
  15. #include <sys/time.h>
  16. #include "dynclock.h"
  17. #include "miner.h"
  18. // Fraction of a second, USB timeout is measured in
  19. // i.e. 10 means 1/10 of a second
  20. // Right now, it MUST be 10 due to other assumptions.
  21. #define TIME_FACTOR 10
  22. // It's 10 per second, thus value = 10/TIME_FACTOR =
  23. #define ICARUS_READ_FAULT_DECISECONDS 1
  24. #define NANOSEC 1000000000.0
  25. // Default value for ICARUS_INFO->read_size
  26. #define ICARUS_DEFAULT_READ_SIZE 4
  27. #define ICA_GETS_ERROR -1
  28. #define ICA_GETS_OK 0
  29. #define ICA_GETS_RESTART 1
  30. #define ICA_GETS_TIMEOUT 2
  31. // Store the last INFO_HISTORY data sets
  32. // [0] = current data, not yet ready to be included as an estimate
  33. // Each new data set throws the last old set off the end thus
  34. // keeping a ongoing average of recent data
  35. #define INFO_HISTORY 10
  36. extern struct device_drv icarus_drv;
  37. struct ICARUS_HISTORY {
  38. struct timeval finish;
  39. double sumXiTi;
  40. double sumXi;
  41. double sumTi;
  42. double sumXi2;
  43. uint32_t values;
  44. uint32_t hash_count_min;
  45. uint32_t hash_count_max;
  46. };
  47. enum timing_mode { MODE_DEFAULT, MODE_SHORT, MODE_LONG, MODE_VALUE };
  48. enum icarus_reopen_mode {
  49. IRM_NEVER,
  50. IRM_TIMEOUT,
  51. IRM_CYCLE,
  52. };
  53. struct ICARUS_INFO {
  54. // time to calculate the golden_ob
  55. struct timeval golden_tv;
  56. struct ICARUS_HISTORY history[INFO_HISTORY+1];
  57. uint32_t min_data_count;
  58. // seconds per Hash
  59. double Hs;
  60. int read_count;
  61. // ds limit for (short=/long=) read_count
  62. int read_count_limit;
  63. enum timing_mode timing_mode;
  64. bool do_icarus_timing;
  65. int do_default_detection;
  66. double fullnonce;
  67. int count;
  68. double W;
  69. uint32_t values;
  70. uint64_t hash_count_range;
  71. // Determine the cost of history processing
  72. // (which will only affect W)
  73. uint64_t history_count;
  74. struct timeval history_time;
  75. // icarus-options
  76. int baud;
  77. int work_division;
  78. int fpga_count;
  79. uint32_t nonce_mask;
  80. enum icarus_reopen_mode reopen_mode;
  81. uint8_t user_set;
  82. bool continue_search;
  83. dclk_change_clock_func_t dclk_change_clock_func;
  84. struct dclk_data dclk;
  85. // Bytes to read from Icarus for nonce
  86. int read_size;
  87. };
  88. struct icarus_state {
  89. bool firstrun;
  90. struct timeval tv_workstart;
  91. struct timeval tv_workfinish;
  92. struct work *last_work;
  93. struct work *last2_work;
  94. bool changework;
  95. bool identify;
  96. uint8_t ob_bin[64];
  97. };
  98. bool icarus_detect_custom(const char *devpath, struct device_drv *, struct ICARUS_INFO *);
  99. extern int icarus_gets(unsigned char *, int fd, struct timeval *tv_finish, struct thr_info *, int read_count, int read_size);
  100. extern int icarus_write(int fd, const void *buf, size_t bufLen);
  101. #endif