Forum: Mikrocontroller und Digitale Elektronik ATmega168, AVRDude, efuse fehler


von gast (Gast)


Lesenswert?

Hallo,

ich hab ein kleines Problem beim flashen eines ATmega168 mit AVRDude.

Der von mir verwendete Programmieradapter funktioniert sonst mit 
ATmega16 einwandfrei, nur beim ATmega168 macht er beim efuse 
Schwierigkeiten.

Ich hoffe Ihr könnt mir helfen.

Vielen Dank für euere Bemühungen.

WindowsXP auf der Komandozeile:
1
C:\avrdude -c stk200 -P lpt1 -p m168 -e -U lfuse
2
:w:0xE2:m -U hfuse:w:0xDC:m -U efuse:w:0xF8:m -E reset
3
4
avrdude: AVR device initialized and ready to accept instructions
5
6
Reading | ################################################## | 100% 0.00s
7
8
avrdude: Device signature = 0x1e9406
9
avrdude: erasing chip
10
avrdude: reading input file "0xE2"
11
avrdude: writing lfuse (1 bytes):
12
13
Writing | ################################################## | 100% 0.00s
14
15
avrdude: 1 bytes of lfuse written
16
avrdude: verifying lfuse memory against 0xE2:
17
avrdude: load data lfuse data from input file 0xE2:
18
avrdude: input file 0xE2 contains 1 bytes
19
avrdude: reading on-chip lfuse data:
20
21
Reading | ################################################## | 100% 0.01s
22
23
avrdude: verifying ...
24
avrdude: 1 bytes of lfuse verified
25
avrdude: reading input file "0xDC"
26
avrdude: writing hfuse (1 bytes):
27
28
Writing | ################################################## | 100% 0.00s
29
30
avrdude: 1 bytes of hfuse written
31
avrdude: verifying hfuse memory against 0xDC:
32
avrdude: load data hfuse data from input file 0xDC:
33
avrdude: input file 0xDC contains 1 bytes
34
avrdude: reading on-chip hfuse data:
35
36
Reading | ################################################## | 100% 0.01s
37
38
avrdude: verifying ...
39
avrdude: 1 bytes of hfuse verified
40
avrdude: reading input file "0xF8"
41
avrdude: writing efuse (1 bytes):
42
43
Writing |                                                    | 0% 0.00s ***faile
44
d;
45
Writing | ################################################## | 100% 0.06s
46
47
avrdude: 1 bytes of efuse written
48
avrdude: verifying efuse memory against 0xF8:
49
avrdude: load data efuse data from input file 0xF8:
50
avrdude: input file 0xF8 contains 1 bytes
51
avrdude: reading on-chip efuse data:
52
53
Reading | ################################################## | 100% 0.00s
54
55
avrdude: verifying ...
56
avrdude: verification error, first mismatch at byte 0x0000
57
         0xf8 != 0x00
58
avrdude: verification error; content mismatch
59
60
avrdude: safemode: efuse changed! Was f8, and is now 0
61
Would you like this fuse to be changed back? [y/n] n
62
avrdude: safemode: Fuses OK
63
64
avrdude done.  Thank you.
65
66
C:\

von Stefan B. (stefan) Benutzerseite


Lesenswert?

Möglicherweise ein zu altes AVRDUDE (avrdude.conf). Du kannst die 
AVRDUDE Version herausfinden, wenn du -v oder -vv oder -vvv in der 
Kommandozeile angibst.

http://www.mail-archive.com/avrdude-dev@nongnu.org/msg01597.html
http://www.mail-archive.com/avrdude-dev@nongnu.org/msg01561.html

von gast (Gast)


Lesenswert?

Auf den ersten blick sieht es so aus als ob meine version neuer als in 
dem link genannte zu sein. Aber das genaue Build wird mit -v nicht 
ausgegeben.

Ist das bei WinAVR-20081205 mitgelieferte AvrDude.
1
avrdude: Version 5.6cvs, compiled on Nov 10 2008 at 17:15:38
2
         Copyright (c) 2000-2005 Brian Dean, http://www.bdmicro.com/

von Stefan B. (stefan) Benutzerseite


Lesenswert?

Die Lösung steht hier
http://tinker.it/now/2007/02/24/the-tale-of-avrdude-atmega168-and-extended-bits-fuses/

Und wenn ich etwas genauer auf deine Kommandozeile und den Bugreport 
gesehen hätte, hätte ich es auch merken müssen ;-)

Kurzfassung: Du kannst keine 0xF8 in die efuse des Atmega168 schreiben!

Bei dem Atmega168 sind nur die untersten 3 Bits der efuse beschreibbar, 
d.h. der Wert 0xF8 (11111000) ist eigentlich ein 0x00 (00000000) und 
genau das bekommst du beim Verify zurück!

