Skip to content

Commit 7125b5b

Browse files
committed
Rewrite, test, and document hamlib interface for PTT.
modified: audio.h modified: config.c modified: direwolf.c modified: man1/direwolf.1 modified: ptt.c
1 parent c6bff39 commit 7125b5b

File tree

5 files changed

+172
-152
lines changed

5 files changed

+172
-152
lines changed

audio.h

+3-1
Original file line numberDiff line numberDiff line change
@@ -182,6 +182,7 @@ struct audio_s {
182182
ptt_method_t ptt_method; /* none, serial port, GPIO, LPT, HAMLIB. */
183183

184184
char ptt_device[20]; /* Serial device name for PTT. e.g. COM1 or /dev/ttyS0 */
185+
/* Also used for HAMLIB. Could be host:port when model is 1. */
185186

186187
ptt_line_t ptt_line; /* Control line when using serial port. PTT_LINE_RTS, PTT_LINE_DTR. */
187188
ptt_line_t ptt_line2; /* Optional second one: PTT_LINE_NONE when not used. */
@@ -195,7 +196,8 @@ struct audio_s {
195196
int ptt_invert2; /* Invert the secondary output. */
196197

197198
#ifdef USE_HAMLIB
198-
int ptt_rig; /* HAMLib rig. */
199+
200+
int ptt_model; /* HAMLIB model. -1 for AUTO. 2 for rigctld. Others are radio model. */
199201
#endif
200202

201203
} octrl[NUM_OCTYPES];

config.c

+35-86
Original file line numberDiff line numberDiff line change
@@ -1,7 +1,7 @@
11
//
22
// This file is part of Dire Wolf, an amateur radio packet TNC.
33
//
4-
// Copyright (C) 2011, 2012, 2013, 2014, 2015 John Langner, WB2OSZ
4+
// Copyright (C) 2011, 2012, 2013, 2014, 2015, 2016 John Langner, WB2OSZ
55
//
66
// This program is free software: you can redistribute it and/or modify
77
// it under the terms of the GNU General Public License as published by
@@ -46,9 +46,6 @@
4646
#include <gps.h> /* for DEFAULT_GPSD_PORT (2947) */
4747
#endif
4848

49-
#ifdef USE_HAMLIB
50-
#include <hamlib/rig.h>
51-
#endif
5249

5350
#include "ax25_pad.h"
5451
#include "textcolor.h"
@@ -612,12 +609,6 @@ void config_init (char *fname, struct audio_s *p_audio_config,
612609
int adevice;
613610
int m;
614611

615-
#if USE_HAMLIB
616-
RIG *rig;
617-
int rigs = 0;
618-
#endif
619-
620-
621612
#if DEBUG
622613
text_color_set(DW_COLOR_DEBUG);
623614
dw_printf ("config_init ( %s )\n", fname);
@@ -1460,6 +1451,12 @@ void config_init (char *fname, struct audio_s *p_audio_config,
14601451
* xxx serial-port [-]rts-or-dtr [ [-]rts-or-dtr ]
14611452
* xxx GPIO [-]gpio-num
14621453
* xxx LPT [-]bit-num
1454+
* PTT RIG model port
1455+
* PTT RIG AUTO port
1456+
*
1457+
* When model is 2, port would host:port like 127.0.0.1:4532
1458+
* Otherwise, port would be a serial port like /dev/ttyS0
1459+
*
14631460
*
14641461
* Applies to most recent CHANNEL command.
14651462
*/
@@ -1544,16 +1541,41 @@ void config_init (char *fname, struct audio_s *p_audio_config,
15441541
}
15451542
else if (strcasecmp(t, "RIG") == 0) {
15461543
#ifdef USE_HAMLIB
1547-
p_audio_config->achan[channel].octrl[ot].ptt_method = PTT_METHOD_HAMLIB;
15481544

15491545
t = split(NULL,0);
15501546
if (t == NULL) {
15511547
text_color_set(DW_COLOR_ERROR);
1552-
dw_printf ("Config file line %d: Missing RIG number.\n", line);
1548+
dw_printf ("Config file line %d: Missing model number for hamlib.\n", line);
15531549
continue;
15541550
}
1551+
if (strcasecmp(t, "AUTO") == 0) {
1552+
p_audio_config->achan[channel].octrl[ot].ptt_model = -1;
1553+
}
1554+
else {
1555+
int n = atoi(t);
1556+
if (n < 1 || n > 9999) {
1557+
text_color_set(DW_COLOR_ERROR);
1558+
dw_printf ("Config file line %d: Unreasonable model number %d for hamlib.\n", line, n);
1559+
continue;
1560+
}
1561+
p_audio_config->achan[channel].octrl[ot].ptt_model = n;
1562+
}
1563+
1564+
t = split(NULL,0);
1565+
if (t == NULL) {
1566+
text_color_set(DW_COLOR_ERROR);
1567+
dw_printf ("Config file line %d: Missing port for hamlib.\n", line);
1568+
continue;
1569+
}
1570+
strlcpy (p_audio_config->achan[channel].octrl[ot].ptt_device, t, sizeof(p_audio_config->achan[channel].octrl[ot].ptt_device));
1571+
1572+
t = split(NULL,0);
1573+
if (t != NULL) {
1574+
text_color_set(DW_COLOR_ERROR);
1575+
dw_printf ("Config file line %d: %s was not expected after model & port for hamlib.\n", line, t);
1576+
}
15551577

1556-
p_audio_config->achan[channel].octrl[ot].ptt_rig = atoi(t);
1578+
p_audio_config->achan[channel].octrl[ot].ptt_method = PTT_METHOD_HAMLIB;
15571579

15581580
#else
15591581
text_color_set(DW_COLOR_ERROR);
@@ -1691,79 +1713,6 @@ void config_init (char *fname, struct audio_s *p_audio_config,
16911713
}
16921714
}
16931715

1694-
/*
1695-
* RIG - HAMLib rig configuration.
1696-
*
1697-
* xxx port model
1698-
*
1699-
* For example a Yeasu FT-817 on /dev/ttyUSB0:
1700-
* RIG /dev/ttyUSB0 120
1701-
*
1702-
* For example rigctld on localhost:
1703-
* RIG 127.0.0.1:4532 2
1704-
*/
1705-
1706-
else if (strcasecmp(t, "RIG") == 0) {
1707-
#ifdef USE_HAMLIB
1708-
int n;
1709-
hamlib_port_t port;
1710-
rig_model_t rig_model;
1711-
1712-
if (rigs == MAX_RIGS) {
1713-
text_color_set(DW_COLOR_ERROR);
1714-
dw_printf ("Config file line %d: Maximum number of rigs reached.\n", line);
1715-
continue;
1716-
}
1717-
1718-
t = split(NULL,0);
1719-
if (t == NULL) {
1720-
text_color_set(DW_COLOR_ERROR);
1721-
dw_printf ("Config file line %d: Missing port, model[, key=value].\n",
1722-
line);
1723-
continue;
1724-
}
1725-
1726-
strncpy (port.pathname, t, FILPATHLEN - 1);
1727-
1728-
t = split(NULL,0);
1729-
if (t == NULL) {
1730-
text_color_set(DW_COLOR_ERROR);
1731-
dw_printf ("Config file line %d: Missing model[, key=value]\n", line);
1732-
continue;
1733-
}
1734-
1735-
if (strcasecmp(t, "AUTO") == 0) {
1736-
rig_load_all_backends();
1737-
rig_model = rig_probe(&port);
1738-
}
1739-
else {
1740-
rig_model = atoi(t);
1741-
}
1742-
1743-
rig = rig_init(rig_model);
1744-
if (!rig) {
1745-
text_color_set(DW_COLOR_ERROR);
1746-
dw_printf ("Config file line %d: Unknown rig %d, please check riglist.h.\n", line, rig_model);
1747-
continue;
1748-
}
1749-
1750-
strncpy (rig->state.rigport.pathname, port.pathname, FILPATHLEN - 1);
1751-
n = rig_open(rig);
1752-
if (n != RIG_OK) {
1753-
text_color_set(DW_COLOR_ERROR);
1754-
dw_printf ("Config file line %d: Rig open error %d: %s\n", line, n, rigerror(n));
1755-
continue;
1756-
}
1757-
1758-
p_audio_config->rig[rigs++] = rig;
1759-
p_audio_config->rigs = rigs;
1760-
1761-
#else
1762-
text_color_set(DW_COLOR_ERROR);
1763-
dw_printf ("Config file line %d: RIG is only available when hamlib support is enabled.\n", line);
1764-
continue;
1765-
#endif
1766-
}
17671716

17681717
/*
17691718
* DWAIT - Extra delay for receiver squelch.

direwolf.c

+19-3
Original file line numberDiff line numberDiff line change
@@ -67,6 +67,10 @@
6767
#include <netdb.h>
6868
#endif
6969

70+
#if USE_HAMLIB
71+
#include <hamlib/rig.h>
72+
#endif
73+
7074

7175
#define DIREWOLF_C 1
7276

@@ -185,7 +189,9 @@ int main (int argc, char *argv[])
185189
int d_g_opt = 0; /* "-d g" option for GPS. Can be repeated for more detail. */
186190
int d_o_opt = 0; /* "-d o" option for output control such as PTT and DCD. */
187191
int d_i_opt = 0; /* "-d i" option for IGate. Repeat for more detail */
188-
192+
#if USE_HAMLIB
193+
int d_h_opt = 0; /* "-d h" option for hamlib debugging. Repeat for more detail */
194+
#endif
189195

190196
strlcpy(l_opt, "", sizeof(l_opt));
191197
strlcpy(P_opt, "", sizeof(P_opt));
@@ -230,8 +236,8 @@ int main (int argc, char *argv[])
230236

231237
text_color_init(t_opt);
232238
text_color_set(DW_COLOR_INFO);
233-
//dw_printf ("Dire Wolf version %d.%d (%s) Beta Test\n", MAJOR_VERSION, MINOR_VERSION, __DATE__);
234-
dw_printf ("Dire Wolf DEVELOPMENT version %d.%d %s (%s)\n", MAJOR_VERSION, MINOR_VERSION, "K", __DATE__);
239+
dw_printf ("Dire Wolf version %d.%d (%s) Beta Test\n", MAJOR_VERSION, MINOR_VERSION, __DATE__);
240+
//dw_printf ("Dire Wolf DEVELOPMENT version %d.%d %s (%s)\n", MAJOR_VERSION, MINOR_VERSION, "K", __DATE__);
235241
//dw_printf ("Dire Wolf version %d.%d\n", MAJOR_VERSION, MINOR_VERSION);
236242

237243
#if defined(ENABLE_GPSD) || defined(USE_HAMLIB)
@@ -453,6 +459,9 @@ int main (int argc, char *argv[])
453459
case 'i': d_i_opt++; break;
454460
#if AX25MEMDEBUG
455461
case 'm': ax25memdebug_set(); break; // Track down memory leak. Not documented.
462+
#endif
463+
#if USE_HAMLIB
464+
case 'h': d_h_opt++; break; // Hamlib verbose level.
456465
#endif
457466
default: break;
458467
}
@@ -527,6 +536,10 @@ int main (int argc, char *argv[])
527536
* Possibly override some by command line options.
528537
*/
529538

539+
#if USE_HAMLIB
540+
rig_set_debug(d_h_opt);
541+
#endif
542+
530543
symbols_init ();
531544

532545
config_init (config_file, &audio_config, &digi_config, &tt_config, &igate_config, &misc_config);
@@ -1067,6 +1080,9 @@ static void usage (char **argv)
10671080
dw_printf (" t t = Tracker beacon.\n");
10681081
dw_printf (" o o = output controls such as PTT and DCD.\n");
10691082
dw_printf (" i i = IGate.\n");
1083+
#if USE_HAMLIB
1084+
dw_printf (" h h = hamlib increase verbose level.\n");
1085+
#endif
10701086
dw_printf (" -q Quiet (suppress output) options:\n");
10711087
dw_printf (" h h = Heard line with the audio level.\n");
10721088
dw_printf (" d d = Decoding of APRS packets.\n");

man1/direwolf.1

+2
Original file line numberDiff line numberDiff line change
@@ -84,6 +84,8 @@ t = Tracker beacon.
8484
o = Output controls such as PTT and DCD.
8585
.P
8686
i = IGate
87+
.P
88+
h = Hamlib verbose level. Repeat for more.
8789
.RE
8890
.RE
8991
.PD

0 commit comments

Comments
 (0)