Untitled


SUBMITTED BY: Guest

DATE: Dec. 11, 2013, 8:24 p.m.

FORMAT: Text only

SIZE: 15.1 kB

HITS: 18660

  1. This README contains extended details about FPGA mining with BFGMiner
  2. ModMiner (MMQ)
  3. --------------
  4. ModMiner does not have any persistent storage for bitstreams, so BFGMiner must
  5. upload it after power on. For this to work, you must first download the
  6. necessary bitstream file to BFGMiner's "bitstreams" directory, and give it the
  7. name "fpgaminer_x6500-overclocker-0402.bit". You can download this bitstream
  8. from FPGA Mining LLC's website:
  9. http://www.fpgamining.com/documentation/firmware
  10. -
  11. If the MMQ doesn't respond to BFGMiner at all, or the red LED isn't flashing
  12. then you will need to reset the MMQ.
  13. The red LED should always be flashing when it is mining or ready to mine.
  14. To reset the MMQ, you are best to press the left "RESET" button on the
  15. backplane, then unplug and replug the USB cable.
  16. If your MMQ doesn't have a button on the "RESET" pad, you need to join the two
  17. left pads of the "RESET" pad with conductive wire to reset it. Cutting a small
  18. (metal) paper-clip in half works well for this.
  19. Then unplug the USB cable, wait for 5 seconds, then plug it back in.
  20. After you press reset, the red LED near the USB port should blink continuously.
  21. If it still wont work, power off, wait for 5 seconds, then power on the MMQ
  22. This of course means it will upload the bitstream again when you start BFGMiner.
  23. -
  24. Device 0 is on the power end of the board.
  25. -
  26. You must make sure you have an appropriate firmware in your MMQ
  27. Read here for official details of changing the firmware:
  28. http://wiki.btcfpga.com/index.php?title=Firmware
  29. The basics of changing the firmware are:
  30. You need two short pieces of conductive wire if your MMQ doesn't have buttons
  31. on the "RESET" and "ISP" pads on the backplane board.
  32. Cutting a small (metal) paper-clip in half works well for this.
  33. Join the 2 left pads of the "RESET" pad with wire and the led will dim.
  34. Without disconnecting the "RESET", join the 2 left pads of the "ISP" pad with
  35. a wire and it will stay dim.
  36. Release "RESET" then release "ISP" and is should still be dim.
  37. Unplug the USB and when you plug it back in it will show up as a mass storage
  38. device.
  39. Linux: (as one single line):
  40. mcopy -i /dev/disk/by-id/usb-NXP_LPC134X_IFLASH_ISP000000000-0:0
  41. modminer091012.bin ::/firmware.bin
  42. Windows: delete the MSD device file firmware.bin and copy in the new one
  43. rename the new file and put it under the same name 'firmware.bin'
  44. Disconnect the USB correctly (so writes are flushed first)
  45. Join and then disconnect "RESET" and then plug the USB back in and it's done.
  46. Best to update to one of the latest 2 listed below if you don't already
  47. have one of them in your MMQ.
  48. The current latest different firmware are:
  49. Latest for support of normal or TLM bitstream:
  50. http://btcfpga.com/files/firmware/modminer092612-TLM.bin
  51. Latest with only normal bitstream support (Temps/HW Fix):
  52. http://btcfpga.com/files/firmware/modminer091012.bin
  53. The code is currently tested on the modminer091012.bin firmware.
  54. This comment will be updated when others have been tested.
  55. -
  56. On many Linux distributions there is an app called modem-manager that may cause
  57. problems when it is enabled, due to opening the MMQ device and writing to it.
  58. The problem will typically present itself by the flashing led on the backplane
  59. going out (no longer flashing) and it takes a power cycle to re-enable the MMQ
  60. firmware - which then can lead to the problem reoccurring.
  61. You can either disable/uninstall modem-manager if you don't need it or:
  62. a (hack) solution to this is to blacklist the MMQ USB device in
  63. /lib/udev/rules.d/77-mm-usb-device-blacklist.rules
  64. Adding 2 lines like this (just above APC) should help.
  65. # MMQ
  66. ATTRS{idVendor}=="1fc9", ATTRS{idProduct}=="0003", ENV{ID_MM_DEVICE_IGNORE}="1"
  67. The change will be lost and need to be re-done, next time you update the
  68. modem-manager software.
  69. BitForce (BFL)
  70. --------------
  71. --bfl-range Use nonce range on BitForce devices if supported
  72. This option is only for BitForce devices. Earlier devices such as the single
  73. did not have any way of doing small amounts of work which meant that a lot of
  74. work could be lost across block changes. Some of the Mini Rigs have support
  75. for doing this, so less work is lost across a longpoll. However, it comes at
  76. a cost of 1% in overall hashrate so this feature is disabled by default. It
  77. is only recommended you enable this if you are mining with a Mini Rig on
  78. P2Pool.
  79. BFGMiner also bundles a bitforce-firmware-flash utility on Linux. Using this,
  80. you can change the bitstream firmware on BitForce Singles. It is untested with
  81. other devices. Use at your own risk! Windows users may use Butterfly Labs
  82. EasyMiner to change firmware.
  83. To compile:
  84. make bitforce-firmware-flash
  85. To flash your BFL, specify the BFL port and the flash file e.g.:
  86. sudo ./bitforce-firmware-flash /dev/ttyUSB0 alphaminer_832.bfl
  87. It takes a bit under 3 minutes to flash a BFL and shows a progress % counter
  88. Once it completes, you may also need to wait about 15 seconds, then power the
  89. BFL off and on again.
  90. If you get an error at the end of the BFL flash process stating:
  91. "Error reading response from ZBX"
  92. it may have worked successfully anyway.
  93. Test mining on it to be sure if it worked or not.
  94. You need to give BFGMiner about 10 minutes mining with the BFL to be sure of
  95. the Mh/s value reported with the changed firmware - and the MH/s reported will
  96. be less than the firmware speed since you lose work on every block change.
  97. Icarus (ICA)
  98. ------------
  99. There are two hidden options in BFGMiner when Icarus support is compiled in:
  100. --icarus-options <arg> Set specific FPGA board configurations - one set of values for all or comma separated
  101. baud:work_division:fpga_count:quirks
  102. baud The Serial/USB baud rate - 115200 or 57600 only - default 115200
  103. work_division The fraction of work divided up for each FPGA chip - 1, 2, 4 or 8
  104. e.g. 2 means each FPGA does half the nonce range - default 2
  105. fpga_count The actual number of FPGA working - this would normally be the same
  106. as work_division - range is from 1 up to 'work_division'
  107. It defaults to the value of work_division - or 2 if you don't specify
  108. work_division
  109. quirks List of quirks to enable and disable (after a minus sign):
  110. r Reopen device regularly to workaround buggy Icarus USB chipset
  111. (enabled by default)
  112. If you define fewer comma separated values than Icarus devices, the last values
  113. will be used for all extra devices.
  114. An example would be: --icarus-options 57600:2:1:-r
  115. This would mean: use 57600 baud, the FPGA board divides the work in half however
  116. only 1 FPGA actually runs on the board, and don't reopen the device (e.g. like
  117. an early CM1 Icarus copy bitstream).
  118. --icarus-timing <arg> Set how the Icarus timing is calculated - one setting/value for all or comma separated
  119. default[=N] Use the default Icarus hash time (2.6316ns)
  120. short=[N] Calculate the hash time and stop adjusting it at ~315 difficulty 1 shares (~1hr)
  121. long=[N] Re-calculate the hash time continuously
  122. value[=N] Specify the hash time in nanoseconds (e.g. 2.6316) and abort time (e.g. 2.6316=80)
  123. If you define fewer comma separated values than Icarus devices, the last values
  124. will be used for all extra devices.
  125. Icarus timing is required for devices that do not exactly match a default
  126. Icarus Rev3 in processing speed.
  127. If you have an Icarus Rev3 you should not normally need to use --icarus-timing
  128. since the default values will maximise the Mh/s and display it correctly.
  129. Icarus timing is used to determine the number of hashes that have been checked
  130. when it aborts a nonce range (including on a longpoll).
  131. It is also used to determine the elapsed time when it should abort a nonce
  132. range to avoid letting the Icarus go idle, but also to safely maximise that
  133. time.
  134. 'short' or 'long' mode should only be used on a computer that has enough CPU
  135. available to run BFGMiner without any CPU delays (an active desktop or swapping
  136. computer would not be stable enough).
  137. Any CPU delays while calculating the hash time will affect the result
  138. 'short' mode only requires the computer to be stable until it has completed
  139. ~315 difficulty 1 shares, 'long' mode requires it to always be stable to ensure
  140. accuracy, however, over time it continually corrects itself.
  141. The optional additional =N for 'short' or 'long' specifies the limit to set the
  142. timeout to in deciseconds; thus if the timing code calculation is higher while
  143. running, it will instead use the limit.
  144. This can be set to the appropriate value to ensure the device never goes idle
  145. even if the calculation is negatively affected by system performance.
  146. When in 'short' or 'long' mode, it will report the hash time value each time it
  147. is re-calculated.
  148. In 'short' or 'long' mode, the scan abort time starts at 5 seconds and uses the
  149. default 2.6316ns scan hash time, for the first 5 nonces or one minute
  150. (whichever is longer).
  151. In 'default' or 'value' mode the 'constants' are calculated once at the start,
  152. based on the default value or the value specified.
  153. The optional additional =N specifies to set the default abort at N 1/10ths of a
  154. second, not the calculated value, which is 112 for 2.6316ns
  155. To determine the hash time value for a non Icarus Rev3 device or an Icarus Rev3
  156. with a different bitstream to the default one, use 'long' mode and give it at
  157. least a few hundred shares, or use 'short' mode and take note of the final hash
  158. time value (Hs) calculated.
  159. You can also use the RPC API 'stats' command to see the current hash time (Hs)
  160. at any time.
  161. The Icarus code currently only works with an FPGA device that supports the same
  162. commands as Icarus Rev3 requires and also is less than ~840Mh/s and greater
  163. than 2Mh/s.
  164. If an FPGA device does hash faster than ~840Mh/s it should work correctly if
  165. you supply the correct hash time nanoseconds value.
  166. The timing code itself will affect the Icarus performance since it increases
  167. the delay after work is completed or aborted until it starts again.
  168. The increase is, however, extremely small and the actual increase is reported
  169. with the RPC API 'stats' command (a very slow CPU will make it more noticeable).
  170. Using the 'short' mode will remove this delay after 'short' mode completes.
  171. The delay doesn't affect the calculation of the correct hash time.
  172. X6500
  173. -----
  174. Since X6500 FPGAs do not use serial ports for communication, the --scan-serial
  175. option instead works with product serial numbers. By default, any devices with
  176. the X6500 USB product id will be used, but some X6500s may have shipped without
  177. this product id being configured. If you have any of these, you will need to
  178. specify their serial numbers explicitly, and also add -S x6500:auto if you
  179. still want to use the autodetection for other properly-configured FPGAs.
  180. The serial number of X6500s is usually found on a label applied to the ATX
  181. power connector slot. If yours is missing, devices seen by the system can be
  182. displayed by starting bfgminer in debug mode. To get a simple list of devices,
  183. with the debug output shown, you can use: bfgminer -D -d? -T
  184. X6500 does not have any persistent storage for bitstreams, so BFGMiner must
  185. upload it after power on. For this to work, you must first download the
  186. necessary bitstream file to BFGMiner's "bitstreams" directory, and give it the
  187. name "fpgaminer_x6500-overclocker-0402.bit". You can download this bitstream
  188. from FPGA Mining LLC's website:
  189. http://www.fpgamining.com/documentation/firmware
  190. ZTEX FPGA Boards
  191. ----------------
  192. http://www.ztex.de sells two boards suitable for mining: the 1.15x with 1 FPGA
  193. and the 1.15y with 4 FPGAs. ZTEX distributes their own mining software and
  194. drivers. BFGMiner has full support for these boards, as long as they have at
  195. least the "dummy" mining bitstreams installed on them.
  196. If your boards do not have a mining bitstream yet, you must first, install
  197. ZTEX's BTCMiner (requires Java JDK version 6 or later) and install one.
  198. === WINDOWS NOTE ===
  199. Upon first powering up and connecting the board via USB, windows will attempt
  200. and fail to find the appropriate drivers. To load the initial firmware on the
  201. board, you'll need the EZ-USB FX2 SDK from here:
  202. http://www.ztex.de/downloads/#firmware_kit
  203. Extract the firmware kit and use the driver within libusb-win32/ztex.inf.
  204. Windows should now recognize the board and you're ready to program it.
  205. === END OF WINDOWS ===
  206. Grab the latest miner jar from http://www.ztex.de/btcminer/#download and program
  207. the appropriate dummy firmware for your board. The command should look
  208. something like (for a single FPGA board):
  209. java -cp ZtexBTCMiner-120417.jar BTCMiner -m p -f **FILENAME** -s 01-02-01
  210. For ZTEX 1.15x boards, the dummy bitstream filename is ztex_ufm1_15d.ihx
  211. For ZTEX 1.15y boards, the dummy bitstream filename is ztex_ufm1_15y.ihx
  212. === WINDOWS NOTE ===
  213. To mine using BFGMiner, you'll have to swap the USB drivers. The BFGMiner-
  214. compatible WinUSB drivers for the board can be generated with this tool:
  215. http://sourceforge.net/projects/libwdi/files/zadig/
  216. Basic usage instructions for Zadig can be found here:
  217. https://github.com/pbatard/libwdi/wiki/Zadig
  218. Once Zadig generates and installs a WinUSB driver, ensure everything is working
  219. by running:
  220. bfgminer -D -d? -T
  221. You should see something like this in the output:
  222. [2013-01-22 20:19:11] Found 1 ztex board
  223. [2013-01-22 20:19:11] ZTX 0: Found Ztex (ZTEX 0001-02-01-1)
  224. === END OF WINDOWS ===
  225. If you have installed a dummy bitstream, you will now need to copy the main
  226. mining bitstream where BFGMiner can find it. This are usually the same as the
  227. dummy bitstream filename, but with a number added to the end. Extract the
  228. ZtexBTCMiner-120417.jar file using any unzip utility, and look for the proper
  229. *.ihx and *.bit files (the latter will be inside the 'fpga' directory of the
  230. jar). Copy them to BFGMiner's "bitstreams" directory, and you're ready to start
  231. mining.

comments powered by Disqus