Skip to content

g8dhe/lora-gateway

 
 

Repository files navigation

Part of the LoRa Balloon Tracking System

Runs on a Raspberry Pi with 1 or 2 RFM98HW modules attached to the SPI port. Also works with other compatible HopeRF and Semtec LoRa devices.

Connections

Connect the LoRa module to the Pi A+/B+ like so:

LORA PI ==== ==== 3.3V 3.3V Power GND Ground MOSI MOSI (pin 19) MISO MISO (pin 21) NSS CE0 (pin 24) (CE1 (pin 26) for 2nd module) SCK SLCK DIO0 Wiring Pi 31 (Pin 28) (Wiring Pi 6 (pin 22) for 2nd module) DIO5 Wiring Pi 26 (Pin 32) (Wiring Pi 5 (pin 18) for 2nd module)

For the model A/B boards, use the following for DIO0/DIO5:

DIO0 Wiring Pi 6 (Pin 22) (Wiring Pi 1 (pin 12) for 2nd module) DIO5 Wiring Pi 5 (Pin 18) (Wiring Pi 0 (pin 11) for 2nd module)

Installation

Enable SPI in raspi-config.

Install WiringPi:

1. cd ~
2. git clone git://git.drogon.net/wiringPi
3. cd wiringPi
4. ./build

Install the curl library:

sudo apt-get install libcurl4-openssl-dev

Install the ncurses library

sudo apt-get install libncurses5-dev

Install the LoRa gateway

1. cd ~ 
2. git clone https://github.com/PiInTheSky/lora-gateway.git
3. cd lora-gateway
4. make

Configuration

The configuration is in the file gateway.txt. Example:

tracker=M0RPI
EnableHabitat=N
EnableSSDV=Y
LogTelemetry=Y
CallingTimeout=60

frequency_0=434.347
mode_0=1
DIO0_0=31
DIO5_0=26
AFC_0=N

frequency_1=434.475
mode_1=5
DIO0_1=6
DIO5_1=5
AFC_1=Y

The options are:

tracker=<callsign>.  This is whatever callsign you want to appear as on the tracking map and/or SSDV page.

EnableHabitat=<Y/N>.  Enables uploading of telemetry packets to Habitat.

EnableSSDV=<Y/N>.  Enables uploading of SSDV image packets to the SSDV server.

LogTelemetry=<Y/N>.  Enables logging of telemetry packets (ASCII only at present) to telemetry.txt.

CallingTimeout=<seconds>.  Sets a timeout for returning to calling mode after a period with no received packets.

frequency_<n>=<freq in MHz>.  This sets the frequency for LoRa module <n> (0 for first, 1 for second).  e.g. frequency_0=434.450

AFC_<n>=<Y/N>.  Enables or disables automatic frequency control (retunes by the frequency error of last received packet).

mode_<n>=<mode>.  Sets the "mode" for the selected LoRa module.  This offers a simple way of setting the various
				LoRa parameters (SF etc.) in one go.  The modes are:
				
				0 = (normal for telemetry)	Explicit mode, Error coding 4:8, Bandwidth 20.8kHz, SF 11, Low data rate optimize on
				1 = (normal for SSDV) 		Implicit mode, Error coding 4:5, Bandwidth 20.8kHz,  SF 6, Low data rate optimize off
				2 = (normal for repeater)	Explicit mode, Error coding 4:8, Bandwidth 62.5kHz,  SF 8, Low data rate optimize off
				3 = (normal for fast SSDV)	Explicit mode, Error coding 4:6, Bandwidth 250kHz,   SF 7, Low data rate optimize off
				4 = Test mode not for normal use.
				5 = (normal for calling mode)	Explicit mode, Error coding 4:8, Bandwidth 41.7kHz, SF 11, Low data rate optimize off
				
SF_<n>=<Spreading Factor>  e.g. SF_0=7

Bandwidth_<n>=<Bandwidth>.  e.g. Bandwidth_0=41K7.  Options are 7K8, 10K4, 15K6, 20K8, 31K25, 41K7, 62K5, 125K, 250K, 500K

Implicit_<n>=<Y/N>.  e.g. Implicit_0=Y

Coding_<n>=<error_coding>.  e.g. Coding_0=5 (4:5)

lowopt_<n>=<Y/N>.  Enables or disables low data rate optimization.

Use

Run with:

sudo ./gateway

Interactive Features

The following key presses are available. Where appropriate unshifted keys affect Channel 0 and shifted keys affect Channel 1. Many thanks to David Brooke for coding this feature and the AFC.

q	quit

a	increase frequency by 100kHz
z	decrease frequency by 100kHz
s	increase frequency by 10kHz
x	decrease frequency by 10kHz
d	increase frequency by 1kHz
c	decrease frequency by 1kHz

f	toggle AFC

About

LoRa gateway to Habitat

Resources

Stars

Watchers

Forks

Releases

No releases published

Packages

No packages published

Languages

  • C 98.9%
  • Other 1.1%