P5OUT|=MOSI+SCK+RST;
P5DIR|=MOSI+SCK+RST;
//P5DIR&=~MISO; //MOSI is MISO
+
+ //P5REN=0xFF;
+
}
//! Initialize the debugger
void ccdebuginit(){
+ delay(30); //So the beginning is ready for glitching.
+
//Two positive debug clock pulses while !RST is low.
//Take RST low, pulse twice, then high.
P5OUT&=~SCK;
void cc_lockchip(){
register int i;
- debugstr("Locking chip.");
+ //debugstr("Locking chip.");
cc_wr_config(1);//Select Info Flash
if(!(cc_rd_config()&1))
debugstr("Config forgotten!");
//! Read the CHIP ID bytes.
unsigned short cc_get_chip_id(){
- unsigned short toret;
cmddata[0]=CCCMD_GET_CHIP_ID; //0x68
cccmd(1);
ccread(2);
case 0x81://CC2510
case 0x91://CC2511
flash_word_size=0x02;
- debugstr("2 bytes/flash word");
+ //debugstr("2 bytes/flash word");
break;
default:
debugstr("Warning: Guessing flash word size.");
case 0x85://CC2430
case 0x89://CC2431
- debugstr("4 bytes/flash word");
+ //debugstr("4 bytes/flash word");
flash_word_size=0x04;
break;
}