Colin O'Flynn <coflynn@newae.com>

* safemode.c: Stop ignoring return values!
      Closes bug #18339


git-svn-id: svn://svn.savannah.nongnu.org/avrdude/trunk/avrdude@698 81a1dc3b-b13d-400b-aceb-764788c761c2
This commit is contained in:
Colin O Flynn 2006-12-11 14:41:59 +00:00
parent 09af282646
commit 67506bb186
2 changed files with 67 additions and 18 deletions

View File

@ -1,3 +1,9 @@
2006-12-11 Colin O'Flynn <coflynn@newae.com>
* safemode.c: Stop ignoring return values!
Closes bug #18339
2006-12-11 Joerg Wunsch <j@uriah.heep.sax.de> 2006-12-11 Joerg Wunsch <j@uriah.heep.sax.de>
Submitted by Nick Lott: Submitted by Nick Lott:

View File

@ -49,8 +49,14 @@ int safemode_writefuse (unsigned char fuse, char * fusename, PROGRAMMER * pgm,
/* Keep trying to write then read back the fuse values */ /* Keep trying to write then read back the fuse values */
while (tries > 0) { while (tries > 0) {
avr_write_byte(pgm, p, m, 0, fuse); if (avr_write_byte(pgm, p, m, 0, fuse) != 0)
pgm->read_byte(pgm, p, m, 0, &fuseread); {
continue;
}
if (pgm->read_byte(pgm, p, m, 0, &fuseread) != 0)
{
continue;
}
/* Report information to user if needed */ /* Report information to user if needed */
if (verbose > 0) { if (verbose > 0) {
@ -99,11 +105,21 @@ int safemode_readfuses (unsigned char * lfuse, unsigned char * hfuse,
m = avr_locate_mem(p, "fuse"); m = avr_locate_mem(p, "fuse");
if (m != NULL) { if (m != NULL) {
fusegood = 0; /* By default fuse is a failure */ fusegood = 0; /* By default fuse is a failure */
pgm->read_byte(pgm, p, m, 0, &safemode_fuse); if(pgm->read_byte(pgm, p, m, 0, &safemode_fuse) != 0)
pgm->read_byte(pgm, p, m, 0, &value); {
safemode_fuse = 1 + value; //failed - ensure they differ
}
if(pgm->read_byte(pgm, p, m, 0, &value) != 0)
{
value = 1 + safemode_fuse; //failed - ensure they differ
}
if (value == safemode_fuse) { if (value == safemode_fuse) {
pgm->read_byte(pgm, p, m, 0, &value); if (pgm->read_byte(pgm, p, m, 0, &value) != 0)
if (value == safemode_fuse){ {
value = 1 + safemode_fuse;
}
if (value == safemode_fuse)
{
fusegood = 1; /* Fuse read OK three times */ fusegood = 1; /* Fuse read OK three times */
} }
} }
@ -126,10 +142,19 @@ int safemode_readfuses (unsigned char * lfuse, unsigned char * hfuse,
m = avr_locate_mem(p, "lfuse"); m = avr_locate_mem(p, "lfuse");
if (m != NULL) { if (m != NULL) {
fusegood = 0; /* By default fuse is a failure */ fusegood = 0; /* By default fuse is a failure */
pgm->read_byte(pgm, p, m, 0, &safemode_lfuse); if (pgm->read_byte(pgm, p, m, 0, &safemode_lfuse) != 0)
pgm->read_byte(pgm, p, m, 0, &value); {
safemode_lfuse = 1 + value;
}
if (pgm->read_byte(pgm, p, m, 0, &value) != 0)
{
value = safemode_lfuse + 1;
}
if (value == safemode_lfuse) { if (value == safemode_lfuse) {
pgm->read_byte(pgm, p, m, 0, &value); if (pgm->read_byte(pgm, p, m, 0, &value) != 0)
{
value = safemode_lfuse + 1;
}
if (value == safemode_lfuse){ if (value == safemode_lfuse){
fusegood = 1; /* Fuse read OK three times */ fusegood = 1; /* Fuse read OK three times */
} }
@ -152,10 +177,19 @@ int safemode_readfuses (unsigned char * lfuse, unsigned char * hfuse,
m = avr_locate_mem(p, "hfuse"); m = avr_locate_mem(p, "hfuse");
if (m != NULL) { if (m != NULL) {
fusegood = 0; /* By default fuse is a failure */ fusegood = 0; /* By default fuse is a failure */
pgm->read_byte(pgm, p, m, 0, &safemode_hfuse); if (pgm->read_byte(pgm, p, m, 0, &safemode_hfuse) != 0)
pgm->read_byte(pgm, p, m, 0, &value); {
safemode_hfuse = value + 1;
}
if (pgm->read_byte(pgm, p, m, 0, &value) != 0)
{
value = safemode_hfuse + 1;
}
if (value == safemode_hfuse) { if (value == safemode_hfuse) {
pgm->read_byte(pgm, p, m, 0, &value); if (pgm->read_byte(pgm, p, m, 0, &value) != 0)
{
value = safemode_hfuse + 1;
}
if (value == safemode_hfuse){ if (value == safemode_hfuse){
fusegood = 1; /* Fuse read OK three times */ fusegood = 1; /* Fuse read OK three times */
} }
@ -178,10 +212,19 @@ int safemode_readfuses (unsigned char * lfuse, unsigned char * hfuse,
m = avr_locate_mem(p, "efuse"); m = avr_locate_mem(p, "efuse");
if (m != NULL) { if (m != NULL) {
fusegood = 0; /* By default fuse is a failure */ fusegood = 0; /* By default fuse is a failure */
pgm->read_byte(pgm, p, m, 0, &safemode_efuse); if (pgm->read_byte(pgm, p, m, 0, &safemode_efuse) != 0)
pgm->read_byte(pgm, p, m, 0, &value); {
safemode_efuse = value + 1;
}
if (pgm->read_byte(pgm, p, m, 0, &value) != 0)
{
value = safemode_efuse + 1;
}
if (value == safemode_efuse) { if (value == safemode_efuse) {
pgm->read_byte(pgm, p, m, 0, &value); if (pgm->read_byte(pgm, p, m, 0, &value) != 0)
{
value = safemode_efuse + 1;
}
if (value == safemode_efuse){ if (value == safemode_efuse){
fusegood = 1; /* Fuse read OK three times */ fusegood = 1; /* Fuse read OK three times */
} }