avrftdi_tpi.c: Adds avrftdi_tpi_disable()

In this function the NVM enable bit in TPISR is written to zero, like
described in AVR918. The reset line is released in avrftdi_close().

git-svn-id: svn://svn.savannah.nongnu.org/avrdude/trunk@1149 81a1dc3b-b13d-400b-aceb-764788c761c2
This commit is contained in:
Hannes Weisbach 2013-05-02 11:06:45 +00:00
parent 848cf9b55d
commit 91c6cdfdea
1 changed files with 16 additions and 4 deletions

View File

@ -20,6 +20,8 @@
#include <libusb-1.0/libusb.h> #include <libusb-1.0/libusb.h>
#include <libftdi1/ftdi.h> #include <libftdi1/ftdi.h>
static void avrftdi_tpi_disable(PROGRAMMER *);
static void static void
avrftdi_debug_frame(uint16_t frame) avrftdi_debug_frame(uint16_t frame)
{ {
@ -75,8 +77,10 @@ avrftdi_tpi_initialize(PROGRAMMER * pgm, AVRPART * p)
pgm->program_enable = avrftdi_tpi_program_enable; pgm->program_enable = avrftdi_tpi_program_enable;
pgm->cmd_tpi = avrftdi_cmd_tpi; pgm->cmd_tpi = avrftdi_cmd_tpi;
pgm->chip_erase = avrftdi_tpi_chip_erase; pgm->chip_erase = avrftdi_tpi_chip_erase;
//pgm->read_byte = avrftdi_tpi_read_byte; pgm->disable = avrftdi_tpi_disable;
//pgm->write_byte = avrftdi_tpi_write_byte;
pgm->paged_load = NULL;
pgm->paged_write = NULL;
log_info("Setting /Reset pin low\n"); log_info("Setting /Reset pin low\n");
pdata->set_pin(pgm, PIN_AVR_RESET, OFF); pdata->set_pin(pgm, PIN_AVR_RESET, OFF);
@ -344,6 +348,14 @@ avrftdi_tpi_chip_erase(PROGRAMMER * pgm, AVRPART * p)
return 0; return 0;
} }
static void
avrftdi_tpi_disable(PROGRAMMER * pgm)
{
log_info("Leaving Programming mode.\n");
avrftdi_tpi_write_byte(pgm, TPI_OP_SSTCS(TPIPCR));
avrftdi_tpi_write_byte(pgm, 0);
}
#else /*HAVE_LIBFTDI*/ #else /*HAVE_LIBFTDI*/
#endif /* HAVE_LIBFTDI */ #endif /* HAVE_LIBFTDI */