Go to file
2023-11-05 13:32:34 +01:00
.github/workflows run ci only on master branch, create all images and save only *.bin 2023-09-13 16:46:59 +02:00
.vscode Move to PlatformIO 2023-04-15 23:56:13 +02:00
3d_files NerdMinerCase with buttons 2023-08-04 23:58:36 +02:00
bin bin files updated and added sprite destroy on Tdisplav1 2023-09-13 00:11:39 +02:00
boards Lilygo S3 T-Dongle fix after TFT driver upgrade. 2023-09-09 14:44:26 +03:00
images minor updates on readme 2023-09-12 13:58:09 +02:00
include Move to PlatformIO 2023-04-15 23:56:13 +02:00
lib update cam display 2023-09-22 01:36:10 +02:00
src Add support for M5 StampS3 device 2023-11-05 13:32:34 +01:00
.gitignore Revert "Just for internal tests" 2023-10-04 21:51:47 -03:00
LICENSE Move to PlatformIO 2023-04-15 23:56:13 +02:00
platformio.ini Add support for M5 StampS3 device 2023-11-05 13:32:34 +01:00
README.md readme update 2023-10-01 10:54:30 +02:00

NerdSoloMiner

The NerdSoloMiner v2

This is a free and open source project that let you try to reach a bitcoin block with a small piece of hardware.

The main aim of this project is to let you learn more about minery and to have a beautiful piece of hardware in your desktop.

Original project https://github.com/valerio-vaccaro/HAN

image

Requirements

  • TTGO T-Display S3 or any supported boards (check Build tutorial 👇)
  • 3D BOX here

Project description

ESP32 implementing Stratum protocol to mine on solo pool. Pool can be changed but originally works with Public-pool.io (where Nerdminers are supported).

This project was initialy developed using ESP32-S3, but currently support other boards. It uses WifiManager to modify miner settings and save them to SPIFF. The microMiner comes with several screens to monitor it's working procedure and also to show you network mining stats. Currently includes:

  • NerdMiner Screen > Mining data of Nerdminer
  • ClockMiner Screen > Fashion style clock miner
  • GlobalStats Screen > Global minery stats and relevant data

This miner is multicore and multithreads, both cores are used to mine and several threads are used to implementing stratum work and wifi stuff. Every time an stratum job notification is received miner update its current work to not create stale shares.

IMPORTANT Miner is not seen by all standard pools due to its low share difficulty. You can check miner work remotely using specific pools specified down or seeing logs via UART.

Current project is still in developement and more features will be added

Build Tutorial

Hardware requirements

  • LILYGO T-Display S3 (original one) or any other supported boards
  • 3D BOX here

Current Supported Boards

*Affiliate links

Flash firmware

Easyiest way to flash firmware. Build your own miner using the folowing firwmare flash tool:

  1. Get a TTGO T-display S3 or any other supported board
  2. Go to NM2 flasher online: https://bitmaker-hub.github.io/diyflasher/

Standard tool

Create your own miner using the online firwmare flash tool ESPtool and one of the binary files that you will find in the bin folder. If you want you can compile the entire project using Arduino, PlatformIO or Expressif IDF.

  1. Get a TTGO T-display S3 or any supported board
  2. Download this repository
  3. Go to ESPtool online: https://espressif.github.io/esptool-js/
  4. Load the firmware with the binary from one of the sub-folders of bin corresponding to your board.
  5. Plug your board and select each file from the sub-folder (.bin files).

Update firmware

Update NerdMiner firmware following same flashing steps but only using the file 0x10000_firmware.bin.

Build troubleshooting

  1. Online ESPtool works with chrome, chromium, brave
  2. ESPtool recommendations: use 115200bps
  3. Build errors > If during firmware download upload stops, it's recommended to enter the board in boot mode. Unplug cable, hold right bottom button and then plug cable. Try programming
  4. In extreme case you can "Erase all flash" on ESPtool to clean all current configuration before uploading firmware. There has been cases that experimented Wifi failures until this was made.
  5. In case of ESP32-WROOM Boards, could be necessary to put your board on boot mode. Hold boot button, press reset button and then program.

