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@698 81a1dc3b-b13d-400b-aceb-764788c761c2
This commit is contained in:
parent
10eb9c7f5c
commit
f25cf95909
|
@ -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:
|
||||||
|
|
|
@ -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,13 +105,23 @@ 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);
|
{
|
||||||
if (value == safemode_fuse) {
|
safemode_fuse = 1 + value; //failed - ensure they differ
|
||||||
pgm->read_byte(pgm, p, m, 0, &value);
|
|
||||||
if (value == safemode_fuse){
|
|
||||||
fusegood = 1; /* Fuse read OK three times */
|
|
||||||
}
|
}
|
||||||
|
if(pgm->read_byte(pgm, p, m, 0, &value) != 0)
|
||||||
|
{
|
||||||
|
value = 1 + safemode_fuse; //failed - ensure they differ
|
||||||
|
}
|
||||||
|
if (value == safemode_fuse) {
|
||||||
|
if (pgm->read_byte(pgm, p, m, 0, &value) != 0)
|
||||||
|
{
|
||||||
|
value = 1 + safemode_fuse;
|
||||||
|
}
|
||||||
|
if (value == safemode_fuse)
|
||||||
|
{
|
||||||
|
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 */
|
||||||
}
|
}
|
||||||
|
|
Loading…
Reference in New Issue