Forum: Compiler & IDEs EEProm - Problem


von Nucor (Gast)


Angehängte Dateien:

Lesenswert?

Hi,

ich hab' ein Problem mit dem Lesen des Eeproms bei einem Atmega64.
Beim Lesen einer EEProm - Zelle führt der Prozessor einen ungewollten 
Sprung nach Adresse 2C aus.

Jörg Wünsch hatte mich vor einiger Zeit gescholten, daß ich dem Problem 
nicht weiter nachgegangen bin.
Im Moment habe mehr Zeit und konnte die Problemstelle näher eingrenzen.

Im Anhang sind 3 Bitmaps (aus Platzgründen gezippt)


- EEprom ist der inline C - Code

- in Exit ist die Absprungstelle markiert

- JmpTable zeigt die danach fehlerhaft angesprungene Adresse



also:

an Adresse A34 steht der Befehl ST X,R24

X ist 3C, R24 enthält 1, trotzdem wird als nächstes 2C angesprungen,
warum ?


der Prozessor ist ein Atmega64
die SW-Version ist WinAVR-20080610
die Codeoptimierung ist ausgeschaltet -O0 (mit -Os tritt der
 Fehler übrigens nicht auf)
die Codegrösse beträgt ohne Optimierung 30166 Byte

Zum Testen steht ein JTAG-Adapter zur Verfügung. An Adresse A34 wurde
ein Breakpoint gesetzt,
dann ein Singlestep ausgeführt. Das Problem tritt auch ohne
JTAG-Adapter auf.


Dieselben EEpromzellen werden an mehreren anderen Stellen mit
derselben Routine "eeprom_read_byte" problemlos gelesen.


mfg

Nucor

von Falk B. (falk)


Lesenswert?

@ Nucor (Gast)

>Dateianhang: Bitmaps.zip (113 KB, 7 Downloads)

Du schiesst wirklich den Vogel ab. Soviel EDV-Unwissen kann keiner 
allein haben. RESPEKT.

Lies mal was über Bildformate.

MFG
Falk

von Falk B. (falk)


Lesenswert?

@ Nucor (Gast)

>die Codeoptimierung ist ausgeschaltet -O0 (mit -Os tritt der
> Fehler übrigens nicht auf)

Dann schalt sie doch einfach ein!
Und ausserdem wurde doch schon festgestellt, dass das ein BUG in diesem 
AVR Typen ist. Fertig.

MFG
Falk

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.