X-Git-Url: http://git.rot13.org/?p=goodfet;a=blobdiff_plain;f=firmware%2Fapps%2Fradios%2Fnrf.c;h=ca701130eee5a896609bd16181be5d98048a89b2;hp=9254f9325039c5665be46db7289530253fbfc422;hb=97143fece53250662a3ffd22f141619a4902eda7;hpb=87c8139ff30306e8269e009d7fbd309dacf6d24e diff --git a/firmware/apps/radios/nrf.c b/firmware/apps/radios/nrf.c index 9254f93..ca70113 100644 --- a/firmware/apps/radios/nrf.c +++ b/firmware/apps/radios/nrf.c @@ -15,26 +15,21 @@ #include "nrf.h" #include "spi.h" -//Weird HOPE badge wiring. This was a fuckup. -//BIT0 should be SS, but in point of fact it is IRQ. -//BIT4 is actually SS, BIT5 is CE. -#define SS BIT4 -#define CE BIT5; - -#define RADIOACTIVE P5OUT|=CE -#define RADIOPASSIVE P5OUT&=~CE +#define RADIOACTIVE SETCE +#define RADIOPASSIVE CLRCE //! Set up the pins for NRF mode. void nrfsetup(){ - P5OUT|=SS; + SETSS; P5DIR&=~MISO; - P5DIR|=MOSI+SCK+SS+CE; - + P5DIR|=MOSI+SCK; + DIRSS; + DIRCE; //Begin a new transaction. - P5OUT&=~SS; - P5OUT|=SS; + CLRSS; + SETSS; } //! Read and write an NRF byte. @@ -64,24 +59,24 @@ u8 nrftrans8(u8 byte){ //! Writes a register u8 nrf_regwrite(u8 reg, const u8 *buf, int len){ - P5OUT&=~SS; + CLRSS; reg=nrftrans8(reg); while(len--) nrftrans8(*buf++); - P5OUT|=SS; + SETSS; return reg;//status } //! Reads a register u8 nrf_regread(u8 reg, u8 *buf, int len){ - P5OUT&=~SS; + CLRSS; reg=nrftrans8(reg); while(len--) *buf++=nrftrans8(0); - P5OUT|=SS; + SETSS; return reg;//status } @@ -94,35 +89,35 @@ void nrfhandle(unsigned char app, //Drop CE to passify radio. RADIOPASSIVE; //Raise !SS to end transaction, just in case we forgot. - P5OUT|=SS; + SETSS; nrfsetup(); switch(verb){ //PEEK and POKE might come later. case READ: case WRITE: - P5OUT&=~SS; //Drop !SS to begin transaction. + CLRSS; //Drop !SS to begin transaction. for(i=0;i