Table of Contents

Getting Started with Meshtastic in Singapore

(Quickstart for existing Meshtastic users with Python CLI)

Reasons to Use Meshtastic

Meshtastic® is a project that enables you to use inexpensive LoRa radios as a long range off-grid communication platform in areas without existing or reliable communications infrastructure. This project is 100% community driven and open source!

https://meshtastic.org/docs/introduction/

For Laypersons

Meshtastic provides a phone app that looks and feels similar to other messaging apps, except that it does not require any cellular data or Wi-Fi. Instead, communications take place over a network of devices (nodes) that are owned and operated by the users, with nodes relaying messages to other nodes in range (typically several kilometers).

For Persons with An Interest in Electronics or Radio Communications

Meshtastic is a great platform with opportunities to observe and experiment with radio communications in the real world, urban and outdoors. The software, firmware and protocol are open source and extensible; the protocol can send GPS coordinates, telemetry such as weather data, GPIO sensors and more. Various integrations for other software to send data over Meshtastic have also been written e.g. ATAK.

For more information about the LoRa modulation/encoding Meshtastic uses, have a read of what is LoRa.

Use Cases

Buy Hardware to Use Meshtastic

:!: Do not power up LoRa boards without an antenna attached, the transmitter may get damaged by the reflected signal :!:

Minimum hardware needed to get connected:

  1. Meshtastic Software i.e. a client device

Meshtastic Devices

:!: When ordering, select the 923 MHz option if available, otherwise, 915 MHz, or 868 MHz if no other 900 MHz band is available

:?: The device hardware for 868/915/923 MHz selection is the same, just with different antennae in the box; 433 MHz has hardware differences and can't be used for 900 MHz band

:!: Heltec devices are missing USB-C Configuration Channel resistors, so USB-C PD compliant supplies will likely not supply power. Using a USB-A to USB-C cable solves this issue. LILYGO boards have the correct CC resistors (i.e. 5.1 kΩ from pins CC1 and CC2 to ground) and do not have this issue.

Meshtastic Software

:?: Connects to the Meshtastic node over Bluetooth LE, USB serial or Wi-Fi. Optional if you have a standalone node with keyboard.

Antennae

Antenna Suggestions (TODO: NanoVNA test reports)

Nice to Haves

Installing Meshtastic Firmware

Flash the latest firmware with the Meshtastic web flasher.

  1. Appropriate USB COM port drivers must be installed (Windows/MacOS), e.g. Silicon Labs CP210x VCP drivers
  2. Put the device into programming mode
    • Battery powered devices: Connect USB cable, hold the boot button, tap the reset button, release the boot button
    • USB powered devices: Hold the boot button, connect USB cable, release the boot button
  3. Select your board and the latest firmware at Meshtastic web flasher
  4. Click Flash, Continue
  5. Select Full Erase and Install if this is the first time installing Meshtastic, this will wipe any leftover data from factory programming

For more experienced ESP32 users, standard tools and methods to flash ESP32 can be used as well, with files from the Meshtastic firmware releases.

First Use Configuration

Region Configuration

A freshly installed Meshtastic device must have its region configured before the LoRa radio is enabled, this sets limits on the Meshtastic device and LoRa radio to operate within local regulation restrictions. The exact firmware limits for each region can be found in the firmware definitions.

Devices are only visible to, and can only communicate with, devices configured with the same region.

Usable regions in Singapore:

Meshtastic Channel Configuration

Creating a Private 9V1 Primary Channel with Default Secondary Channel

Motivations:

Steps (the easy way):

  1. Contact me for the channel URL
  2. Install the channel and LoRa settings with the URL
    • Android/iOS Client: Open the link on the same device as the Meshtastic app and accept the settings
    • Python CLI: meshtastic --seturl '[channel url]'

Steps (the hard way, adapted from Creating a Private Primary with Default Secondary):

  1. Ensure you have not changed the LoRa Modem Preset from the default unset/LONG_FAST
  2. On your PRIMARY channel, set channel name to 9V1 and set encryption key (contact me for it)
  3. Configure and enable a SECONDARY channel named LongFast with PSK AQ==
  4. If your LoRa channel is at the default (0), the radio's frequency will be automatically changed based on your PRIMARY channel's name. In this case, you will have to manually set it back to your region's default (in LoRa settings) in order to interface with users on the default channel:
    • 4 for SG_9231)

