X-Git-Url: https://git.gag.com/?a=blobdiff_plain;f=src%2Fkernel%2Fao_notask.c;h=c87bbbbbe21cbf32ab217b2856f105a299af379f;hb=d225adc3af9e5726d436cbbdbf8dcc5837e50804;hp=00fe1ed61fc78d150dcf4e22102415e999d9d948;hpb=1085ec5d57e0ed5d132f2bbdac1a0b6a32c0ab4a;p=fw%2Faltos diff --git a/src/kernel/ao_notask.c b/src/kernel/ao_notask.c index 00fe1ed6..c87bbbbb 100644 --- a/src/kernel/ao_notask.c +++ b/src/kernel/ao_notask.c @@ -21,7 +21,7 @@ static volatile void *ao_wchan; uint8_t -ao_sleep(__xdata void *wchan) +ao_sleep(void *wchan) { #if 1 ao_wchan = wchan; @@ -39,8 +39,26 @@ ao_sleep(__xdata void *wchan) return 0; } +#if HAS_AO_DELAY void -ao_wakeup(__xdata void *wchan) +ao_delay_until(AO_TICK_TYPE target) +{ + ao_arch_block_interrupts(); + while ((AO_TICK_SIGNED) (target - ao_tick_count) > 0) + ao_sleep((void *) &ao_tick_count); + ao_arch_release_interrupts(); +} + +void +ao_delay(AO_TICK_TYPE ticks) +{ + ao_delay_until(ao_time() + ticks); +} + +#endif + +void +ao_wakeup(void *wchan) { (void) wchan; ao_wchan = 0;