telescience: steal last adc channel for icp3 most recent value
[fw/altos] / src / avr / ao_spi_slave.c
index 76f574c6480f6ac1012f9a43295d1c75fa4a765b..a400b8a0a929f0485b8d8da894f43c17ec098f79 100644 (file)
@@ -18,7 +18,7 @@
 #include "ao.h"
 
 uint8_t
-ao_spi_read(uint8_t *buf, uint8_t len)
+ao_spi_slave_recv(uint8_t *buf, uint8_t len)
 {
        while (len--) {
                while (!(SPSR & (1 << SPIF)))
@@ -30,7 +30,7 @@ ao_spi_read(uint8_t *buf, uint8_t len)
 }
 
 void
-ao_spi_write(uint8_t *buf, uint8_t len)
+ao_spi_slave_send(uint8_t *buf, uint8_t len)
 {
        while (len--) {
                SPDR = *buf++;
@@ -44,9 +44,8 @@ ao_spi_write(uint8_t *buf, uint8_t len)
 
 static uint8_t ao_spi_slave_running;
 
-ISR(PCINT0_vect)
+ISR(PCINT0_vect, ISR_BLOCK)
 {
-       cli();
 #if SPI_SLAVE_PIN_0_3
        if ((PINB & (1 << PORTB0)) == 0)
 #endif
@@ -61,7 +60,6 @@ ISR(PCINT0_vect)
        } else {
                ao_spi_slave_running = 0;
        }
-       sei();
 }
 
 void
@@ -87,7 +85,7 @@ ao_spi_slave_init(void)
                 (1 << 3) |             /* MISO, output */
                 (0 << 2) |             /* MOSI, no pull-up */
                 (0 << 1) |             /* SCK, no pull-up */
-                (0 << 0));             /* SS, no pull-up */
+                (1 << 0));             /* SS, pull-up */
 #endif
 #if SPI_SLAVE_PIN_2_5
        PCMSK0 |= (1 << PCINT2);        /* Enable PCINT2 pin change */
@@ -103,7 +101,7 @@ ao_spi_slave_init(void)
                 (0 << 5) |             /* SCK, no pull-up */
                 (1 << 4) |             /* MISO, output */
                 (0 << 3) |             /* MOSI, no pull-up */
-                (0 << 2));             /* SS, no pull-up */
+                (1 << 2));             /* SS, pull-up */
 #endif 
 
        SPCR = (0 << SPIE) |            /* Disable SPI interrupts */