projects
/
fw
/
altos
/ blobdiff
commit
grep
author
committer
pickaxe
?
search:
re
summary
|
shortlog
|
log
|
commit
|
commitdiff
|
tree
raw
|
inline
| side by side
altos/microsplash: fix .gitignore to ignore resulting binary
[fw/altos]
/
src
/
cc1111
/
ao_arch.h
diff --git
a/src/cc1111/ao_arch.h
b/src/cc1111/ao_arch.h
index a97515a7547509d31b1a4328d2f272fa7bd0e28e..b3c6b5dcce6fd29ffa7710ec47c1ecb5293a950d 100644
(file)
--- a/
src/cc1111/ao_arch.h
+++ b/
src/cc1111/ao_arch.h
@@
-40,6
+40,8
@@
#define AO_STACK_END 0xfe
#define AO_STACK_SIZE (AO_STACK_END - AO_STACK_START + 1)
#define AO_STACK_END 0xfe
#define AO_STACK_SIZE (AO_STACK_END - AO_STACK_START + 1)
+#define AO_PORT_TYPE uint8_t
+
#define ao_arch_reboot() do { \
WDCTL = WDCTL_EN | WDCTL_MODE_WATCHDOG | WDCTL_INT_64; \
ao_delay(AO_SEC_TO_TICKS(2)); \
#define ao_arch_reboot() do { \
WDCTL = WDCTL_EN | WDCTL_MODE_WATCHDOG | WDCTL_INT_64; \
ao_delay(AO_SEC_TO_TICKS(2)); \
@@
-112,9
+114,7
@@
extern AO_ROMCONFIG_SYMBOL(0x00a6) uint32_t ao_radio_cal;
/* Push ACC first, as when restoring the context it must be restored \
* last (it is used to set the IE register). */ \
push ACC \
/* Push ACC first, as when restoring the context it must be restored \
* last (it is used to set the IE register). */ \
push ACC \
- /* Store the IE register then enable interrupts. */ \
push _IEN0 \
push _IEN0 \
- setb _EA \
push DPL \
push DPH \
push b \
push DPL \
push DPH \
push b \
@@
-147,11
+147,18
@@
extern AO_ROMCONFIG_SYMBOL(0x00a6) uint32_t ao_radio_cal;
while (--stack_len); \
}
while (--stack_len); \
}
-#define ao_arch_isr_stack() \
- /* Empty the stack; might as well let interrupts have the whole thing */ \
- (SP = AO_STACK_START - 1)
+/* Empty the stack; might as well let interrupts have the whole thing */
+#define ao_arch_isr_stack() (SP = AO_STACK_START - 1)
+
+#define ao_arch_block_interrupts() __asm clr _EA __endasm
+#define ao_arch_release_interrupts() __asm setb _EA __endasm
-#define ao_arch_cpu_idle() (PCON = PCON_IDLE)
+/* Idle the CPU, waking when an interrupt occurs */
+#define ao_arch_wait_interrupt() do { \
+ ao_arch_release_interrupts(); \
+ (PCON = PCON_IDLE); \
+ ao_arch_block_interrupts(); \
+ } while (0)
#define ao_arch_restore_stack() { \
uint8_t stack_len; \
#define ao_arch_restore_stack() { \
uint8_t stack_len; \
@@
-192,7
+199,7
@@
extern AO_ROMCONFIG_SYMBOL(0x00a6) uint32_t ao_radio_cal;
0098$: \
SETB _EA \
0099$: \
0098$: \
SETB _EA \
0099$: \
- /* Finally
pop off th
e ACC, which was the first register saved. */ \
+ /* Finally
restor
e ACC, which was the first register saved. */ \
pop ACC \
ret \
__endasm; \
pop ACC \
ret \
__endasm; \
@@
-229,17
+236,17
@@
ao_button_clear(void) __critical;
/* ao_string.c */
void
/* ao_string.c */
void
-_ao_xmemcpy(__xdata void *dst, __xdata void *src, uint
8
_t count);
+_ao_xmemcpy(__xdata void *dst, __xdata void *src, uint
16
_t count);
#define ao_xmemcpy(d,s,c) _ao_xmemcpy(d,s,c)
void
#define ao_xmemcpy(d,s,c) _ao_xmemcpy(d,s,c)
void
-_ao_xmemset(__xdata void *dst, uint8_t value, uint
8
_t count);
+_ao_xmemset(__xdata void *dst, uint8_t value, uint
16
_t count);
#define ao_xmemset(d,v,c) _ao_xmemset(d,v,c)
int8_t
#define ao_xmemset(d,v,c) _ao_xmemset(d,v,c)
int8_t
-_ao_xmemcmp(__xdata void *a, __xdata void *b, uint
8
_t count);
+_ao_xmemcmp(__xdata void *a, __xdata void *b, uint
16
_t count);
#define ao_xmemcmp(d,s,c) _ao_xmemcmp((d), (s), (c))
#define ao_xmemcmp(d,s,c) _ao_xmemcmp((d), (s), (c))
@@
-316,4
+323,11
@@
void
ao_serial1_tx_isr(void) ao_arch_interrupt(14);
#endif
ao_serial1_tx_isr(void) ao_arch_interrupt(14);
#endif
+#if HAS_EXTI_0
+void
+ao_p0_isr(void) __interrupt(13);
+#endif
+
+#define AO_ADC_MAX 32767
+
#endif /* _AO_ARCH_H_ */
#endif /* _AO_ARCH_H_ */