X-Git-Url: http://git.rot13.org/?p=goodfet;a=blobdiff_plain;f=firmware%2Fapps%2Fjtag%2Fjtag430.c;h=9a33a7242a385d6b884406b3d43e6012876542d4;hp=f98cc5f27195557ed4375a2ebe047e46e0926b4c;hb=5fb0341d348e101b30794945a6c91546e25e8e7b;hpb=386bb6b2c16f5d729a49e8eb8f42bbfad6a42d10 diff --git a/firmware/apps/jtag/jtag430.c b/firmware/apps/jtag/jtag430.c index f98cc5f..9a33a72 100644 --- a/firmware/apps/jtag/jtag430.c +++ b/firmware/apps/jtag/jtag430.c @@ -7,6 +7,27 @@ #include "command.h" #include "jtag430.h" +//! Handles classic MSP430 JTAG commands. Forwards others to JTAG. +void jtag430_handle_fn(uint8_t const app, + uint8_t const verb, + uint32_t const len); + +// define the jtag430 app's app_t +app_t const jtag430_app = { + + /* app number */ + JTAG430, + + /* handle fn */ + jtag430_handle_fn, + + /* name */ + "JTAG430", + + /* desc */ + "\tThe JTAG430 app adds to the basic JTAG app\n" + "\tsupport for JTAG'ing MSP430 devices.\n" +}; unsigned int jtag430mode=MSP430X2MODE; @@ -313,14 +334,13 @@ void jtag430_setinstrfetch(){ //! Handles classic MSP430 JTAG commands. Forwards others to JTAG. -void jtag430handle(unsigned char app, - unsigned char verb, - unsigned long len){ - unsigned long at; +void jtag430_handle_fn(uint8_t const app, + uint8_t const verb, + uint32_t const len) +{ + unsigned long at, l; unsigned int i, val; - //debugstr("Classic MSP430 handler."); - /* FIXME * Sometimes JTAG doesn't init correctly. @@ -371,13 +391,13 @@ void jtag430handle(unsigned char app, //Fetch large blocks for bulk fetches, //small blocks for individual peeks. if(len>5) - len=(cmddataword[2]);//always even. + l=(cmddataword[2]);//always even. else - len=2; - len&=~1;//clear lsbit + l=2; + l&=~1;//clear lsbit - txhead(app,verb,len); - for(i=0;i