* usbasp.c (usbasp_tpi_paged_load): Calculate correct
buffer address. * usbasp.c (usbasp_tpi_paged_write): Calculate correct buffer address; don't issue a SECTION_ERASE command for each page (a CHIP_ERASE has been done before anyway); remove the code that attempted to handle partial page writes, as all writes are now done with a full page. git-svn-id: svn://svn.savannah.nongnu.org/avrdude/trunk@1191 81a1dc3b-b13d-400b-aceb-764788c761c2
This commit is contained in:
parent
3ec648749d
commit
f747521b39
|
@ -1,3 +1,13 @@
|
|||
2013-09-01 Joerg Wunsch <j.gnu@uriah.heep.sax.de>
|
||||
|
||||
* usbasp.c (usbasp_tpi_paged_load): Calculate correct
|
||||
buffer address.
|
||||
* usbasp.c (usbasp_tpi_paged_write): Calculate correct
|
||||
buffer address; don't issue a SECTION_ERASE command for
|
||||
each page (a CHIP_ERASE has been done before anyway);
|
||||
remove the code that attempted to handle partial page
|
||||
writes, as all writes are now done with a full page.
|
||||
|
||||
2013-09-01 Joerg Wunsch <j.gnu@uriah.heep.sax.de>
|
||||
|
||||
* usbasp.c: Add more trace output, by now only for the TPI
|
||||
|
|
|
@ -1035,7 +1035,7 @@ static int usbasp_tpi_paged_load(PROGRAMMER * pgm, AVRPART * p, AVRMEM * m,
|
|||
fprintf(stderr, "%s: usbasp_tpi_paged_load(\"%s\", 0x%0x, %d)\n",
|
||||
progname, m->desc, addr, n_bytes);
|
||||
|
||||
dptr = m->buf;
|
||||
dptr = addr + m->buf;
|
||||
pr = addr + m->offset;
|
||||
readed = 0;
|
||||
|
||||
|
@ -1070,7 +1070,6 @@ static int usbasp_tpi_paged_write(PROGRAMMER * pgm, AVRPART * p, AVRMEM * m,
|
|||
unsigned int addr, unsigned int n_bytes)
|
||||
{
|
||||
unsigned char cmd[4];
|
||||
unsigned char dummy[8];
|
||||
unsigned char* sptr;
|
||||
int writed, clen, n;
|
||||
uint16_t pr;
|
||||
|
@ -1080,7 +1079,7 @@ static int usbasp_tpi_paged_write(PROGRAMMER * pgm, AVRPART * p, AVRMEM * m,
|
|||
fprintf(stderr, "%s: usbasp_tpi_paged_write(\"%s\", 0x%0x, %d)\n",
|
||||
progname, m->desc, addr, n_bytes);
|
||||
|
||||
sptr = m->buf;
|
||||
sptr = addr + m->buf;
|
||||
pr = addr + m->offset;
|
||||
writed = 0;
|
||||
|
||||
|
@ -1089,15 +1088,6 @@ static int usbasp_tpi_paged_write(PROGRAMMER * pgm, AVRPART * p, AVRMEM * m,
|
|||
usbasp_tpi_send_byte(pgm, (pr & 0xFF) | 1 );
|
||||
usbasp_tpi_send_byte(pgm, TPI_OP_SSTPR(1));
|
||||
usbasp_tpi_send_byte(pgm, (pr >> 8) );
|
||||
/* select SECTIONERASE */
|
||||
usbasp_tpi_send_byte(pgm, TPI_OP_SOUT(NVMCMD));
|
||||
usbasp_tpi_send_byte(pgm, NVMCMD_SECTION_ERASE);
|
||||
/* dummy write */
|
||||
usbasp_tpi_send_byte(pgm, TPI_OP_SST);
|
||||
usbasp_tpi_send_byte(pgm, 0x00);
|
||||
usbasp_tpi_nvm_waitbusy(pgm);
|
||||
|
||||
usleep(p->chip_erase_delay);
|
||||
|
||||
while(writed < n_bytes)
|
||||
{
|
||||
|
@ -1122,28 +1112,6 @@ static int usbasp_tpi_paged_write(PROGRAMMER * pgm, AVRPART * p, AVRMEM * m,
|
|||
sptr += clen;
|
||||
}
|
||||
|
||||
/* finishing write */
|
||||
while(( clen = (-pr) & (m->page_size-1) ) != 0)
|
||||
{
|
||||
if(clen > 8)
|
||||
clen = 8;
|
||||
|
||||
memset(dummy, 0xFF, clen);
|
||||
|
||||
cmd[0] = pr & 0xFF;
|
||||
cmd[1] = pr >> 8;
|
||||
cmd[2] = 0;
|
||||
cmd[3] = 0;
|
||||
n = usbasp_transmit(pgm, 0, USBASP_FUNC_TPI_WRITEBLOCK, cmd, dummy, clen);
|
||||
if(n != clen)
|
||||
{
|
||||
fprintf(stderr, "%s: error: wrong count at writing %x\n", progname, n);
|
||||
return -3;
|
||||
}
|
||||
|
||||
pr += clen;
|
||||
}
|
||||
|
||||
return n_bytes;
|
||||
}
|
||||
|
||||
|
|
Loading…
Reference in New Issue