Skip to main content

Garmin SL40 ATC VHF Radio Serial Protocol in Bash

The Garmin SL30 and SL40 protocols are used by most aircraft and marine VHF radios.  These radios are very simple AM devices and basically one only needs to set the frequency.

The Emergency/Setup channel is 121.5 MHz.  Don't use it for testing...

Here is a Bash script that will compute a SL40 frequency message complete with its arithmetic checksum, using the bc calculator:

#! /bin/bash
echo Garmin SL40 ATC Radio Protocol
echo

# Set Active Frequency Message
HDR='$PMRRC'    # Header
IDH='0'        # ID
IDL='0'       
MHZ='119'    # 118 to 136 MHz
KHZ='100'    # multiples of 25 kHz
MOD='N'        # N=normal

SUM=0    # Arithmetic Checksum
MD=0    # MHZ scaled to ASCII decimal value
MA=""    # MHZ in ASCII character
KD=0    # KHZ scaled to ASCII decimal value
KA=""    # KHZ in ASCII character
MODD="" # MOD in ASCII decimal value
IDHD="" # ID high ASCII decimal value
IDLD="" # ID low ASCII decimal value
SUMH="" # Checksum as two digit Hex


# Example: "Set ATC radio to 119.100 MHz Normal"
# '$PMRRC00G4N29\r\n'

if [ -n "$1" ]; then
MHZ=$(echo "$1" | cut -d "." -f 1)   
KHZ=$(echo "$1" | cut -d "." -f 2)
echo "Frequency=$MHZ.$KHZ"
echo

echo "Set serial port USB0 to 9600N81"
stty -F /dev/ttyUSB0 raw
stty -F /dev/ttyUSB0 9600
echo

echo Calculate frequency characters
MD=$(echo "$MHZ - 48" | bc)
MA=$(printf \\$(printf "%o" $MD))
KD=$(echo "$KHZ - 48" | bc)
KA=$(printf \\$(printf "%o" $KD))
echo m=$MA
echo k=$KA
echo

echo Calculate checksum
IDHD=$(printf "%d" "'$IDH")
IDLD=$(printf "%d" "'$IDL")
MODD=$(printf "%d" "'$MOD")
SUM=$(echo "$IDHD + $IDLD + $MD + $KD + $MODD" | bc)
SUM=$(echo "$SUM % 256" | bc)
SUMH=$(printf "%02x" "$SUM")
echo SUMH=$SUMH
echo

echo "Frequency Message = $HDR$IDH$IDL$MA$KA$MOD$SUMH"
echo "$HDR$IDH$IDL$MA$KA$MOD$SUMH" > /dev/ttyUSB0
echo

echo "La Voila!"
exit 1

fi
echo Example: atcfreq 123.450
exit 0


The above script will take 119.100 MHz and output the message '$PMRRC00G4N29' to the screen and to the serial port.


Why on earth do I use Bash for this?  Because I'm a masochist and love to fight the Bash automatic type conversions...  

All Linux/UNIX machines have Bash (and Windows has Cygwin), therefore this is an easy way to debug and test any and all black boxes in a lab setting.

Modify at your peril!

Comments

  1. This is long ago!
    The minus 48 converts the character from ASCII to a numerical value.
    See this table https://www.asciitable.com/
    Note that "0" == 48 decimal
    So there is an offset of 48 for the numbers in the ASCII table.

    ReplyDelete
  2. Some googling will find a manual with the serial protocol description, for example this one: http://www.aeroelectric.com/Installation_Data/Garmin/SL30_IM.pdf

    ReplyDelete

Post a Comment

On topic comments are welcome. Junk will be deleted.

Popular posts from this blog

Parasitic Quadrifilar Helical Antenna

This article was reprinted in OSCAR News, March 2018:  http://www.amsat-uk.org If you want to receive Satellite Weather Pictures , then you need a decent antenna, otherwise you will receive more noise than picture. For polar orbit satellites, one needs an antenna with a mushroom shaped radiation pattern .  It needs to have strong gain towards the horizon where the satellites are distant, less gain upwards where they are close and as little as possible downwards, which would be wasted and a source of noise.  Most satellites are spin stabilized and therefore the antenna also needs circular polarization, otherwise the received signal will flutter as the antennas rotate through nulls. The helical antenna, first proposed by Kraus in 1948, is the natural solution to circular polarized satellite communications.  It is a simple twisted wire - there seems to be nothing to it.  Various papers have been published on helix antennas, so the operation is pretty well ...

Unlock CRA PDF Forms

Unlock Canada Revenue Agency PDF Forms It appears that there is a relatively new PDF feature to prevent casual copying and saving of a file and that some programs save PDF files with these foolish features active by default.  Many forms from the Canada Revenue Agency are locked in this way, which makes it difficult to do one's taxes, since one can fill the form, but cannot save it.  One can only print the form.  It should be possible to print to a file or export it to a new PDF file, but it is far better to reset the annoying anti-taxpayer flags, since the 'printed' form cannot be edited easily any more and I always manage to make a mistake or three that need to be corrected after review. If there is a Linux (virtual) machine handy, install qpdf and use it to reset the silly flags: $ su - password # dnf update # dnf install qpdf # exit $ qpdf --decrypt lockedfile.pdf unlockedfile.pdf One doesn't need a password to unlock these flags, so the fix is instant. La voila! He...

To C or not to C, That is the Question

As most would know, the Kernighan and Ritchie C Programming Language is an improved version of B, which is a simplified version of BCPL, which is derived from ALGOL, which is the Ur computer language that started the whole madness, when Adam needed an operating system for his Abacus, to count Eve's apples in the garden of Eden in Iraq.  The result is that C is my favourite, most hated computer language , which I use for everything. At university, I learned FORTRAN with punch cards on a Sperry-Univac, in order to run SPICE, to simulate an operational amplifier.  Computers rapidly lost their glamour after that era! Nobody taught me C.  I bought the book and figured it out myself. Over time, I wrote a couple of assemblers, a linker-locator, various low level debuggers and schedulers and I even fixed a bug in a C compiler - not because I wanted to, but because I had to, to get the job done!   Much of my software work was down in the weeds with DSP and radio modems...