+#define ao_arch_isr_stack() /* nothing */
+
+#define ao_arch_cpu_idle() do { \
+ if (!ao_cpu_sleep_disable) \
+ sleep_cpu(); \
+ } while (0)
+
+#define ao_arch_restore_stack() do { \
+ uint8_t sp_l, sp_h; \
+ sp_l = (uint16_t) ao_cur_task->sp; \
+ sp_h = ((uint16_t) ao_cur_task->sp) >> 8; \
+ cli(); \
+ asm("out __SP_H__,%0" : : "r" (sp_h) ); \
+ asm("out __SP_L__,%0" : : "r" (sp_l) ); \
+ asm("pop r0" "\n\t" \
+ "out __SREG__, r0"); \
+ asm("pop r0" "\n\t" "pop r1" "\n\t" "pop r2" "\n\t" "pop r3" "\n\t" "pop r4"); \
+ asm("pop r5" "\n\t" "pop r6" "\n\t" "pop r7" "\n\t" "pop r8" "\n\t" "pop r9"); \
+ asm("pop r10" "\n\t" "pop r11" "\n\t" "pop r12" "\n\t" "pop r13" "\n\t" "pop r14"); \
+ asm("pop r15" "\n\t" "pop r16" "\n\t" "pop r17" "\n\t" "pop r18" "\n\t" "pop r19"); \
+ asm("pop r20" "\n\t" "pop r21" "\n\t" "pop r22" "\n\t" "pop r23" "\n\t" "pop r24"); \
+ asm("pop r25" "\n\t" "pop r26" "\n\t" "pop r27" "\n\t" "pop r28" "\n\t" "pop r29"); \
+ asm("pop r30" "\n\t" "pop r31"); \
+ asm("ret"); \
+ } while(0)
+
+#define ao_arch_critical(b) do { cli(); b; sei(); } while (0)
+
+#define AO_TELESCIENCE_NUM_ADC 12
+
+struct ao_adc {
+ uint16_t tick; /* tick when the sample was read */
+ uint16_t adc[AO_TELESCIENCE_NUM_ADC]; /* samples */
+};
+
+#define AO_ADC_RING 16
+