Merge branch 'master' of ssh://git.gag.com/scm/git/fw/altos
[fw/altos] / src / kernel / ao_notask.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 <ao.h>
20
21 static volatile void *ao_wchan;
22
23 uint8_t
24 ao_sleep(void *wchan)
25 {
26 #if 1
27         ao_wchan = wchan;
28         ao_arch_wait_interrupt();
29 #else
30         uint8_t sreg;
31
32         ao_wchan = wchan;
33         asm("in %0,__SREG__" : "=&r" (sreg));
34         sei();
35         while (ao_wchan)
36                 ao_arch_cpu_idle();
37         asm("out __SREG__,%0" : : "r" (sreg));
38 #endif
39         return 0;
40 }
41
42 #if HAS_AO_DELAY
43 void
44 ao_delay(uint16_t ticks)
45 {
46         AO_TICK_TYPE    target;
47
48         if (!ticks)
49                 ticks = 1;
50         target = ao_tick_count + ticks;
51         do {
52                 ao_sleep(&ao_time);
53         } while ((int16_t) (target - ao_tick_count) > 0);
54 }
55 #endif
56
57 void
58 ao_wakeup(void *wchan)
59 {
60         (void) wchan;
61         ao_wchan = 0;
62 }