www.mikrocontroller.net

Forum: Mikrocontroller und Digitale Elektronik Wieso kann avr-gcc Register wie eine Variablen-Zuweisung benutzen?


Autor: X. H. (shadow0815)
Datum:

Bewertung
0 lesenswert
nicht lesenswert
---
Beispiel "inspiriert" durch Beitrag:
Beitrag "zeitfunktion "_delay_ms()""
Beitrag mit der Uhrzeit 16:54
---
------------------------------------------------------------------------ 
------------------
#define _BV(bit) (1 << (bit))
#define SREG      _SFR_IO8(0x3F)
#define _SFR_IO8(io_addr) ((io_addr) + __SFR_OFFSET)
#define __SFR_OFFSET 0x20
#define    SREG_I       7
------------------------------------------------------------------------ 
------------------
SREG &= ~_BV(SREG_I);
_SFR_IO8(0x3F) &= ~_BV(SREG_I);
((0x3F) + __SFR_OFFSET) &= ~_BV(SREG_I);
((0x3F) + 0x20) &= ~_BV(SREG_I);
((0x3F) + 0x20) &= ~(1 << (SREG_I));
((0x3F) + 0x20) &= ~(1 << (7));
(0x5F) &= ~(1 << (7));
(0x5F) = (0x5F) & ~(1 << (7));
(0x5F) = (0x5F) & 0x7F;
------------------------------------------------------------------------ 
------------------

Woher weis avr-gcc, dass die Operation (und anschließende Zuweisung)
(0x5F) = (0x5F) & 0x7F;
Mit dem Inhalt des SFR-Registers 0x5F gemacht werden soll?

Ist _SFR_IO8 nicht einfach nur ein Makro, sondern der Präprozessor teilt 
dem avr-gcc irgendwie mit, dass das "avr-Spezifische Schlüsselwort" 
_SFR_IO8 gefunden wurde weshalb der
Compiler weis, das die Auflösung des Makro-Ausdrucks einen "Zeiger auf 
SFR-Register" darstellen soll?

Andernfalls hätte ich eine ungültige Zuweisung (und nicht gewollte 
Rechenoperation mit dem Literal 0x5F) an den Literal 0x5F

Laut Datenblatt sind 0x3F (0x5F) SREG gleichwertige Adressen? Warum 
nochmal zwei Adressräume?

Autor: A. K. (prx)
Datum:

Bewertung
0 lesenswert
nicht lesenswert
Was der Compiler bei SREG &= ~_BV(SREG_I); tatsächlich sieht:
  (*(volatile uint8_t *)((0x3F) + 0x20)) &= ~(1 << ((7)));

Wie man das rauskriegt: avr-gcc -E

Antwort schreiben

Die Angabe einer E-Mail-Adresse ist freiwillig. Wenn Sie automatisch per E-Mail über Antworten auf Ihren Beitrag informiert werden möchten, melden Sie sich bitte an.

Wichtige Regeln - erst lesen, dann posten!

  • Groß- und Kleinschreibung verwenden
  • Längeren Sourcecode nicht im Text einfügen, sondern als Dateianhang

Formatierung (mehr Informationen...)

  • [c]C-Code[/c]
  • [avrasm]AVR-Assembler-Code[/avrasm]
  • [code]Code in anderen Sprachen, ASCII-Zeichnungen[/code]
  • [math]Formel in LaTeX-Syntax[/math]
  • [[Titel]] - Link zu Artikel
  • Verweis auf anderen Beitrag einfügen: Rechtsklick auf Beitragstitel,
    "Adresse kopieren", und in den Text einfügen




Bild automatisch verkleinern, falls nötig
Bitte das JPG-Format nur für Fotos und Scans verwenden!
Zeichnungen und Screenshots im PNG- oder
GIF-Format hochladen. Siehe Bildformate.
Hinweis: der ursprüngliche Beitrag ist mehr als 6 Monate alt.
Bitte hier nur auf die ursprüngliche Frage antworten,
für neue Fragen einen neuen Beitrag erstellen.

Mit dem Abschicken bestätigst du, die Nutzungsbedingungen anzuerkennen.