Kontrolliere die Quelle aus der du die 0xF8 hast und was damit bezweckt 
werden sollte. Wenn es darum geht, einen 1024 Word Bootloader zu 
schützen und den per Reset anzuspringen, dann ändere die Kommandozeile 
und alles wird gut.

C:\avrdude -c stk200 -P lpt1 -p m168 -e -U lfuse
:w:0xE2:m -U hfuse:w:0xDC:m -U efuse:w:0x0:m -E reset

von gast (Gast)


Lesenswert?

Stimmt, 0xF8 sollte den Bootloaderbereich mit 1024 Word aktivieren.

Hier ein Link zu meiner Quelle.
Den Administrator hab ich über diesen Fehler benachrichtigt.
http://www.engbedded.com/fusecalc/
http://www.engbedded.com/cgi-bin/fc.cgi

Vielen Dank für Deine Hilfe.

von Mark Hämmerling (Gast)


Lesenswert?

Hallo,

ist lange her, dass ich hier mal was geschrieben habe. :)

Habe den Fehler behoben. Ich habe mich durch die Default-Werte in der 
Tabelle irritieren lassen, die ja trotz undefinierter Fuse-Bits auf 
"unprogrammed" ('1') stehen. Jetzt habe ich die Randnotiz (werden als 
'0' gelesen) auch gesehen. :)

Im Calculator werden jetzt global alle nicht-definierten Bits auf '0' 
ausmaskiert. Also auch aus Pseudo-Werten, die man über die 
Hex-Direkteingabe übertragen hat.

Danke für den Hinweis.

Viel Spaß weiterhin mit dem Tool!

Mark

von Mark Hämmerling (Gast)


Lesenswert?

Hallo nochmal,

also ganz so einfach ist es offensichtlich doch nicht. Dass undefinierte 
Fuse-Bits als '0' gelesen werden, trifft offensichtlich nur auf einen 
Teil der AVRs zu. Seit ich die Änderung (s.o.) gemacht habe, häufen sich 
die Bugreports, dass die Bits auf '1' stehen müssten. Und tatsächlich 
trifft das auf diese Targets zu (z.B. m644, t*4). Nun hab ich mir 
nochmal das XML-File vom m168 angesehen und selbst Atmel schreibt dort 
als Default-Wert für die "ExtendedFuse" einen Wert von 0xf9, also mit 
'1' in den undefinierten Bits.

Wer hat eine gute Idee, wie ich die Bits nun behandeln soll? Meiner 
Meinung nach sollten sie doch wieder als '1' angezeigt werden. Wenn es 
selbst Atmel so schreibt. Man darf halt den Verify-Error von avrdude 
nicht so ernst nehmen.

Ich tendiere dazu, die Bits wieder als '1' anzuzeigen und einen 
Hinweistext bzgl. evtl. auftretender Verify-Errors dazu zu schreiben. 
Was meint Ihr?

Grüße,
Mark

von Stefan B. (stefan) Benutzerseite


Lesenswert?

Mark Hämmerling wrote:

> Ich tendiere dazu, die Bits wieder als '1' anzuzeigen und einen
> Hinweistext bzgl. evtl. auftretender Verify-Errors dazu zu schreiben.
> Was meint Ihr?

An der offiziellen Doku bleiben plus die Idee mit dem Hinweistext finde 
ich gut.

von Mark Hämmerling (Gast)


Lesenswert?

Hallo,

also auch eine '1' als zu programmierenden Wert ausweisen, auch wenn die 
undefinierten Bits bei dem Device als '0' gelesen werden? Es sollte ja 
nicht schaden, eine '1' in ein undef. Bit zu schreiben. Ich will halt 
nur die Verwunderung der User bei Verify-Fehlern begrenzen.

Mark

von Mark Hämmerling (Gast)


Lesenswert?

Hallo,

http://www.engbedded.com/fusecalc/

Version 0.8.0 beinhaltet nun diese Warnmeldungen, sobald sich die Werte 
unterscheiden.

Mark

von alex (Gast)


Lesenswert?

Hallo zusammen.

Versuche gerade mit avrdude einen atmega168p zu programmieren.
In der avrdude.conf gibt es aber keine configuration von diesem chip.
kann mir jemand helfen wie ich eine configuration von diesem chip machen 
kann.

von Jörg W. (dl8dtl) (Moderator) Benutzerseite


Lesenswert?

alex schrieb:

> kann mir jemand helfen wie ich eine configuration von diesem chip machen
> kann.

Es sollte genügen, die Konfiguration des ATmega168 zu clonen und
die device ID darin zu ersetzen.

Bitte melde dich an um einen Beitrag zu schreiben. Anmeldung ist kostenlos und dauert nur eine Minute.
Bestehender Account
Schon ein Account bei Google/GoogleMail? Keine Anmeldung erforderlich!
Mit Google-Account einloggen
Noch kein Account? Hier anmelden.