X-Git-Url: http://git.rot13.org/?a=blobdiff_plain;f=firmware%2Fgoodfet.c;h=39cad44a60256e8858647b6127c63073ffe543af;hb=04de1e3bc7c3c2721bbfcae0dd5135dbd2befc80;hp=5f30c77cf2669a8b9946b35599b8b109bd493fde;hpb=5b89da5a9d7864784dbe4942d856f751c3758c1c;p=goodfet diff --git a/firmware/goodfet.c b/firmware/goodfet.c index 5f30c77..39cad44 100644 --- a/firmware/goodfet.c +++ b/firmware/goodfet.c @@ -12,6 +12,13 @@ #include "apps.h" #include "glitch.h" +#if (platform == tilaunchpad) +#include +jmp_buf warmstart; +void coldstart(); +#include "msp430_serial.h" +#endif + #define RESET 0x80 // not a real app -- causes firmware to reset #define DEBUGAPP 0xFF @@ -45,7 +52,7 @@ void handle(uint8_t const app, int i; //debugstr("GoodFET"); - PLEDOUT&=~PLEDPIN; + led_off(); // find the app and call the handle fn for(i = 0; i < num_apps; i++){ @@ -74,14 +81,30 @@ int main(void) unsigned long len; // MSP reboot count for reset input & reboot function located at 0xFFFE volatile unsigned int reset_count = 0; +#if (platform == tilaunchpad) + int ret=0; + + //ret = setjmp(warmstart);// needs to be here since context from init() would be gone + warmstart: + if (ret == 0) { + coldstart(); // basic hardware setup, clock to TUSB3410, and enable + } else if (ret == 2) { + dputs("\nalmost BSL only one RTS change\n"); + } else if (ret > 2) { // reset released after more than two tst transisitions + // We could write a BSL, a nice exercise for a Sunday afternoon. + dputs("\nBSL\n"); + //call_BSL(); // once you are done uncomment ;-) + } else { // we come here after DTR high (release reset) + dputs("\nWarmstart\n"); + } +#else void (*reboot_function)(void) = (void *) 0xFFFE; - +#endif init(); txstring(MONITOR,OK,"http://goodfet.sf.net/"); - #ifdef ECHOTEST - while(1) serial0_tx(serial0_rx()); - #endif + //txstring(0xab,0xcd,"http://goodfet.sf.net/"); + //Command loop. There's no end! while(1) @@ -102,7 +125,16 @@ int main(void) // WDTCTL = WDTPW + WDTCNTCL + WDTSSEL + 0x00; // but instead we'll jump to our reboot function pointer #ifdef MSP430 +#if (platform == tilaunchpad) + // do we really need this, we do not want to reset the TUSB3410 + dputs("reset_count>4\n"); + + //longjmp(warmstart,111); + goto warmstart; + +#else (*reboot_function)(); +#endif #else debugstr("Rebooting not supported on this platform."); #endif @@ -118,7 +150,7 @@ int main(void) verb = serial_rx(); len = rxword(); - //Read data, looking for buffer overflow.y + //Read data, looking for buffer overflow. if(len <= CMDDATALEN) { for(i = 0; i < len; i++)