Forum: Mikrocontroller und Digitale Elektronik SRAM Verwirrung


von Malte Marwedel (Gast)


Lesenswert?

Ich habe ein Programm für eine AT90S8535 (512 Byte Ram) geschrieben. Da
hier ein Effekt auftrat, den ich mir nicht erklären konnte, hab ich das
Programm mal im AVRStudio 4.08 simuliert.

Den beobachtete Effekt konnte ich auch simulieren, unglücklicherweise
hat die Simulation mehr Fragen aufgewofen als beantwortet.

1) Wieso steht der Stack Pointer direkt nach dem Programmstart bei 607?
dürfte es nicht maximal 511 sein?
2) gcc gibt mir nach der Compilierung .data = 148 und .bss = 96 aus.
Von Hand zähle ich ungefähr 120 Byte an globalen Variablen + einige
lokale Konstanten und Variablen. Wieso gibt das AVRStudio die Adresse
einer globalen Variable mit 0x152 = 338 an? das ist doch mehr als .data
+ .bss
3) ist es Zufall, dass 511+ .bss = der Stackpointer beim Programm start
ist?
4) Ordnet der Compiler die Variablen im RAM wirklich ohne Zusammenhang,
mit der Reinfolge der Deklaration im Quelltext, an?

von Hannes Lux (Gast)


Lesenswert?

Hallo...

SRAM beginnt erst bei Adresse 60h.
Darunter im Adressbereich von 00h bis 5fh liegen Register und
I/O-Bereich...

Bit- & Bytebruch... - HanneS...

von Malte Marwedel (Gast)


Lesenswert?

Danke. So ergeben die Zahlen des AVRStudios Sinn.
Den ursprünglichen Fehler hab ich wohl auch gefunden. Ich hatte nicht
daran gedacht, dass eine Variable von einer Interrupt Routine ständig
neu beschrieben wird.

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.