Enable MQTT Forwarding

Because we don't currently have enough nodes in Singapore to form a full mesh, we need to enable MQTT forwarding to use the Internet as a backhaul to forward messages between isolated nodes and meshes.

The node must either be connected to Wi-Fi directly (mesh router-client to MQTT bridge), or be paired with an Android or iOS device with “MQTT Client Proxy” enabled (mobile node).

In future, when a full mesh is formed, MQTT can be disabled for a truly decentralized and private mesh, or left enabled as a backup in case of dead zones in the mesh.

Configuration for Wi-Fi MQTT Routers

:!: Turning Wi-Fi on turns BLE off, so further configuration will have to be done over the Web Client, Android client or Python CLI.

Enable Store & Forward

Requirements:

:?: To find GPS coordinates for your address, you can use the Google Maps geocoding demo :!: Please write to me@ndoo.sg if you have a site to offer for a Wi-Fi to MQTT router; we will sponsor the hardware.

Build, Buy or 3D Print Enclosure for your Meshtastic Device

Meshtastic devices are primarily development boards, thus being bare PCBs; many also use U.FL/IPEX connections for their LoRa antenna, which are extremely fragile. For your Meshtastic device to leave your desk, you are likely to want an enclosure.

Have a look at Device Enclosures for some ideas and recommendations.

Python CLI Quickstart

If you have used Meshtastic before and just want to switch over to SG_923, here are all the commands you need to get configured.

# Licensed hams
meshtastic --set-ham [YOUR_CALLSIGN] --set-owner-short  [4_CHARACTER_SHORT_NAME]
# Other users
meshtastic --set-owner [LONG_NAME] --set-owner-short  [4_CHARACTER_SHORT_NAME]
 
# Set region
meshtastic --set lora.region 18 && sleep 15
 
# Set channel and tx power (don't configure it at the same time as changing regions)
meshtastic --set lora.channel_num 4 --set lora.tx_power 0 && sleep 15
 
 
# IF Portable device
meshtastic --set mqtt.enabled true --set mqtt.proxy_to_client_enabled true
 
# ELSEIF Stationary MQTT router
meshtastic  --set mqtt.enabled true --set mqtt.proxy_to_client_enabled true --set device.role ROUTER_CLIENT --set network.wifi_enabled true --set network.wifi_ssid "your network" --set network.wifi_psk yourpassword
 
# ENDIF
 
# IF configuring channels via channel URL
meshtastic --seturl [CONTACT ME FOR URL]
 
# ELSEIF configuring channels manually
meshtastic --ch-longfast
meshtastic --ch-set name 9V1 --ch-index 0
meshtastic --ch-set psk [CONTACT ME FOR PSK] --ch-index 0
meshtastic --ch-set downlink_enabled true --ch-index 0 --ch-set uplink_enabled true --ch-index 0
meshtastic --ch-set name LongFast --ch-index 1
meshtastic --ch-set psk 0x01 --ch-index 1
meshtastic --ch-set downlink_enabled true --ch-index 1 --ch-set uplink_enabled true --ch-index 1
meshtastic --ch-enable --ch-index 1
 
# ENDIF

Android/iOS app: Skip ahead to First Use Configuration

Other Meshtastic Notes

Data Rates

Channel setting Alt Channel Name Data-Rate SF / Symbols Coding Rate Bandwidth Link Budget
Short Range / Fast Short Fast 10.94 kbps 7 / 128 4/5 250 143dB
Short Range / Slow Short Slow 6.25 kbps 8 / 256 4/5 250 145.5dB
Medium Range / Fast Medium Fast 3.52 kbps 9 / 512 4/5 250 148dB
Medium Range / Slow Medium Slow 1.95 kbps 10 / 1024 4/5 250 150.5dB
Long Range / Fast Long Fast 1.07 kbps 11 / 2048 4/5 250 153dB
Long Range / Moderate Long Moderate 0.34 kbps 11 / 2048 4/8 125 156dB
Long Range / Slow Long Slow 0.18 kbps 12 / 4096 4/8 125 158.5dB
Very Long Range / Slow Very Long Slow 0.09 kbps 12 / 4096 4/8 62.5 161.5dB

- Data Rates

Windows Python Incompatibility

Entering ESP32 Download Mode