X-Git-Url: http://git.rot13.org/?p=goodfet;a=blobdiff_plain;f=firmware%2Fgoodfet.c;h=b8d9e3dbe7940936065d98a0c4bb9b4ccbe5c7ff;hp=5d01977a47f5f36f1a146dc8fb47b0ce2007d5f1;hb=ea94279f763800d71e86d9bb25d140bf78dfb4ea;hpb=c28cce5afcc1e1747f51e5afe15e338dae030376 diff --git a/firmware/goodfet.c b/firmware/goodfet.c index 5d01977..b8d9e3d 100644 --- a/firmware/goodfet.c +++ b/firmware/goodfet.c @@ -1,95 +1,209 @@ -//GOODFET Main File -//Includes several applications. - -#include "platform.h" -#include "command.h" -#include "apps.h" - - - -//LED on P1.0 -//IO on P5 - -//! Initialize registers and all that jazz. -void init(){ - WDTCTL = WDTPW + WDTHOLD; // Stop watchdog timer - - //LED out and on. - PLEDDIR |= PLEDPIN; - PLEDOUT |= PLEDPIN; - - //Setup clocks, unique to each '430. - msp430_init_dco(); - msp430_init_uart(); - - //Enable Interrupts. - //eint(); -} - -//! Handle a command. -void handle(unsigned char app, - unsigned char verb, - unsigned char len){ - switch(app){ - case MONITOR: - monitorhandle(app,verb,len); - break; - case SPI: - spihandle(app,verb,len); - break; - case I2CAPP: - i2chandle(app,verb,len); - break; - case CHIPCON: - cchandle(app,verb,len); - break; - case JTAG: - jtaghandle(app,verb,len); - break; - case JTAG430: - jtag430handle(app,verb,len); - break; - default: - txdata(app,NOK,0); - break; - } -} - -//! Main loop. -int main(void) -{ - volatile unsigned int i; - unsigned char app, verb, len; - - init(); - - - //Ready - //txdata(MONITOR,OK,0); - //while (1){ - // txdata(0xFF,0xff,0x0); - // delay(1000); - //} - //delay(0xffff); - //while(*((int*)0x1001)); - - //while(1) - // txdata(0xFF,0xFF,0); - - txstring(MONITOR,OK,"http://goodfet.sf.net/"); - - //Command loop. There's no end! - while(1){ - //Magic 3 - app=serial_rx(); - verb=serial_rx(); - len=serial_rx(); - - //Read data, if any - for(i=0;i 4) { + // We could trigger the WDT with either: + // WDTCTL = 0; + // or + // WDTCTL = WDTPW + WDTCNTCL + WDTSSEL + 0x00; + // but instead we'll jump to our reboot function pointer + (*reboot_function)(); + } + + continue; + } else { + reset_count = 0; + } + + verb=serial_rx(); + //len=serial_rx(); + len=rxword(); + + //Read data, looking for buffer overflow.y + if(len<=CMDDATALEN){ + for(i=0;i