Skip to content

Commit 6f95752

Browse files
committed
Merge branch 'feature/dns-sd' of git://github.com/hessu/direwolf into hessu-feature/dns-sd
2 parents 085e837 + feb1034 commit 6f95752

14 files changed

+545
-21
lines changed

CMakeLists.txt

+9
Original file line numberDiff line numberDiff line change
@@ -157,6 +157,10 @@ elseif(APPLE)
157157
set(CMAKE_MACOSX_RPATH ON)
158158
message(STATUS "RPATH support: ${CMAKE_MACOSX_RPATH}")
159159

160+
# just blindly enable dns-sd
161+
set(USE_MACOS_DNSSD ON)
162+
set(CMAKE_C_FLAGS "${CMAKE_C_FLAGS} -DUSE_MACOS_DNSSD")
163+
160164
elseif (WIN32)
161165
if(NOT VS2015 AND NOT VS2017)
162166
message(FATAL_ERROR "You must use Microsoft Visual Studio 2015 or 2017 as compiler")
@@ -277,6 +281,11 @@ if(LINUX)
277281
set(CMAKE_C_FLAGS "${CMAKE_C_FLAGS} -DUSE_CM108")
278282
endif()
279283

284+
find_package(Avahi)
285+
if(AVAHI_CLIENT_FOUND)
286+
set(CMAKE_C_FLAGS "${CMAKE_C_FLAGS} -DUSE_AVAHI_CLIENT")
287+
endif()
288+
280289
elseif (NOT WIN32 AND NOT CYGWIN)
281290
find_package(Portaudio REQUIRED)
282291
if(PORTAUDIO_FOUND)

README.md

+8-5
Original file line numberDiff line numberDiff line change
@@ -1,4 +1,4 @@
1-
1+
22
# Dire Wolf #
33

