altos/telelco-v0.2-cc1200: Add build for NAR hacked TeleLCO v0.2 board
[fw/altos] / src / test / ao_aprs_test.c
1 /*
2  * Copyright © 2012 Keith Packard <keithp@keithp.com>
3  *
4  * This program is free software; you can redistribute it and/or modify
5  * it under the terms of the GNU General Public License as published by
6  * the Free Software Foundation; either version 2 of the License, or
7  * (at your option) any later version.
8  *
9  * This program is distributed in the hope that it will be useful, but
10  * WITHOUT ANY WARRANTY; without even the implied warranty of
11  * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the GNU
12  * General Public License for more details.
13  *
14  * You should have received a copy of the GNU General Public License along
15  * with this program; if not, write to the Free Software Foundation, Inc.,
16  * 59 Temple Place, Suite 330, Boston, MA 02111-1307 USA.
17  */
18
19 #include <stdio.h>
20 #include <stdlib.h>
21 #include <string.h>
22 #include <stdint.h>
23 #include <stdarg.h>
24
25 #define HAS_GPS 1
26
27 #include <ao_telemetry.h>
28
29 #define AO_GPS_NUM_SAT_MASK     (0xf << 0)
30 #define AO_GPS_NUM_SAT_SHIFT    (0)
31
32 #define AO_GPS_VALID            (1 << 4)
33 #define AO_GPS_RUNNING          (1 << 5)
34 #define AO_GPS_DATE_VALID       (1 << 6)
35 #define AO_GPS_COURSE_VALID     (1 << 7)
36
37 struct ao_telemetry_location ao_gps_data;
38 struct ao_telemetry_satellite ao_gps_tracking_data;
39
40 #define AO_APRS_TEST
41
42 typedef int16_t (*ao_radio_fill_func)(uint8_t *buffer, int16_t len);
43
44 #define DEBUG 0
45 #if DEBUG
46 void
47 ao_aprs_bit(uint8_t bit)
48 {
49         static int      seq = 0;
50         printf ("%6d %d\n", seq++, bit ? 1 : 0);
51 }
52 #else
53 void
54 ao_aprs_bit(uint8_t bit)
55 {
56         putchar (bit ? 0xc0 : 0x40);
57 }
58 #endif
59
60 void
61 ao_radio_send_aprs(ao_radio_fill_func fill);
62
63 static void
64 aprs_bit_debug(uint8_t tx_bit)
65 {
66         fprintf (stderr, "bit %d\n", tx_bit);
67 }
68
69 static void
70 aprs_byte_debug(uint8_t tx_byte)
71 {
72         fprintf(stderr, "byte %02x\n", tx_byte);
73 }
74 #define APRS_BIT_DEBUG(x) aprs_bit_debug(x)
75 #define APRS_BYTE_DEBUG(y) aprs_byte_debug(y)
76
77 #include <ao_aprs.c>
78
79 /*
80  * @section copyright_sec Copyright
81  *
82  * Copyright (c) 2001-2009 Michael Gray, KD7LMO
83
84
85  *
86  *
87  * @section gpl_sec GNU General Public License
88  *
89  *  This program is free software; you can redistribute it and/or modify
90  *  it under the terms of the GNU General Public License as published by
91  *  the Free Software Foundation; either version 2 of the License, or
92  *  (at your option) any later version.
93  *
94  *  This program is distributed in the hope that it will be useful,
95  *  but WITHOUT ANY WARRANTY; without even the implied warranty of
96  *  MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the
97  *  GNU General Public License for more details.
98  *
99  *  You should have received a copy of the GNU General Public License
100  *  along with this program; if not, write to the Free Software
101  *  Foundation, Inc., 59 Temple Place, Suite 330, Boston, MA  02111-1307  USA
102  *
103
104  */
105
106 static void
107 audio_gap(int secs)
108 {
109 #if !DEBUG
110         int     samples = secs * 9600;
111
112         while (samples--)
113                 ao_aprs_bit(0);
114 #endif
115 }
116
117 // This is where we go after reset.
118 int main(int argc, char **argv)
119 {
120 //    audio_gap(1);
121
122     ao_gps_data.latitude = (45.0 + 28.25 / 60.0) * 10000000;
123     ao_gps_data.longitude = (-(122 + 44.2649 / 60.0)) * 10000000;
124     AO_TELEMETRY_LOCATION_SET_ALTITUDE(&ao_gps_data, 84);
125     ao_gps_data.flags = (AO_GPS_VALID|AO_GPS_RUNNING);
126
127     /* Transmit one packet */
128     ao_aprs_send();
129
130     tncBuffer[strlen((char *) tncBuffer) - 2] = '\0';
131     fprintf(stderr, "packet: %s\n", tncBuffer);
132
133     exit(0);
134 }
135
136 void
137 ao_radio_send_aprs(ao_radio_fill_func fill)
138 {
139         int16_t len;
140         uint8_t done = 0;
141         uint8_t buf[16], *b, c;
142         uint8_t bit;
143
144         while (!done) {
145                 len = (*fill)(buf, sizeof (buf));
146                 if (len < 0) {
147                         done = 1;
148                         len = -len;
149                 }
150                 b = buf;
151                 while (len--) {
152                         c = *b++;
153                         for (bit = 0; bit < 8; bit++) {
154                                 ao_aprs_bit(c & 0x80);
155                                 c <<= 1;
156                         }
157                 }
158         }
159 }