X-Git-Url: http://git.rot13.org/?p=goodfet;a=blobdiff_plain;f=firmware%2Fapps%2Favr%2Favr.c;h=0cc4c0da79842727fd70833ad4dba75b8321400d;hp=5b5fcae04638481d782ce2f9ca284c2a0c5f05b2;hb=3e4992b4d109f361b42abdda403471860edfeabf;hpb=a6afe092f45e72e65198bf6fbe07e8da40706970 diff --git a/firmware/apps/avr/avr.c b/firmware/apps/avr/avr.c index 5b5fcae..0cc4c0d 100644 --- a/firmware/apps/avr/avr.c +++ b/firmware/apps/avr/avr.c @@ -11,7 +11,7 @@ #include #include "avr.h" -#include "glitch.h" +//#include "glitch.h" //! Setup the AVR pins. void avrsetup(){ @@ -21,11 +21,15 @@ void avrsetup(){ //! Initialized an attached AVR. void avrconnect(){ //set I/O pins - avrsetup(); + avrsetup(); //Cut this? + + SETSS; + //delay(50); //Pulse !RST (SS) at least twice while CLK is low. CLRCLK; CLRSS; + //delay(5); SETSS; CLRCLK; @@ -126,6 +130,16 @@ u8 avr_peekflash(u16 adr){ return avrexchange(0x20,a>>8,a&0xff,0); } +void avr_bulk_load(u16 start, u16 len, u8 *data) { + u16 adr; + for (adr = 0; adr < len; adr++) { + u16 a = adr + start; + avrexchange((adr & 1) ? 0x48 : 0x40, + a >> 9, + (a >> 1) & 0xff, + data[adr]); + } +} //! Handles an AVR command. void avrhandle(unsigned char app, @@ -133,7 +147,6 @@ void avrhandle(unsigned char app, unsigned long len){ unsigned long i; unsigned int at; - static u8 connected=0; /* if(!avr_isready() && connected) @@ -155,6 +168,9 @@ void avrhandle(unsigned char app, avrconnect(); txdata(app,verb,0); break;//Used to fall through here. + case STOP: + SETSS; + txdata(app, verb, 0); case AVR_PEEKSIG: for(i=0;i<4;i++) cmddata[i]=avr_sig(i); @@ -179,6 +195,16 @@ void avrhandle(unsigned char app, cmddata[0]=avr_peekeeprom(cmddataword[0]); txdata(app,verb,1); break; + case AVR_BULKLOAD: + if (len < 3) { + debugstr("Length too short"); + txdata(app, NOK, 0); + } else { + at = cmddataword[0]; + avr_bulk_load(at, len - 2, cmddata + 2); + txdata(app, verb, 0); + } + break; case PEEK: //cmddata[0]=avr_peekflash(cmddataword[0]); //txdata(app,verb,1);