FPGA-README 11 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266
  1. This README contains extended details about FPGA mining with cgminer
  2. For ModMinerQuad (MMQ) and BitForce (BFL)
  3. -----------------------------------------
  4. When mining on windows, the driver being used will determine if mining will work.
  5. If the driver doesn't allow mining, you will get a "USB init," error message
  6. i.e. one of:
  7. open device failed, err %d, you need to install a Windows USB driver for the device
  8. or
  9. kernel detach failed :(
  10. or
  11. claim interface %d failed, err %d
  12. The best solution for this is to use a tool called Zadig to set the driver:
  13. http://sourceforge.net/projects/libwdi/files/zadig/
  14. This allows you set the driver for the device to be WinUSB which is usually
  15. required to make it work if your having problems
  16. With Zaidg, you may need to run it as administrator and if your device is
  17. plugged in but you cannot see it, use the Menu: Options -> List All Devices
  18. You must also make sure you are using the latest libusb-1.0.dll supplied
  19. with cgminer (not the libusbx version)
  20. -
  21. When mining on linux, but not using 'sudo' and not logged into 'root' you
  22. may get a USB priviledge error (-3), so you may also need to do the following:
  23. Create /etc/udev/rules.d/01-cgminer.rules
  24. With:
  25. ATTRS{idVendor}=="0403", ATTRS{idProduct}=="6014", SUBSYSTEMS=="usb", ACTION=="add", MODE="0666", GROUP="plugdev"
  26. ATTRS{idVendor}=="1fc9", ATTRS{idProduct}=="0003", SUBSYSTEMS=="usb", ACTION=="add", MODE="0666", GROUP="plugdev"
  27. And also:
  28. sudo usermod -G plugdev -a `whoami`
  29. Then reboot ...
  30. If your linux distro doesn't have the 'plugdev' group, you can create it like:
  31. sudo groupadd plugdev
  32. -
  33. There is a hidden option in cgminer to dump out a lot of information
  34. about USB that will help the developers to assist you if you are having
  35. problems:
  36. --usb-dump 0
  37. It will only help if you have a working MMQ or BFL device attached to the
  38. computer
  39. ModMinerQuad (MMQ)
  40. ------------------
  41. The mining bitstream does not survive a power cycle, so cgminer will upload
  42. it, if it needs to, before it starts mining (approx 7min 40sec)
  43. The red LED also flashes while it is uploading the bitstream
  44. -
  45. If the MMQ doesn't respond to cgminer at all, or the red LED isn't flashing
  46. then you will need to reset the MMQ
  47. The red LED should always be flashing when it is mining or ready to mine
  48. To reset the MMQ, you are best to press the left "RESET" button on the
  49. backplane, then unplug and replug the USB cable
  50. If your MMQ doesn't have a button on the "RESET" pad, you need to join
  51. the two left pads of the "RESET" pad with conductive wire to reset it.
  52. Cutting a small (metal) paper-clip in half works well for this
  53. Then unplug the USB cable, wait for 5 seconds, then plug it back in
  54. After you press reset, the red LED near the USB port should blink continuously
  55. If it still wont work, power off, wait for 5 seconds, then power on the MMQ
  56. This of course means it will upload the bitstream again when you start cgminer
  57. -
  58. Device 0 is on the power end of the board
  59. -
  60. You must make sure you have an approriate firmware in your MMQ
  61. Read here for official details of changing the firmware:
  62. http://wiki.btcfpga.com/index.php?title=Firmware
  63. The basics of changing the firmware are:
  64. You need two short pieces of conductive wire if your MMQ doesn't have
  65. buttons on the "RESET" and "ISP" pads on the backplane board
  66. Cutting a small (metal) paper-clip in half works well for this
  67. Join the 2 left pads of the "RESET" pad with wire and the led will dim
  68. Without disconnecting the "RESET", join the 2 left pads of the "ISP" pad
  69. with a wire and it will stay dim
  70. Release "RESET" then release "ISP" and is should still be dim
  71. Unplug the USB and when you plug it back in it will show up as a mass
  72. storage device
  73. Linux: (as one single line):
  74. mcopy -i /dev/disk/by-id/usb-NXP_LPC134X_IFLASH_ISP000000000-0:0
  75. modminer091012.bin ::/firmware.bin
  76. Windows: delete the MSD device file firmware.bin and copy in the new one
  77. rename the new file and put it under the same name 'firmware.bin'
  78. Disconnect the USB correctly (so writes are flushed first)
  79. Join and then disconnect "RESET" and then plug the USB back in and it's done
  80. Best to update to one of the latest 2 listed below if you don't already
  81. have one of them in your MMQ
  82. The current latest different firmware are:
  83. Latest for support of normal or TLM bitstream:
  84. http://btcfpga.com/files/firmware/modminer092612-TLM.bin
  85. Latest with only normal bitstream support (Temps/HW Fix):
  86. http://btcfpga.com/files/firmware/modminer091012.bin
  87. The code is currently tested on the modminer091012.bin firmware.
  88. This comment will be updated when others have been tested
  89. -
  90. On many linux distributions there is an app called modem-manager that
  91. may cause problems when it is enabled, due to opening the MMQ device
  92. and writing to it
  93. The problem will typically present itself by the flashing led on the
  94. backplane going out (no longer flashing) and it takes a power cycle to
  95. re-enable the MMQ firmware - which then can lead to the problem happening
  96. again
  97. You can either disable/uninstall modem-manager if you don't need it or:
  98. a (hack) solution to this is to blacklist the MMQ USB device in
  99. /lib/udev/rules.d/77-mm-usb-device-blacklist.rules
  100. Adding 2 lines like this (just above APC) should help
  101. # MMQ
  102. ATTRS{idVendor}=="1fc9", ATTRS{idProduct}=="0003", ENV{ID_MM_DEVICE_IGNORE}="1"
  103. The change will be lost and need to be re-done, next time you update the
  104. modem-manager software
  105. TODO: check that all MMQ's have the same product ID
  106. BitForce (BFL)
  107. --------------
  108. --bfl-range Use nonce range on bitforce devices if supported
  109. This option is only for bitforce devices. Earlier devices such as the single
  110. did not have any way of doing small amounts of work which meant that a lot of
  111. work could be lost across block changes. Some of the "minirigs" have support
  112. for doing this, so less work is lost across a longpoll. However, it comes at
  113. a cost of 1% in overall hashrate so this feature is disabled by default. It
  114. is only recommended you enable this if you are mining with a minirig on
  115. p2pool.
  116. C source is included for a bitforce firmware flash utility on Linux only:
  117. bitforce-firmware-flash.c
  118. Using this, you can change the bitstream firmware on bitforce singles.
  119. It is untested with other devices. Use at your own risk!
  120. To compile:
  121. make bitforce-firmware-flash
  122. To flash your BFL, specify the BFL port and the flash file e.g.:
  123. sudo ./bitforce-firmware-flash /dev/ttyUSB0 alphaminer_832.bfl
  124. It takes a bit under 3 minutes to flash a BFL and shows a progress % counter
  125. Once it completes, you may also need to wait about 15 seconds,
  126. then power the BFL off and on again
  127. If you get an error at the end of the BFL flash process stating:
  128. "Error reading response from ZBX"
  129. it may have worked successfully anyway.
  130. Test mining on it to be sure if it worked or not.
  131. You need to give cgminer about 10 minutes mining with the BFL to be sure of
  132. the MH/s value reported with the changed firmware - and the MH/s reported
  133. will be less than the firmware speed since you lose work on every block change.
  134. Icarus (ICA)
  135. ------------
  136. There are two hidden options in cgminer when Icarus support is compiled in:
  137. --icarus-options <arg> Set specific FPGA board configurations - one set of values for all or comma separated
  138. baud:work_division:fpga_count
  139. baud The Serial/USB baud rate - 115200 or 57600 only - default 115200
  140. work_division The fraction of work divided up for each FPGA chip - 1, 2, 4 or 8
  141. e.g. 2 means each FPGA does half the nonce range - default 2
  142. fpga_count The actual number of FPGA working - this would normally be the same
  143. as work_division - range is from 1 up to 'work_division'
  144. It defaults to the value of work_division - or 2 if you don't specify
  145. work_division
  146. If you define fewer comma seperated values than Icarus devices, the last values will be used
  147. for all extra devices
  148. An example would be: --icarus-options 57600:2:1
  149. This would mean: use 57600 baud, the FPGA board divides the work in half however
  150. only 1 FPGA actually runs on the board (e.g. like an early CM1 Icarus copy bitstream)
  151. --icarus-timing <arg> Set how the Icarus timing is calculated - one setting/value for all or comma separated
  152. default[=N] Use the default Icarus hash time (2.6316ns)
  153. short Calculate the hash time and stop adjusting it at ~315 difficulty 1 shares (~1hr)
  154. long Re-calculate the hash time continuously
  155. value[=N] Specify the hash time in nanoseconds (e.g. 2.6316) and abort time (e.g. 2.6316=80)
  156. If you define fewer comma seperated values than Icarus devices, the last values will be used
  157. for all extra devices
  158. Icarus timing is required for devices that do not exactly match a default Icarus Rev3 in
  159. processing speed
  160. If you have an Icarus Rev3 you should not normally need to use --icarus-timing since the
  161. default values will maximise the MH/s and display it correctly
  162. Icarus timing is used to determine the number of hashes that have been checked when it aborts
  163. a nonce range (including on a LongPoll)
  164. It is also used to determine the elapsed time when it should abort a nonce range to avoid
  165. letting the Icarus go idle, but also to safely maximise that time
  166. 'short' or 'long' mode should only be used on a computer that has enough CPU available to run
  167. cgminer without any CPU delays (an active desktop or swapping computer would not be stable enough)
  168. Any CPU delays while calculating the hash time will affect the result
  169. 'short' mode only requires the computer to be stable until it has completed ~315 difficulty 1 shares
  170. 'long' mode requires it to always be stable to ensure accuracy, however, over time it continually
  171. corrects itself
  172. When in 'short' or 'long' mode, it will report the hash time value each time it is re-calculated
  173. In 'short' or 'long' mode, the scan abort time starts at 5 seconds and uses the default 2.6316ns
  174. scan hash time, for the first 5 nonce's or one minute (whichever is longer)
  175. In 'default' or 'value' mode the 'constants' are calculated once at the start, based on the default
  176. value or the value specified
  177. The optional additional =N specifies to set the default abort at N 1/10ths of a second, not the
  178. calculated value, which is 112 for 2.6316ns
  179. To determine the hash time value for a non Icarus Rev3 device or an Icarus Rev3 with a different
  180. bitstream to the default one, use 'long' mode and give it at least a few hundred shares, or use
  181. 'short' mode and take note of the final hash time value (Hs) calculated
  182. You can also use the RPC API 'stats' command to see the current hash time (Hs) at any time
  183. The Icarus code currently only works with an FPGA device that supports the same commands as
  184. Icarus Rev3 requires and also is less than ~840MH/s and greater than 2MH/s
  185. If an FPGA device does hash faster than ~840MH/s it should work correctly if you supply the
  186. correct hash time nanoseconds value
  187. The timing code itself will affect the Icarus performance since it increases the delay after
  188. work is completed or aborted until it starts again
  189. The increase is, however, extremely small and the actual increase is reported with the
  190. RPC API 'stats' command (a very slow CPU will make it more noticeable)
  191. Using the 'short' mode will remove this delay after 'short' mode completes
  192. The delay doesn't affect the calculation of the correct hash time