MicroAPRS
Important! For new projects, please consider using OpenModem as a platform instead. It is much more powerful, and has none of the limitations of this implementation. For simple projects, MicroAPRS is absolutely still usable, and it is incredibly stable and well-tested in thousands of hours of real-life usage, but have a look at OpenModem as well, since that is what I will be maintaining from now on. No new features or updates will be added to MicroAPRS from here on. I consider it stable and feature-complete for what the hardware is capable of.
MicroAPRS is an APRS firmware for MicroModem. It supports both normal KISS mode, and a simple serial protocol for easy communication with an Arduino, or other MCU.
You can buy a complete modem from my shop, or you can build one yourself pretty easily. Take a look at the documentation in the MicroModem repository for information and getting started guides!
Some features
- Send and receive AX.25 APRS packets
- Full modulation and demodulation in software
- Easy configuration of callsign and path settings
- Flexibility in how received packets are output over serial connection
- Persistent configuration stored in EEPROM
- Shorthand functions for sending location updates and messages, so you don't need to manually create the packets
- Ability to send raw packets
- Support for settings APRS symbols
- Support for power/height/gain info in location updates
- Ability to automatically ACK messages adressed to the modem
- Can run with open squelch
- Supports KISS mode for use with programs on a host computer
KISS mode
When the modem is running in KISS mode, there's really not much more to it than connecting the modem to a computer, opening whatever program you want to use with it, and off you go.
When in KISS mode, the preamble time, tail time, persistence and slot time parameters can be configured by the default KISS commands for these. See KISS.h and KISS.c for more info on the configuration command syntax.
It's important to note that some programs (Xastir, for example) will reset the modem when connecting to it, and then immediately send configuration commands. Depending on your hardware, this might have the unfortunate effect that the configuration commands are sent to the bootloader, instead of the booted firmware. If your program does not allow you to disable resetting or to set a delay for sending the configuration commands, you can manually disable the reset functionality by connecting a resistor of around 100 ohms between the VCC and DTR pins. This will ensure that the modem is not reset, even if the host program sends a reset command.
Modem control - SimpleSerial
If you want to use the SimpleSerial protocol, here's how to control the APRS modem over a serial connection. The modem accepts a variety of commands for setting options and sending packets. Generally a command starts with one or more characters defining the command, and then whatever data is needed to set the options for that command. Here's a list of the currently available commands:
Serial commands
Command | Description |
---|---|
!<data> | Send raw packet |
@<cmt> | Send location update (cmt = optional comment) |
#<msg> | Send APRS message |
 |  |
c<call> | Set your callsign |
d<call> | Set destination callsign |
1<call> | Set PATH1 callsign |
2<call> | Set PATH2 callsign |
 |  |
sc<ssid> | Set your SSID |
sd<ssid> | Set destination SSID |
s1<ssid> | Set PATH1 SSID |
s2<ssid> | Set PATH2 SSID |
 |  |
lla<LAT> | Set latitude (NMEA-format, eg 4903.50N) |
llo<LON> | Set latitude (NMEA-format, eg 07201.75W) |
lp<0-9> | Set TX power info |
lh<0-9> | Set antenna height info |
lg<0-9> | Set antenna gain info |
ld<0-9> | Set antenna directivity info |
ls<sym> | Select symbol |
lt<s/a> | Select symbol table (standard/alternate) |
 |  |
mc<call> | Set message recipient callsign |
ms<ssid> | Set message recipient SSID |
mr<ssid> | Retry last message |
ma<1/0> | Automatic message ACK on/off |
 |  |
ps<1/0> | Print SRC on/off |
pd<1/0> | Print DST on/off |
pp<1/0> | Print PATH on/off |
pm<1/0> | Print DATA on/off |
pi<1/0> | Print INFO on/off |
v<1/0> | Verbose mode on/off |
V<1/0> | Silent mode on/off |
 |  |
w<XXX> | Set preamble in ms |
W<XXX> | Set TX tail in ms |
 |  |
S | Save configuration |
L | Load configuration |
C | Clear configuration |
H | Print configuration |
Examples
To set your callsign to XX1YYY-5, and then save the configuration, send these three commands:
cXX1YYY
sc5
S
To send an APRS message to ZZ5ABC-1 with the content "Hi there!", send these commands:
mcZZ5ABC
ms1
# Hi there!
To send a location update, with the comment "MicroAPRS", you can do something like this:
lla5230.70N
llo01043.70E
@MicroAPRS
To send an APRS message to ZZ5ABC-1 with the content "Hi there!", using a raw packet, send this command:
!:ZZ5ABC-1 :Hi there!{01
Here's an example of how to send a location update with power, height and gain information, using a raw packet:
!=5230.70N/01043.70E-PHG2410MicroAPRS
EEPROM Settings
When saving the configuration, it is written to EEPROM, so it will persist between poweroffs. If a configuration has been stored, it will automatically be loaded when the modem powers up. The configuration can be cleared by sending the "clear configuration" command (C
).
Serial Connection
To connect to the modem use 9600 baud, 8N1 serial. By default, the firmware uses time-sensitive input, which means that it will buffer serial data as it comes in, and when it has received no data for a few milliseconds, it will start interpreting whatever it has received. This means you need to set your serial terminal program to not send data for every keystroke, but only on new-line, or pressing send or whatever. If you do not want this behaviour, you can compile the firmware with the DEBUG flag set, which will make the modem wait for a new-line character before interpreting the received data. I would generally advise against this though, since it means that you cannot have newline characters in whatever data you want to send!
The project has been implemented in your normal C with makefile style, and uses AVR Libc. The firmware is compatible with Arduino-based products, although it was not written in the Arduino IDE.
Visit my site for questions, comments and other details.
Support Me
If you have benefited from this project, you can help support the continued development of open, free and private communications systems by donating via one of the following channels:
- Ethereum: 0x81F7B979fEa6134bA9FD5c701b3501A2e61E897a
- Bitcoin: 3CPmacGm34qYvR6XWLVEJmi2aNe3PZqUuq
- Ko-Fi: https://ko-fi.com/markqvist