altos: stm i2c debug code was calling flush() even when disabled
[fw/altos] / src / cc1111 / ao_arch_funcs.h
index 9ad14fbbad0144e4b960c32be95a82244c293a67..728f1f76d935507787aa6f8b6ef3749fd6720b3d 100644 (file)
 
 extern __xdata uint8_t ao_spi_mutex;
 
-#define ao_spi_get_mask(reg,mask) do {\
+#define ao_spi_get_mask(reg,mask,bus) do {             \
        ao_mutex_get(&ao_spi_mutex); \
        (reg) &= ~(mask); \
        } while (0)
 
-#define ao_spi_put_mask(reg,mask) do { \
+#define ao_spi_put_mask(reg,mask,bus) do {             \
        (reg) |= (mask); \
        ao_mutex_put(&ao_spi_mutex); \
        } while (0)
 
-#define ao_spi_get_bit(bit) do {\
-       ao_mutex_get(&ao_spi_mutex); \
-       (bit) = 0; \
+#define ao_spi_get_bit(reg,bit,pin,bus) do {   \
+               ao_mutex_get(&ao_spi_mutex);    \
+               pin = 0;                        \
        } while (0)
 
-#define ao_spi_put_bit(bit) do { \
-       (bit) = 1; \
-       ao_mutex_put(&ao_spi_mutex); \
+#define ao_spi_put_bit(reg,bit,pin,bus) do {   \
+               pin = 1;                        \
+               ao_mutex_put(&ao_spi_mutex);    \
        } while (0)
 
+
 /*
  * The SPI mutex must be held to call either of these
  * functions -- this mutex covers the entire SPI operation,
@@ -48,11 +49,31 @@ extern __xdata uint8_t      ao_spi_mutex;
  */
 
 void
-ao_spi_send(void __xdata *block, uint16_t len) __reentrant;
+ao_spi_send_bus(void __xdata *block, uint16_t len) __reentrant;
 
 void
-ao_spi_recv(void __xdata *block, uint16_t len) __reentrant;
+ao_spi_recv_bus(void __xdata *block, uint16_t len) __reentrant;
+
+#define ao_spi_send(block, len, bus) ao_spi_send_bus(block, len)
+#define ao_spi_recv(block, len, bus) ao_spi_recv_bus(block, len)
 
 void
 ao_spi_init(void);
 
+#define ao_spi_init_cs(port, mask) do {                \
+               SPI_CS_PORT |= mask;            \
+               SPI_CS_DIR |= mask;             \
+               SPI_CS_SEL &= ~mask;            \
+       } while (0)
+
+#define cc1111_enable_output(port,dir,sel,mask,v) do { \
+       port = port & ~(mask) | v; \
+       dir |= mask; \
+       sel &= ~mask; \
+} while (0)
+
+#define disable_unreachable    _Pragma("disable_warning 126")
+
+#define token_paster(x,y)      x ## y
+#define token_evaluator(x,y)   token_paster(x,y)
+#define ao_enable_output(port,pin,v) cc1111_enable_output(port,token_evaluator(port,DIR), token_evaluator(port,SEL), 1 << pin, 1 << v)