* 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>
|
2013-09-01 Joerg Wunsch <j.gnu@uriah.heep.sax.de>
|
||||||
|
|
||||||
* usbasp.c: Add more trace output, by now only for the TPI
|
* 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",
|
fprintf(stderr, "%s: usbasp_tpi_paged_load(\"%s\", 0x%0x, %d)\n",
|
||||||
progname, m->desc, addr, n_bytes);
|
progname, m->desc, addr, n_bytes);
|
||||||
|
|
||||||
dptr = m->buf;
|
dptr = addr + m->buf;
|
||||||
pr = addr + m->offset;
|
pr = addr + m->offset;
|
||||||
readed = 0;
|
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 int addr, unsigned int n_bytes)
|
||||||
{
|
{
|
||||||
unsigned char cmd[4];
|
unsigned char cmd[4];
|
||||||
unsigned char dummy[8];
|
|
||||||
unsigned char* sptr;
|
unsigned char* sptr;
|
||||||
int writed, clen, n;
|
int writed, clen, n;
|
||||||
uint16_t pr;
|
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",
|
fprintf(stderr, "%s: usbasp_tpi_paged_write(\"%s\", 0x%0x, %d)\n",
|
||||||
progname, m->desc, addr, n_bytes);
|
progname, m->desc, addr, n_bytes);
|
||||||
|
|
||||||
sptr = m->buf;
|
sptr = addr + m->buf;
|
||||||
pr = addr + m->offset;
|
pr = addr + m->offset;
|
||||||
writed = 0;
|
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, (pr & 0xFF) | 1 );
|
||||||
usbasp_tpi_send_byte(pgm, TPI_OP_SSTPR(1));
|
usbasp_tpi_send_byte(pgm, TPI_OP_SSTPR(1));
|
||||||
usbasp_tpi_send_byte(pgm, (pr >> 8) );
|
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)
|
while(writed < n_bytes)
|
||||||
{
|
{
|
||||||
|
@ -1122,28 +1112,6 @@ static int usbasp_tpi_paged_write(PROGRAMMER * pgm, AVRPART * p, AVRMEM * m,
|
||||||
sptr += clen;
|
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;
|
return n_bytes;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
Loading…
Reference in New Issue