summaryrefslogtreecommitdiff
path: root/src/product
diff options
context:
space:
mode:
authorKeith Packard <keithp@keithp.com>2013-03-24 15:14:12 -0700
committerKeith Packard <keithp@keithp.com>2013-05-07 20:07:52 -0700
commit4551be8b03a795ece94fd303a1f556c63c0a0096 (patch)
treebd79284e6c94b5ef1dd61cb9a3b55a743d399124 /src/product
parent6dea353e732b6e19586c844796bc3bb848cc92f8 (diff)
altos: Call ao_task_init before initializing any drivers
When using task queues, the sleep queues must be initialized before any invocation of ao_wakeup or the OS will crash. Just make sure ao_task_init is always invoked early in the task process to get that done. Signed-off-by: Keith Packard <keithp@keithp.com>
Diffstat (limited to 'src/product')
-rw-r--r--src/product/ao_teledongle.c2
-rw-r--r--src/product/ao_telelaunch.c2
-rw-r--r--src/product/ao_telemetrum.c2
-rw-r--r--src/product/ao_telemini.c2
-rw-r--r--src/product/ao_telenano.c2
-rw-r--r--src/product/ao_telepyro.c2
-rw-r--r--src/product/ao_telescience.c2
-rw-r--r--src/product/ao_teleterra.c2
-rw-r--r--src/product/ao_teleterra_0_2.c2
-rw-r--r--src/product/ao_test.c2
-rw-r--r--src/product/ao_tidongle.c3
11 files changed, 23 insertions, 0 deletions
diff --git a/src/product/ao_teledongle.c b/src/product/ao_teledongle.c
index 25ebe73e..8bfd8b84 100644
--- a/src/product/ao_teledongle.c
+++ b/src/product/ao_teledongle.c
@@ -26,6 +26,8 @@ main(void)
/* Turn on the LED until the system is stable */
ao_led_init(LEDS_AVAILABLE);
ao_led_on(AO_LED_RED);
+ ao_task_init();
+
ao_timer_init();
ao_cmd_init();
ao_usb_init();
diff --git a/src/product/ao_telelaunch.c b/src/product/ao_telelaunch.c
index b6e4bfc1..dde66090 100644
--- a/src/product/ao_telelaunch.c
+++ b/src/product/ao_telelaunch.c
@@ -27,6 +27,8 @@ main(void)
ao_led_init(LEDS_AVAILABLE);
ao_led_on(AO_LED_RED);
+ ao_task_init();
+
ao_timer_init();
ao_adc_init();
ao_beep_init();
diff --git a/src/product/ao_telemetrum.c b/src/product/ao_telemetrum.c
index ea77f5af..221498d6 100644
--- a/src/product/ao_telemetrum.c
+++ b/src/product/ao_telemetrum.c
@@ -42,6 +42,8 @@ main(void)
while (P1_3 == 0)
;
}
+ ao_task_init();
+
ao_timer_init();
ao_adc_init();
ao_beep_init();
diff --git a/src/product/ao_telemini.c b/src/product/ao_telemini.c
index 21551ee9..a0d8e18a 100644
--- a/src/product/ao_telemini.c
+++ b/src/product/ao_telemini.c
@@ -46,6 +46,8 @@ main(void)
;
}
+ ao_task_init();
+
ao_timer_init();
ao_adc_init();
ao_cmd_init();
diff --git a/src/product/ao_telenano.c b/src/product/ao_telenano.c
index d91983d0..77750efd 100644
--- a/src/product/ao_telenano.c
+++ b/src/product/ao_telenano.c
@@ -28,6 +28,8 @@ main(void)
ao_led_init(LEDS_AVAILABLE);
ao_led_on(AO_LED_RED);
+ ao_task_init();
+
ao_timer_init();
ao_adc_init();
ao_cmd_init();
diff --git a/src/product/ao_telepyro.c b/src/product/ao_telepyro.c
index 79454fb7..6f09be64 100644
--- a/src/product/ao_telepyro.c
+++ b/src/product/ao_telepyro.c
@@ -25,6 +25,8 @@ main(void)
PORTE |= (1 << 6);
DDRE |= (1 << 6);
+ ao_task_init();
+
ao_avr_stdio_init();
ao_timer_init();
ao_cmd_init();
diff --git a/src/product/ao_telescience.c b/src/product/ao_telescience.c
index d448d318..2888c266 100644
--- a/src/product/ao_telescience.c
+++ b/src/product/ao_telescience.c
@@ -28,6 +28,8 @@ main(void)
PORTE |= (1 << 6);
DDRE |= (1 << 6);
+ ao_task_init();
+
ao_avr_stdio_init();
ao_timer_init();
ao_cmd_init();
diff --git a/src/product/ao_teleterra.c b/src/product/ao_teleterra.c
index d696b914..e739ae0b 100644
--- a/src/product/ao_teleterra.c
+++ b/src/product/ao_teleterra.c
@@ -26,6 +26,8 @@ main(void)
/* Turn on the red LED until the system is stable */
ao_led_init(AO_LED_RED|AO_LED_GREEN);
ao_led_on(AO_LED_RED);
+ ao_task_init();
+
ao_timer_init();
ao_beep_init();
ao_cmd_init();
diff --git a/src/product/ao_teleterra_0_2.c b/src/product/ao_teleterra_0_2.c
index 68f02596..4f7530f7 100644
--- a/src/product/ao_teleterra_0_2.c
+++ b/src/product/ao_teleterra_0_2.c
@@ -23,6 +23,8 @@ main(void)
{
ao_clock_init();
+ ao_task_init();
+
ao_timer_init();
ao_beep_init();
ao_cmd_init();
diff --git a/src/product/ao_test.c b/src/product/ao_test.c
index 14c2eb75..273a73b5 100644
--- a/src/product/ao_test.c
+++ b/src/product/ao_test.c
@@ -102,6 +102,8 @@ main(void)
{
ao_clock_init();
+ ao_task_init();
+
// ao_add_task(&blink_0_task, blink_0);
// ao_add_task(&blink_1_task, blink_1);
// ao_add_task(&wakeup_task, wakeup);
diff --git a/src/product/ao_tidongle.c b/src/product/ao_tidongle.c
index cba0b122..b1a96bdd 100644
--- a/src/product/ao_tidongle.c
+++ b/src/product/ao_tidongle.c
@@ -27,6 +27,9 @@ main(void)
/* Turn on the LED until the system is stable */
ao_led_init(AO_LED_RED);
ao_led_on(AO_LED_RED);
+
+ ao_task_init();
+
ao_timer_init();
ao_cmd_init();
ao_usb_init();