X-Git-Url: http://git.rot13.org/?p=goodfet;a=blobdiff_plain;f=firmware%2Fapps%2Favr%2Favr.c;h=577d87847d32aec4e0550b2efa65248ee3f71df9;hp=c9d0b94d6737bda36abe2f75061dfec129145fca;hb=ccbb5f9f7ae6fee33ba360030ecdaa76e7967024;hpb=c63fa4693820603a0444cc323ca34ad0b8fa9791 diff --git a/firmware/apps/avr/avr.c b/firmware/apps/avr/avr.c index c9d0b94..577d878 100644 --- a/firmware/apps/avr/avr.c +++ b/firmware/apps/avr/avr.c @@ -16,8 +16,6 @@ //! Setup the AVR pins. void avrsetup(){ spisetup(); - - glitchsetup(); } //! Initialized an attached AVR. @@ -31,9 +29,9 @@ void avrconnect(){ SETSS; CLRCLK; - delay(500); + delay(10); CLRSS; - delay(500); + delay(10); //Enable programming avr_prgen(); @@ -104,6 +102,11 @@ void avr_erase(){ u8 avr_lockbits(){ return avrexchange(0x58, 0, 0, 0); } +//! Write lock bits. +void avr_setlock(u8 bits){ + avrexchange(0xAC,0xE0,0x00, + bits); +} //! Read a byte of EEPROM. u8 avr_peekeeprom(u16 adr){ @@ -132,8 +135,10 @@ void avrhandle(unsigned char app, unsigned int at; static u8 connected=0; + /* if(!avr_isready() && connected) debugstr("AVR is not yet ready."); + */ switch(verb){ case READ: @@ -162,7 +167,10 @@ void avrhandle(unsigned char app, cmddata[0]=avr_lockbits(); txdata(app,verb,1); break; - + case AVR_POKELOCK: + avr_setlock(cmddata[0]); + txdata(app,verb,0); + break; case AVR_POKEEEPROM: avr_pokeeeprom(cmddataword[0], cmddata[2]); //no break here.