projects
/
goodfet
/ blobdiff
commit
grep
author
committer
pickaxe
?
search:
re
summary
|
shortlog
|
log
|
commit
|
commitdiff
|
tree
raw
|
inline
| side by side
GoodFET firmware on the Telos B reveals the Flash chip.
[goodfet]
/
firmware
/
apps
/
radios
/
nrf.c
diff --git
a/firmware/apps/radios/nrf.c
b/firmware/apps/radios/nrf.c
index
f81afba
..
e607bf6
100644
(file)
--- a/
firmware/apps/radios/nrf.c
+++ b/
firmware/apps/radios/nrf.c
@@
-15,27
+15,46
@@
#include "nrf.h"
#include "spi.h"
#include "nrf.h"
#include "spi.h"
-//This could be more accurate.
-//Does it ever need to be?
-#define NRFSPEED 0
-#define NRFDELAY(x)
-//delay(x)
+//! Handles a Nordic RF command.
+void nrf_handle_fn( uint8_t const app,
+ uint8_t const verb,
+ uint32_t const len);
+
+// define the nrf app's app_t
+app_t const nrf_app = {
+
+ /* app number */
+ NRF,
+
+ /* handle fn */
+ nrf_handle_fn,
+ /* name */
+ "NRF",
+
+ /* desc */
+ "\tThe NRF app adds support for the NordicRF register\n"
+ "\tinterface.\n"
+};
+
+#define RADIOACTIVE SETCE
+#define RADIOPASSIVE CLRCE
//! Set up the pins for NRF mode.
void nrfsetup(){
//! Set up the pins for NRF mode.
void nrfsetup(){
- P5OUT|=SS;
- P5DIR|=MOSI+SCK+SS;
- P5DIR&=~MISO;
+ SETSS;
+ SPIDIR&=~MISO;
+ SPIDIR|=MOSI+SCK;
+ DIRSS;
+ DIRCE;
//Begin a new transaction.
//Begin a new transaction.
-
P5OUT&=~
SS;
-
P5OUT|=
SS;
+
CLR
SS;
+
SET
SS;
}
}
-
//! Read and write an NRF byte.
//! Read and write an NRF byte.
-u
nsigned char nrftrans8(unsigned char
byte){
+u
8 nrftrans8(u8
byte){
register unsigned int bit;
//This function came from the NRF Wikipedia article.
//Minor alterations.
register unsigned int bit;
//This function came from the NRF Wikipedia article.
//Minor alterations.
@@
-59,44
+78,103
@@
unsigned char nrftrans8(unsigned char byte){
}
}
-
+//! Writes a register
+u8 nrf_regwrite(u8 reg, const u8 *buf, int len){
+ CLRSS;
+
+ reg=nrftrans8(reg);
+ while(len--)
+ nrftrans8(*buf++);
+
+ SETSS;
+ return reg;//status
+}
+//! Reads a register
+u8 nrf_regread(u8 reg, u8 *buf, int len){
+ CLRSS;
+
+ reg=nrftrans8(reg);
+ while(len--)
+ *buf++=nrftrans8(0);
+
+ SETSS;
+ return reg;//status
+}
//! Handles a Nordic RF command.
//! Handles a Nordic RF command.
-void nrfhandle(unsigned char app,
- unsigned char verb,
- unsigned long len){
+void nrf_handle_fn( uint8_t const app,
+ uint8_t const verb,
+ uint32_t const len)
+{
unsigned long i;
unsigned long i;
+ //Drop CE to passify radio.
+ RADIOPASSIVE;
//Raise !SS to end transaction, just in case we forgot.
//Raise !SS to end transaction, just in case we forgot.
-
P5OUT|=
SS;
+
SET
SS;
nrfsetup();
switch(verb){
//PEEK and POKE might come later.
nrfsetup();
switch(verb){
//PEEK and POKE might come later.
- case READ:
+ case READ:
case WRITE:
case WRITE:
-
P5OUT&=~
SS; //Drop !SS to begin transaction.
+
CLR
SS; //Drop !SS to begin transaction.
for(i=0;i<len;i++)
cmddata[i]=nrftrans8(cmddata[i]);
for(i=0;i<len;i++)
cmddata[i]=nrftrans8(cmddata[i]);
-
P5OUT|=
SS; //Raise !SS to end transaction.
+
SET
SS; //Raise !SS to end transaction.
txdata(app,verb,len);
break;
txdata(app,verb,len);
break;
-
-
case PEEK://Grab NRF Register
case PEEK://Grab NRF Register
- txdata(app,verb,0);
+ CLRSS; //Drop !SS to begin transaction.
+ nrftrans8(NRF_R_REGISTER | cmddata[0]); //000A AAAA
+ for(i=1;i<len;i++)
+ cmddata[i]=nrftrans8(cmddata[i]);
+ SETSS; //Raise !SS to end transaction.
+ txdata(app,verb,len);
break;
case POKE://Poke NRF Register
break;
case POKE://Poke NRF Register
-
- txdata(app,verb,0);
+ CLRSS; //Drop !SS to begin transaction.
+ nrftrans8(NRF_W_REGISTER | cmddata[0]); //001A AAAA
+ for(i=1;i<len;i++)
+ cmddata[i]=nrftrans8(cmddata[i]);
+ SETSS; //Raise !SS to end transaction.
+ txdata(app,verb,len);
break;
break;
-
case SETUP:
nrfsetup();
txdata(app,verb,0);
break;
case SETUP:
nrfsetup();
txdata(app,verb,0);
break;
+ case NRF_RX:
+ RADIOPASSIVE;
+ //Get the packet.
+ CLRSS;
+ nrftrans8(NRF_R_RX_PAYLOAD);
+ for(i=0;i<32;i++)
+ cmddata[i]=nrftrans8(0xde);
+ SETSS;
+ //no break
+ txdata(app,verb,32);
+ break;
+ case NRF_RX_FLUSH:
+ //Flush the buffer.
+ CLRSS;
+ nrftrans8(NRF_FLUSH_RX);
+ SETSS;
+
+ //Return the packet.
+ txdata(app,verb,32);
+ break;
+ case NRF_TX:
+ case NRF_TX_FLUSH:
+ default:
+ debugstr("Not yet supported.");
+ txdata(app,verb,0);
+ break;
}
}
+
+ SETSS;//End session
+ RADIOACTIVE;
}
}