X-Git-Url: http://git.rot13.org/?p=goodfet;a=blobdiff_plain;f=firmware%2Fgoodfet.c;h=a6ccae401655cf1666792487691ca6ca1f946c1a;hp=acfb7e31a17f52b92690b97f4876251597695d28;hb=3e4992b4d109f361b42abdda403471860edfeabf;hpb=b27bfe788715f1d1127a1649ac5e3cbe91037af9 diff --git a/firmware/goodfet.c b/firmware/goodfet.c index acfb7e3..a6ccae4 100644 --- a/firmware/goodfet.c +++ b/firmware/goodfet.c @@ -24,11 +24,36 @@ void init(){ //LED out and on. PLEDDIR |= PLEDPIN; PLEDOUT &= ~PLEDPIN; + + + /* P5.0 out and low; this is chosen for the PIC app (in which P5.0 + is !MCLR) to ensure that an attached PIC chip, if present, is + immediately driven to reset state. A brief explanation of why this + is important follows. + + At least dsPIC33F and PIC24H --and very likely other 16-bit PIC + families-- draw a large amount of current when running, especially + when using a fast clock: from 60 mA up to approx. 90 mA. If the + PIC target begins to run before the client can request a new ICSP + session, which requires much less current (e.g., less than 2 mA), + then the MSP430 chip on the GoodFET will fail to start and the FTDI + may have trouble communicating with the client. The latter likely + relates to the FTDI on-chip 3V3 regulator being specified up to + only 50 mA. */ + + + //P5REN &= ~BIT0; //DO NOT UNCOMMENT. Breaks GF1x support. + + //This will have to be cut soon. Use pulling resistors instead. + /* + P5DIR |= BIT0; + P5OUT &= ~BIT0; + */ //Setup clocks, unique to each '430. msp430_init_dco(); msp430_init_uart(); - + //DAC should be at full voltage if it exists. #ifdef DAC12IR //glitchvoltages(0xfff,0xfff); @@ -64,7 +89,7 @@ void handle(unsigned char app, unsigned char verb, unsigned long len){ //debugstr("GoodFET"); - P1OUT&=~1; + PLEDOUT&=~PLEDPIN; switch(app){ case GLITCH: glitchhandle(app,verb,len); @@ -75,14 +100,21 @@ void handle(unsigned char app, case SPI: spihandle(app,verb,len); break; + case NRF: + nrfhandle(app,verb,len); + break; + case CCSPI: + ccspihandle(app,verb,len); + break; case AVR: avrhandle(app,verb,len); break; -#ifdef INSTALL_PIC_APP case PIC: pichandle(app,verb,len); break; -#endif + case ADC10: + adchandle(app,verb,len); + break; case I2CAPP: i2chandle(app,verb,len); break; @@ -97,8 +129,8 @@ void handle(unsigned char app, break; case JTAG430: //Also JTAG430X, JTAG430X2 //Revert this when X2 support returns. - //jtag430x2handle(app,verb,len); - jtag430handle(app,verb,len); + jtag430x2handle(app,verb,len); + //jtag430handle(app,verb,len); break; case SMARTCARD: smartcardhandle(app,verb,len);