NerdMiner configuration

After programming, you will only need to setup your Wifi and BTC address.

Wifi Accesspoint

  1. Connect to NerdMinerAP
    • AP: NerdMinerAP
    • PASS: MineYourCoins
  2. Setup your Wifi Network
  3. Add your BTCaddress

SD card (if available)

  1. Format a SD card using Fat32.
  2. Create a file named "config.json" in your card's root, containing the the following structure. Adjust the settings to your needs:
    {
    "SSID": "myWifiSSID",
    "WifiPW": "myWifiPassword",
    "PoolUrl": "public-pool.io",
    "PoolPort": 21496,
    "BtcWallet": "walletID",
    "Timezone": 2,
    "SaveStats": false
    }
  3. Insert the SD card.
  4. Hold down the "reset configurations" button as described below to reset the configurations and/or boot without settings in your nvmemory.
  5. Power down to remove the SD card. It is not needed for mining.

Pool selection

Recommended low difficulty share pools:

Pool URL Port Web URL Status
public-pool.io 21496 https://web.public-pool.io Open Source Solo Bitcoin Mining Pool supporting open source miners
nerdminers.org https://nerdminers.org Team domain for future pool - Currently pointing to public-pool.io
pool.nerdminer.io 3333 https://nerdminer.io Mantained by CHMEX
pool.vkbit.com 3333 https://vkbit.com/ Mantained by djerfy

Other standard pools not compatible with low difficulty share:

Pool URL Port Web URL
solo.ckpool.org 3333 https://solo.ckpool.org/
btc.zsolo.bid 6057 https://zsolo.bid/en/btc-solo-mining-pool
eu.stratum.slushpool.com 3333 https://braiins.com/pool

Buttons

One button devices:

  • One click > change screen.
  • Double click > change screen orientation.
  • Tripple click > turn the screen off and on again.
  • Hold 5 seconds > reset the configurations and reboot your NerdMiner.

Two button devices:

With the USB-C port to the right:

TOP BUTTON

  • One click > change screen.
  • Hold 5 seconds > top right button to reset the configurations and reboot your NerdMiner.
  • Hold and power up > enter configuration mode and edit current config via Wifi. You could change your settings or verify them.

BOTTOM BUTTON

  • One Click > turn the screen off and on again
  • Double click > change orientation (default is USB-C to the right)

Build video

Ver video aquí

Developers

Project guidelines

  • Current project was addapted to work with PlatformIO
  • Current project works with ESP32-S3 and ESP32-wroom.
  • Partition squeme should be build as huge app
  • All libraries needed shown on platform.ini

Job done

  • Move project to platformIO
  • Bug rectangle on screen when 1milion shares
  • Bug memory leaks
  • Bug Reboots when received JSON contains some null values
  • Implement midstate sha256
  • Bug Wificlient DNS unresolved on Wifi.h
  • Code refactoring
  • Add blockHeight to screen
  • Add clock to show current time
  • Add new screen with global mining stats
  • Add pool support for low difficulty miners
  • Add best difficulty on miner screen
  • Add suport to standard ESP32 dev-kit / ESP32-WROOM
  • Code changes to support adding multiple boards
  • Add support to TTGO T-display 1.14
  • Add support to Amoled

On process

  • Create a daisy chain protocol via UART or I2C to support ESP32 hashboards
  • Create new screen like clockMiner but with BTC price
  • Add support to control BM1397

Donations/Project contributions

If you would like to contribute and help dev team with this project you can send a donation to the following LN address teamnerdminer@getalby.com or using one of the affiliate links above.

If you want to order a fully assembled Nerdminer you can contribute to my job at bitronics.store.

Enjoy