X-Git-Url: http://git.rot13.org/?p=goodfet;a=blobdiff_plain;f=shellcode%2Fchipcon%2Fcc1110%2Frxpacket.c;h=13ec690865339b06931584e6b1ba3c02666b5e5a;hp=9bea2421a88107533052d28487d0a5761c593c93;hb=8f3ecaa2ecd27948480534d866f9c686fa14a019;hpb=a06f45d24b010987c9128261ff33dd2c93db0970 diff --git a/shellcode/chipcon/cc1110/rxpacket.c b/shellcode/chipcon/cc1110/rxpacket.c index 9bea242..13ec690 100644 --- a/shellcode/chipcon/cc1110/rxpacket.c +++ b/shellcode/chipcon/cc1110/rxpacket.c @@ -1,20 +1,54 @@ #include #include "cc1110-ext.h" -char __xdata at 0xfe00 packet[256] ; - +#define MAXLEN 0xFF +char __xdata at 0xfe00 packet[MAXLEN] ; //! Receives a packet out of the radio from 0xFE00. void main(){ - unsigned char len=100, i=0; - RFST=RFST_SRX; //Begin to receive. - while(i!=len+1){ - while(RFTXRXIF); //Wait for byte to be ready. + unsigned char len=16, i=0; + + do{ + //1-out the buffer. + for(i=0;i<64;i++) + packet[i]=0xFF; + i=0; + + //Disable interrupts. + RFTXRXIE=0; + + //idle a bit. + RFST=RFST_SIDLE; + while(MARCSTATE!=MARC_STATE_IDLE); - RFTXRXIF=0; //Clear the flag. - packet[i++]=RFD; //Grab the next byte. - len=packet[0]; //First byte of the packet is the length. - } - RFST = RFST_SIDLE; //End transmit. + //Begin to receive. + RFST=RFST_SRX; + while(MARCSTATE!=MARC_STATE_RX); + + if(PKTCTRL0&1){ + //auto length + while(i