altos: Add SPI slave get/put macros to cc1111
[fw/altos] / src / cc1111 / ao_arch_funcs.h
index d9f5955a75b3326f03d0cb985bd872942062da40..5e2fc13db1ab808f8a6e5eda1607d5fe871626d5 100644 (file)
 
 extern __xdata uint8_t ao_spi_mutex;
 
 
 extern __xdata uint8_t ao_spi_mutex;
 
-#define ao_spi_get_mask(reg,mask,bus) do {             \
-       ao_mutex_get(&ao_spi_mutex); \
-       (reg) &= ~(mask); \
+#define AO_SPI_SPEED_FAST      17
+#define AO_SPI_SPEED_200kHz    13
+
+#define ao_spi_set_speed(speed) (U0GCR = (UxGCR_CPOL_NEGATIVE |                \
+                                         UxGCR_CPHA_FIRST_EDGE |       \
+                                         UxGCR_ORDER_MSB |             \
+                                         ((speed) << UxGCR_BAUD_E_SHIFT)))
+
+#define ao_spi_get_slave(bus) do {                     \
+               ao_mutex_get(&ao_spi_mutex);            \
+               ao_spi_set_speed(AO_SPI_SPEED_FAST);    \
+       } while (0)
+
+#define ao_spi_put_slave(bus) do {             \
+               ao_mutex_put(&ao_spi_mutex);    \
+       } while (0)
+
+#define ao_spi_get_mask(reg,mask,bus,speed) do {       \
+               ao_mutex_get(&ao_spi_mutex);            \
+               ao_spi_set_speed(speed);                \
+               (reg) &= ~(mask);                       \
        } while (0)
 
 #define ao_spi_put_mask(reg,mask,bus) do {             \
        } while (0)
 
 #define ao_spi_put_mask(reg,mask,bus) do {             \
@@ -31,14 +49,16 @@ extern __xdata uint8_t      ao_spi_mutex;
        ao_mutex_put(&ao_spi_mutex); \
        } while (0)
 
        ao_mutex_put(&ao_spi_mutex); \
        } while (0)
 
-#define ao_spi_get_bit(bit,bus) do {    \
-       ao_mutex_get(&ao_spi_mutex); \
-       (bit) = 0; \
+
+#define ao_spi_get_bit(reg,bit,pin,bus,speed) do {     \
+               ao_mutex_get(&ao_spi_mutex);    \
+               ao_spi_set_speed(speed);        \
+               pin = 0;                        \
        } while (0)
 
        } while (0)
 
-#define ao_spi_put_bit(bit,bus) 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)
 
 
        } while (0)
 
 
@@ -65,3 +85,16 @@ ao_spi_init(void);
                SPI_CS_DIR |= mask;             \
                SPI_CS_SEL &= ~mask;            \
        } while (0)
                SPI_CS_DIR |= mask;             \
                SPI_CS_SEL &= ~mask;            \
        } while (0)
+
+#define cc1111_enable_output(port,dir,sel,pin,bit,v) do {      \
+               pin = v;                                        \
+               dir |= (1 << bit);                              \
+               sel &= ~(1 << bit);                             \
+       } 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,bit,pin,v) cc1111_enable_output(port,token_evaluator(port,DIR), token_evaluator(port,SEL), pin, bit, v)
+#define ao_gpio_set(port, bit, pin, v) ((pin) = (v))