X-Git-Url: http://git.rot13.org/?p=goodfet;a=blobdiff_plain;f=firmware%2Fapps%2Fradios%2Fccspi.c;h=74dde4fbfb8225a0b501a322dde8e889a9df2402;hp=ab1051fdd34a71dca86d39e7205acccb07c2006c;hb=854dba571fe62948dfb23a396be3299225fcbb05;hpb=1afd03f424ab5da0a4c172d7c48814db3660a2f0;ds=sidebyside diff --git a/firmware/apps/radios/ccspi.c b/firmware/apps/radios/ccspi.c index ab1051f..74dde4f 100644 --- a/firmware/apps/radios/ccspi.c +++ b/firmware/apps/radios/ccspi.c @@ -47,17 +47,21 @@ app_t const ccspi_app = { }; -#define RADIOACTIVE SETCE -#define RADIOPASSIVE CLRCE +#define RADIOACTIVE CLRCE +#define RADIOPASSIVE SETCE //! Set up the pins for CCSPI mode. void ccspisetup(){ - SETSS; - P5DIR&=~MISO; - P5DIR|=MOSI+SCK; + SPIDIR&=~MISO; + SPIDIR|=MOSI+SCK; DIRSS; DIRCE; + //Telos B Radio VReg Enable + P4DIR|=BIT5+BIT2+BIT6+BIT7; + P4OUT|=BIT5+BIT7; + P4OUT&=~(BIT6+BIT2); + //Begin a new transaction. CLRSS; SETSS; @@ -113,20 +117,14 @@ u8 ccspi_regread(u8 reg, u8 *buf, int len){ //! Handles a Chipcon SPI command. void ccspi_handle_fn( uint8_t const app, - uint8_t const verb, - uint32_t const len) -{ + uint8_t const verb, + uint32_t const len){ unsigned long i; - //Drop CE to passify radio. - RADIOPASSIVE; - //Raise !SS to end transaction, just in case we forgot. - SETSS; - ccspisetup(); + //debugstr("Chipcon SPI handler."); switch(verb){ - //PEEK and POKE might come later. - case READ: + case READ: case WRITE: CLRSS; //Drop !SS to begin transaction. for(i=0;i