summaryrefslogtreecommitdiff
path: root/src/test/ao_aprs_test.c
diff options
context:
space:
mode:
authorKeith Packard <keithp@keithp.com>2012-12-05 22:23:46 -0800
committerKeith Packard <keithp@keithp.com>2012-12-05 22:23:46 -0800
commit74969483736381858484dca9ebb528d9d2d73f5b (patch)
tree0981c6a8333e71adb7ab5ff2e9c16d9cadb0970b /src/test/ao_aprs_test.c
parent933d654ec917d9794e87407a7e579438bb738d54 (diff)
altos: Start restructuring APRS code to create and send packets
Signed-off-by: Keith Packard <keithp@keithp.com>
Diffstat (limited to 'src/test/ao_aprs_test.c')
-rw-r--r--src/test/ao_aprs_test.c52
1 files changed, 48 insertions, 4 deletions
diff --git a/src/test/ao_aprs_test.c b/src/test/ao_aprs_test.c
index 93dab577..d350ca0d 100644
--- a/src/test/ao_aprs_test.c
+++ b/src/test/ao_aprs_test.c
@@ -25,6 +25,27 @@
#define AO_APRS_TEST
+typedef int16_t (*ao_radio_fill_func)(uint8_t *buffer, int16_t len);
+
+#define DEBUG 0
+#if DEBUG
+void
+ao_aprs_bit(uint8_t bit)
+{
+ static int seq = 0;
+ printf ("%6d %d\n", seq++, bit ? 1 : 0);
+}
+#else
+void
+ao_aprs_bit(uint8_t bit)
+{
+ putchar (bit ? 0xc0 : 0x40);
+}
+#endif
+
+void
+ao_radio_send_lots(ao_radio_fill_func fill);
+
#include <ao_aprs.c>
/*
@@ -57,10 +78,12 @@
static void
audio_gap(int secs)
{
+#if !DEBUG
int samples = secs * 9600;
while (samples--)
- putchar(0x7f);
+ ao_aprs_bit(0);
+#endif
}
// This is where we go after reset.
@@ -76,6 +99,27 @@ int main(int argc, char **argv)
exit(0);
}
-
-
-
+void
+ao_radio_send_lots(ao_radio_fill_func fill)
+{
+ int16_t len;
+ uint8_t done = 0;
+ uint8_t buf[16], *b, c;
+ uint8_t bit;
+
+ while (!done) {
+ len = (*fill)(buf, sizeof (buf));
+ if (len < 0) {
+ done = 1;
+ len = -len;
+ }
+ b = buf;
+ while (len--) {
+ c = *b++;
+ for (bit = 0; bit < 8; bit++) {
+ ao_aprs_bit(c & 0x80);
+ c <<= 1;
+ }
+ }
+ }
+}