44
### Decoded Information from Radio Emissions for Windows Or Linux Fans ###
@@ -39,6 +39,7 @@ It can also be used as a virtual TNC for other applications such as [APRSIS32](h
3939
Send periodic beacons to provide information to others. For tracking the location is provided by a GPS receiver.
4040
Build your own telemetry applications with the toolkit.
4141

42+
4243
- **APRStt Gateway.**
4344

4445
Very few hams have portable equipment for APRS but nearly everyone has a handheld radio that can send DTMF tones. APRStt allows a user, equipped with only DTMF (commonly known as Touch Tone) generation capability, to enter information into the global APRS data network. Responses can be sent by Morse Code or synthesized speech.
@@ -130,15 +131,17 @@ On Debian / Ubuntu / Raspbian / Raspberry Pi OS:
130131
sudo apt-get install cmake
131132
sudo apt-get install libasound2-dev
132133
sudo apt-get install libudev-dev
134+
sudo apt-get install libavahi-client-dev
133135

134136
Or on Red Hat / Fedora / CentOS:
135137

136-
sudo yum install git
137-
sudo yum install gcc
138-
sudo yum install gcc-c++
139-
sudo yum install make
138+
sudo yum install git
139+
sudo yum install gcc
140+
sudo yum install gcc-c++
141+
sudo yum install make
140142
sudo yum install alsa-lib-devel
141143
sudo yum install libudev-devel
144+
sudo yum install avahi-devel
142145

143146
CentOS 6 & 7 currently have cmake 2.8 but we need 3.1 or later.
144147
First you need to enable the EPEL repository. Add a symlink if you don't already have the older version and want to type cmake rather than cmake3.

cmake/modules/FindAvahi.cmake

+19
Original file line numberDiff line numberDiff line change
@@ -0,0 +1,19 @@
1+
2+
find_library(AVAHI_COMMON_LIBRARY NAMES avahi-common PATHS ${PC_AVAHI_CLIENT_LIBRARY_DIRS})
3+
if(AVAHI_COMMON_LIBRARY)
4+
set(AVAHI_COMMON_FOUND TRUE)
5+
endif()
6+
7+
find_library(AVAHI_CLIENT_LIBRARY NAMES avahi-client PATHS ${PC_AVAHI_CLIENT_LIBRARY_DIRS})
8+
if(AVAHI_CLIENT_LIBRARY)
9+
set(AVAHI_CLIENT_FOUND TRUE)
10+
endif()
11+
12+
FIND_PACKAGE_HANDLE_STANDARD_ARGS(AVAHI DEFAULT_MSG AVAHI_COMMON_FOUND AVAHI_CLIENT_FOUND)
13+
14+
if (AVAHI_FOUND)
15+
set(AVAHI_INCLUDE_DIRS ${AVAHI_UI_INCLUDE_DIR})
16+
set(AVAHI_LIBRARIES ${AVAHI_COMMON_LIBRARY} ${AVAHI_CLIENT_LIBRARY})
17+
endif()
18+
19+
mark_as_advanced(AVAHI_INCLUDE_DIRS AVAHI_LIBRARIES)

doc/README.md

+18-16
Original file line numberDiff line numberDiff line change
@@ -1,4 +1,4 @@
1-
# Documentation for Dire Wolf #
1+
# Documentation for Dire Wolf #
22

33
Click on the document name to view in your web browser or the link following to download the PDF file.
44

@@ -11,11 +11,11 @@ Brief summary of packet radio / APRS history and the capbilities of Dire Wolf.
1111

1212
## Essential Reading ##
1313

14-
- [**User Guide**](User-Guide.pdf) [ [*download*](../../../raw/dev/doc/User-Guide.pdf) ]
14+
- [**User Guide**](User-Guide.pdf) [ [*download*](../../../raw/master/doc/User-Guide.pdf) ]
1515

1616
This is your primary source of information about installation, operation, and configuration.
1717

18-
- [**Raspberry Pi APRS**](Raspberry-Pi-APRS.pdf) [ [*download*](../../../raw/dev/doc/Raspberry-Pi-APRS.pdf) ]
18+
- [**Raspberry Pi APRS**](Raspberry-Pi-APRS.pdf) [ [*download*](../../../raw/master/doc/Raspberry-Pi-APRS.pdf) ]
1919

2020
The Raspberry Pi has some special considerations that
2121
make it different from other generic Linux systems.
@@ -46,38 +46,40 @@ These dive into more detail for specialized topics or typical usage scenarios.
4646

4747
- [**Successful APRS IGate Operation**](Successful-APRS-IGate-Operation.pdf) [ [*download*](../../../raw/dev/doc/Successful-APRS-IGate-Operation.pdf) ]
4848

49+
4950
Dire Wolf can serve as a gateway between the APRS radio network and APRS-IS servers on the Internet.
5051

5152
This explains how it all works, proper configuration, and troubleshooting.
5253

53-
- [**Bluetooth KISS TNC**](Bluetooth-KISS-TNC.pdf) [ [*download*](../../../raw/dev/doc/Bluetooth-KISS-TNC.pdf) ]
54+
- [**Bluetooth KISS TNC**](Bluetooth-KISS-TNC.pdf) [ [*download*](../../../raw/master/doc/Bluetooth-KISS-TNC.pdf) ]
5455

5556
Eliminate the cable between your TNC and application. Use Bluetooth instead.
5657

57-
- [**APRStt Implementation Notes**](APRStt-Implementation-Notes.pdf) [ [*download*](../../../raw/dev/doc/APRStt-Implementation-Notes.pdf) ]
58+
- [**APRStt Implementation Notes**](APRStt-Implementation-Notes.pdf) [ [*download*](../../../raw/master/doc/APRStt-Implementation-Notes.pdf) ]
5859

5960
Very few hams have portable equipment for APRS but nearly everyone has a handheld radio that can send DTMF tones. APRStt allows a user, equipped with only DTMF (commonly known as Touch Tone) generation capability, to enter information into the global APRS data network.
6061
This document explains how the APRStt concept was implemented in the Dire Wolf application.
61-
- [**APRStt Interface for SARTrack**](APRStt-interface-for-SARTrack.pdf) [ [*download*](../../../raw/dev/doc/APRStt-interface-for-SARTrack.pdf) ]
62+
63+
- [**APRStt Interface for SARTrack**](APRStt-interface-for-SARTrack.pdf) [ [*download*](../../../raw/master/doc/APRStt-interface-for-SARTrack.pdf) ]
6264

6365
This example illustrates how APRStt can be integrated with other applications such as SARTrack, APRSISCE/32, YAAC, or Xastir.
6466

65-
- [**APRStt Listening Example**](APRStt-Listening-Example.pdf) [ [*download*](../../../raw/dev/doc/APRStt-Listening-Example.pdf) ]
67+
- [**APRStt Listening Example**](APRStt-Listening-Example.pdf) [ [*download*](../../../raw/master/doc/APRStt-Listening-Example.pdf) ]
6668

6769

6870
WB4APR described a useful application for the [QIKCOM-2 Satallite Transponder](http://www.tapr.org/pipermail/aprssig/2015-November/045035.html).
6971

7072
Don’t have your own QIKCOM-2 Satellite Transponder? No Problem. You can do the same thing with an ordinary computer and the APRStt gateway built into Dire Wolf. Here’s how.
7173

72-
- [**Raspberry Pi APRS Tracker**](Raspberry-Pi-APRS-Tracker.pdf) [ [*download*](../../../raw/dev/doc/Raspberry-Pi-APRS-Tracker.pdf) ]
74+
- [**Raspberry Pi APRS Tracker**](Raspberry-Pi-APRS-Tracker.pdf) [ [*download*](../../../raw/master/doc/Raspberry-Pi-APRS-Tracker.pdf) ]
7375

7476
Build a tracking device which transmits position from a GPS receiver.
7577

76-
- [**Raspberry Pi SDR IGate**](Raspberry-Pi-SDR-IGate.pdf) [ [*download*](../../../raw/dev/doc/Raspberry-Pi-SDR-IGate.pdf) ]
78+
- [**Raspberry Pi SDR IGate**](Raspberry-Pi-SDR-IGate.pdf) [ [*download*](../../../raw/master/doc/Raspberry-Pi-SDR-IGate.pdf) ]
7779

7880
It's easy to build a receive-only APRS Internet Gateway (IGate) with only a Raspberry Pi and a software defined radio (RTL-SDR) dongle. Here’s how.
7981

80-
- [**APRS Telemetry Toolkit**](APRS-Telemetry-Toolkit.pdf) [ [*download*](../../../raw/dev/doc/APRS-Telemetry-Toolkit.pdf) ]
82+
- [**APRS Telemetry Toolkit**](APRS-Telemetry-Toolkit.pdf) [ [*download*](../../../raw/master/doc/APRS-Telemetry-Toolkit.pdf) ]
8183

8284
Describes scripts and methods to generate telemetry.
8385
Includes a complete example of attaching an analog to
@@ -86,12 +88,12 @@ These dive into more detail for specialized topics or typical usage scenarios.
8688

8789

8890

89-
- [**2400 & 4800 bps PSK for APRS / Packet Radio**](2400-4800-PSK-for-APRS-Packet-Radio.pdf) [ [*download*](../../../raw/dev/doc/2400-4800-PSK-for-APRS-Packet-Radio.pdf) ]
91+
- [**2400 & 4800 bps PSK for APRS / Packet Radio**](2400-4800-PSK-for-APRS-Packet-Radio.pdf) [ [*download*](../../../raw/master/doc/2400-4800-PSK-for-APRS-Packet-Radio.pdf) ]
9092

9193

9294
Double or quadruple your data rate by sending multiple bits at the same time.
9395

94-
- [**Going beyond 9600 baud**](Going-beyond-9600-baud.pdf) [ [*download*](../../../raw/dev/doc/Going-beyond-9600-baud.pdf) ]
96+
- [**Going beyond 9600 baud**](Going-beyond-9600-baud.pdf) [ [*download*](../../../raw/master/doc/Going-beyond-9600-baud.pdf) ]
9597

9698

9799
Why stop at 9600 baud? Go faster if your soundcard and radio can handle it.
@@ -120,7 +122,7 @@ These dive into more detail for specialized topics or typical usage scenarios.
120122

121123
There have been other occasional mentions of merging Ham Radio with the Internet of Things but only ad hoc incompatible narrowly focused applications. Here is a proposal for a standardized more flexible method so different systems can communicate with each other.
122124

123-
- [**A Better APRS Packet Demodulator, part 1, 1200 baud**](A-Better-APRS-Packet-Demodulator-Part-1-1200-baud.pdf) [ [*download*](../../../raw/dev/doc/A-Better-APRS-Packet-Demodulator-Part-1-1200-baud.pdf) ]
125+
- [**A Better APRS Packet Demodulator, part 1, 1200 baud**](A-Better-APRS-Packet-Demodulator-Part-1-1200-baud.pdf) [ [*download*](../../../raw/master/doc/A-Better-APRS-Packet-Demodulator-Part-1-1200-baud.pdf) ]
124126

125127
Sometimes it's a little mystifying why an
126128
APRS / AX.25 Packet TNC will decode some signals
@@ -132,7 +134,7 @@ and a couple things that can be done about it.
132134

133135

134136

135-
- [**A Better APRS Packet Demodulator, part 2, 9600 baud**](A-Better-APRS-Packet-Demodulator-Part-2-9600-baud.pdf) [ [*download*](../../../raw/dev/doc/A-Better-APRS-Packet-Demodulator-Part-2-9600-baud.pdf) ]
137+
- [**A Better APRS Packet Demodulator, part 2, 9600 baud**](A-Better-APRS-Packet-Demodulator-Part-2-9600-baud.pdf) [ [*download*](../../../raw/master/doc/A-Better-APRS-Packet-Demodulator-Part-2-9600-baud.pdf) ]
136138

137139
In the first part of this series we discussed 1200 baud audio frequency shift keying (AFSK). The mismatch
138140
between FM transmitter pre-emphasis and the
@@ -141,13 +143,13 @@ and a couple things that can be done about it.
141143
This makes it more difficult to demodulate them accurately.
142144
9600 baud operation is an entirely different animal. ...
143145

144-
- [**WA8LMF TNC Test CD Results a.k.a. Battle of the TNCs**](WA8LMF-TNC-Test-CD-Results.pdf) [ [*download*](../../../raw/dev/doc/WA8LMF-TNC-Test-CD-Results.pdf) ]
146+
- [**WA8LMF TNC Test CD Results a.k.a. Battle of the TNCs**](WA8LMF-TNC-Test-CD-Results.pdf) [ [*download*](../../../raw/master/doc/WA8LMF-TNC-Test-CD-Results.pdf) ]
145147

146148
How can we compare how well the TNCs perform under real world conditions?
147149
The de facto standard of measurement is the number of packets decoded from [WA8LMF’s TNC Test CD](http://wa8lmf.net/TNCtest/index.htm).
148150
Many have published the number of packets they have been able to decode from this test. Here they are, all gathered in one place, for your reading pleasure.
149151

150-
- [**A Closer Look at the WA8LMF TNC Test CD**](A-Closer-Look-at-the-WA8LMF-TNC-Test-CD.pdf) [ [*download*](../../../raw/dev/doc/A-Closer-Look-at-the-WA8LMF-TNC-Test-CD.pdf) ]
152+
- [**A Closer Look at the WA8LMF TNC Test CD**](A-Closer-Look-at-the-WA8LMF-TNC-Test-CD.pdf) [ [*download*](../../../raw/master/doc/A-Closer-Look-at-the-WA8LMF-TNC-Test-CD.pdf) ]
151153

152154
Here, we take a closer look at some of the frames on the TNC Test CD in hopes of gaining some insights into why some are easily decoded and others are more difficult.
153155
There are a lot of ugly signals out there. Many can be improved by decreasing the transmit volume. Others are just plain weird and you have to wonder how they are being generated.

src/CMakeLists.txt

+13
Original file line numberDiff line numberDiff line change
@@ -109,6 +109,12 @@ if(LINUX)
109109
cm108.c
110110
)
111111
endif()
112+
if(AVAHI_CLIENT_FOUND)
113+
list(APPEND direwolf_SOURCES
114+
dns_sd_common.c
115+
dns_sd_avahi.c
116+
)
117+
endif()
112118
elseif(WIN32 OR CYGWIN) # windows
113119
list(APPEND direwolf_SOURCES
114120
audio_win.c
@@ -124,6 +130,12 @@ if(LINUX)
124130
list(APPEND direwolf_SOURCES
125131
audio_portaudio.c
126132
)
133+
if(USE_MACOS_DNSSD)
134+
list(APPEND direwolf_SOURCES
135+
dns_sd_common.c
136+
dns_sd_macos.c
137+
)
138+
endif()
127139
endif()
128140

129141
add_executable(direwolf
@@ -140,6 +152,7 @@ target_link_libraries(direwolf
140152
${ALSA_LIBRARIES}
141153
${UDEV_LIBRARIES}
142154
${PORTAUDIO_LIBRARIES}
155+
${AVAHI_LIBRARIES}
143156
)
144157

145158
if(WIN32 OR CYGWIN)

src/config.c

+39
Original file line numberDiff line numberDiff line change
@@ -856,6 +856,8 @@ void config_init (char *fname, struct audio_s *p_audio_config,
856856
p_misc_config->enable_kiss_pt = 0; /* -p option */
857857
p_misc_config->kiss_copy = 0;
858858

859+
p_misc_config->dns_sd_enabled = 1;
860+
859861
/* Defaults from http://info.aprs.net/index.php?title=SmartBeaconing */
860862

861863
p_misc_config->sb_configured = 0; /* TRUE if SmartBeaconing is configured. */
@@ -4564,6 +4566,43 @@ void config_init (char *fname, struct audio_s *p_audio_config,
45644566
}
45654567

45664568

4569+
/*
4570+
* DNSSD - Enable or disable (1/0) dns-sd, DNS Service Discovery announcements
4571+
* DNSSDNAME - Set DNS-SD service name, defaults to "Dire Wolf on <hostname>"
4572+
*/
4573+
4574+
else if (strcasecmp(t, "DNSSD") == 0) {
4575+
int n;
4576+
t = split(NULL,0);
4577+
if (t == NULL) {
4578+
text_color_set(DW_COLOR_ERROR);
4579+
dw_printf ("Line %d: Missing integer value for DNSSD command.\n", line);
4580+
continue;
4581+
}
4582+
n = atoi(t);
4583+
if (n == 0 || n == 1) {
4584+
p_misc_config->dns_sd_enabled = n;
4585+
} else {
4586+
p_misc_config->dns_sd_enabled = 0;
4587+
text_color_set(DW_COLOR_ERROR);
4588+
dw_printf ("Line %d: Invalid integer value for DNSSD. Disabling dns-sd.\n", line);
4589+
}
4590+
}
4591+
4592+
else if (strcasecmp(t, "DNSSDNAME") == 0) {
4593+
t = split(NULL, 1);
4594+
if (t == NULL) {
4595+
text_color_set(DW_COLOR_ERROR);
4596+
dw_printf ("Line %d: Missing service name for DNSSDNAME.\n", line);
4597+
continue;
4598+
}
4599+
else {
4600+
strlcpy(p_misc_config->dns_sd_name, t, sizeof(p_misc_config->dns_sd_name));
4601+
}
4602+
}
4603+
4604+
4605+
45674606
/*
45684607
* GPSNMEA - Device name for reading from GPS receiver.
45694608
*/

src/config.h

+3
Original file line numberDiff line numberDiff line change
@@ -88,6 +88,9 @@ struct misc_config_s {
8888

8989
char log_path[80]; /* Either directory or full file name depending on above. */
9090

91+
int dns_sd_enabled; /* DNS Service Discovery announcement enabled. */
92+
char dns_sd_name[64]; /* Name announced on dns-sd; defaults to "Dire Wolf on <hostname>" */
93+
9194
int sb_configured; /* TRUE if SmartBeaconing is configured. */
9295
int sb_fast_speed; /* MPH */
9396
int sb_fast_rate; /* seconds */

src/direwolf.c

+6
Original file line numberDiff line numberDiff line change
@@ -125,6 +125,7 @@
125125
#include "dtime_now.h"
126126
#include "fx25.h"
127127
#include "dwsock.h"
128+
#include "dns_sd_dw.h"
128129

129130

130131
//static int idx_decoded = 0;
@@ -1029,6 +1030,11 @@ int main (int argc, char *argv[])
10291030
server_init (&audio_config, &misc_config);
10301031
kissnet_init (&misc_config);
10311032

1033+
#if (USE_AVAHI_CLIENT|USE_MACOS_DNSSD)
1034+
if (misc_config.kiss_port > 0 && misc_config.dns_sd_enabled)
1035+
dns_sd_announce(&misc_config);
1036+
#endif
1037+
10321038
/*
10331039
* Create a pseudo terminal and KISS TNC emulator.
10341040
*/

0 commit comments

Comments
 (0)