Enable radio monitor by default in teleterra, teledongle and tidongle
authorKeith Packard <keithp@keithp.com>
Thu, 14 May 2009 03:40:42 +0000 (20:40 -0700)
committerKeith Packard <keithp@keithp.com>
Thu, 14 May 2009 03:40:42 +0000 (20:40 -0700)
These ground loads want to monitor the radio constantly, and not require use
of the 'm' command before listening.

Signed-off-by: Keith Packard <keithp@keithp.com>
ao.h
ao_monitor.c
ao_teledongle.c
ao_teleterra.c
ao_tidongle.c

diff --git a/ao.h b/ao.h
index 96dd02d00509ae52761ebe13c718cd5530ff298b..76fc00ce4648a954f673e7cb289b1d8230753768 100644 (file)
--- a/ao.h
+++ b/ao.h
@@ -23,6 +23,9 @@
 #include <string.h>
 #include "cc1111.h"
 
 #include <string.h>
 #include "cc1111.h"
 
+#define TRUE 1
+#define FALSE 0
+
 /* Convert a __data pointer into an __xdata pointer */
 #define DATA_TO_XDATA(a)       ((void __xdata *) ((uint8_t) (a) | 0xff00))
 
 /* Convert a __data pointer into an __xdata pointer */
 #define DATA_TO_XDATA(a)       ((void __xdata *) ((uint8_t) (a) | 0xff00))
 
@@ -775,7 +778,10 @@ void
 ao_monitor(void);
 
 void
 ao_monitor(void);
 
 void
-ao_monitor_init(uint8_t led);
+ao_set_monitor(uint8_t monitoring);
+
+void
+ao_monitor_init(uint8_t led, uint8_t monitoring) __reentrant;
 
 /*
  * ao_stdio.c
 
 /*
  * ao_stdio.c
index 2f6584bc3dc29f7d37e9ea8d42b5ca787d12c32b..6aed581a69b1f6d71a1b597923860f31428c728e 100644 (file)
@@ -61,24 +61,30 @@ ao_monitor(void)
 
 __xdata struct ao_task ao_monitor_task;
 
 
 __xdata struct ao_task ao_monitor_task;
 
+void
+ao_set_monitor(uint8_t monitoring)
+{
+       ao_monitoring = monitoring;
+       ao_wakeup(&ao_monitoring);
+}
+
 static void
 static void
-ao_set_monitor(void)
+set_monitor(void)
 {
        ao_cmd_hex();
 {
        ao_cmd_hex();
-       ao_monitoring = ao_cmd_lex_i != 0;
-       ao_wakeup(&ao_monitoring);
+       ao_set_monitor(ao_cmd_lex_i != 0);
 }
 
 __code struct ao_cmds ao_monitor_cmds[] = {
 }
 
 __code struct ao_cmds ao_monitor_cmds[] = {
-       { 'm',  ao_set_monitor,         "m <0 off, 1 on>                    Enable/disable radio monitoring" },
-       { 0,    ao_set_monitor, NULL },
+       { 'm',  set_monitor,    "m <0 off, 1 on>                    Enable/disable radio monitoring" },
+       { 0,    set_monitor,    NULL },
 };
 
 void
 };
 
 void
-ao_monitor_init(uint8_t monitor_led)
+ao_monitor_init(uint8_t monitor_led, uint8_t monitoring) __reentrant
 {
        ao_monitor_led = monitor_led;
 {
        ao_monitor_led = monitor_led;
-       ao_monitoring = 0;
+       ao_monitoring = monitoring;
        ao_cmd_register(&ao_monitor_cmds[0]);
        ao_add_task(&ao_monitor_task, ao_monitor, "monitor");
 }
        ao_cmd_register(&ao_monitor_cmds[0]);
        ao_add_task(&ao_monitor_task, ao_monitor, "monitor");
 }
index 98163109f955799e3b86ff39b58dda278d563559..67fe76147c5babedbbb813d27f413037ab8459ff 100644 (file)
@@ -32,7 +32,7 @@ main(void)
        ao_timer_init();
        ao_cmd_init();
        ao_usb_init();
        ao_timer_init();
        ao_cmd_init();
        ao_usb_init();
-       ao_monitor_init(AO_LED_GREEN);
+       ao_monitor_init(AO_LED_GREEN, TRUE);
        ao_rssi_init(AO_LED_RED);
        ao_radio_init();
        ao_dbg_init();
        ao_rssi_init(AO_LED_RED);
        ao_radio_init();
        ao_dbg_init();
index ed72cd4bae1f3773df1ec97eea37ddd8ba7d0e9a..ad3e2d9bd96355347079fe4831d3b746fd36c874 100644 (file)
@@ -34,8 +34,7 @@ main(void)
        ao_usb_init();
        ao_serial_init();
        ao_gps_init();
        ao_usb_init();
        ao_serial_init();
        ao_gps_init();
-       ao_monitor_init(AO_LED_GREEN);
-       ao_monitor_init(AO_LED_RED);
+       ao_monitor_init(AO_LED_GREEN, TRUE);
        ao_radio_init();
        ao_dbg_init();
        ao_config_init();
        ao_radio_init();
        ao_dbg_init();
        ao_config_init();
index 4d9a77f76798200e5a4dfb560eb80af3f574c6e3..b068d04563513719eeca79a1ea5688332bc19eee 100644 (file)
@@ -32,7 +32,7 @@ main(void)
        ao_timer_init();
        ao_cmd_init();
        ao_usb_init();
        ao_timer_init();
        ao_cmd_init();
        ao_usb_init();
-       ao_monitor_init(AO_LED_RED);
+       ao_monitor_init(AO_LED_RED, TRUE);
        ao_rssi_init(AO_LED_RED);
        ao_radio_init();
        ao_dbg_init();
        ao_rssi_init(AO_LED_RED);
        ao_radio_init();
        ao_dbg_init();