software:avr-gcc
Unterschiede
Hier werden die Unterschiede zwischen zwei Versionen angezeigt.
Beide Seiten der vorigen RevisionVorhergehende ÜberarbeitungNächste Überarbeitung | Vorhergehende Überarbeitung | ||
software:avr-gcc [2013/08/06 22:11] – [Zufallszahlen erzeugen] olli | software:avr-gcc [2018/02/24 07:18] (aktuell) – [Links] olli | ||
---|---|---|---|
Zeile 9: | Zeile 9: | ||
Legt man eine Konstante mit <code c> const uint8_t constant = 2; </ | Legt man eine Konstante mit <code c> const uint8_t constant = 2; </ | ||
Platz, denn verändert werden darf der Wert der Konstante sowieso nicht. Soll das automatische Laden in das RAM verhindert werden, muss das Schlüsselword PROGMEM verwendet werden: | Platz, denn verändert werden darf der Wert der Konstante sowieso nicht. Soll das automatische Laden in das RAM verhindert werden, muss das Schlüsselword PROGMEM verwendet werden: | ||
- | <code c> const PROGMEM uint8_t constant = 2; </ | + | <code c> const PROGMEM uint8_t constant = 2; </ |
<code c> | <code c> | ||
const char stringInRAM[] = " | const char stringInRAM[] = " | ||
Zeile 16: | Zeile 16: | ||
lcd_string_P(stringInFlash); | lcd_string_P(stringInFlash); | ||
</ | </ | ||
- | Häufig werden | + | Häufig werden |
<code c> | <code c> | ||
lcd_string(" | lcd_string(" | ||
Zeile 32: | Zeile 32: | ||
}; | }; | ||
</ | </ | ||
- | Hier bei liegt die Variable index und der Pointer auf den String im Flash, der String selbst liegt aber noch im RAM. Um das zu verhindern, muss er wie folgt definiert werden (eine Verwendung des PSTR-Makros ist hier nicht möglich): | + | Hierbei |
<code c> | <code c> | ||
typedef struct{ | typedef struct{ | ||
Zeile 63: | Zeile 63: | ||
</ | </ | ||
kann man dann den Linker anweisen, unbenutzte Sections zu entfernen, so dass das entstehende Binary kleiner wird. | kann man dann den Linker anweisen, unbenutzte Sections zu entfernen, so dass das entstehende Binary kleiner wird. | ||
+ | |||
+ | <WRAP important round> | ||
+ | // | ||
+ | Damit Interrupthandler nicht entfernt werden, müssen sie mit | ||
+ | <code c> | ||
+ | __attribute__ ((used)) | ||
+ | </ | ||
+ | gekennzeichnet werden. | ||
+ | </ | ||
+ | |||
+ | ====== PIN, PORT und DDR mit einem define anpassen ====== | ||
+ | Um einen Pin am AVR zu konfigurieren und zu benutzen, benötigt man die drei Variablen PINX, PORTX, DDRX. | ||
+ | Um dies konfigurierbar zu machen, kann man drei defines verwenden: | ||
+ | <code c> | ||
+ | #define SENSOR_DDR DDRA | ||
+ | #define SENSOR_PORT PORTA | ||
+ | #define SENSOR_PIN PINA | ||
+ | </ | ||
+ | Möchte man den Port z.B. von A auf B ändern, muss man drei defines anpassen. Mit einem Makrotrick kann man das vermeiden. PINX, PORTX, und DDRX werden so definiert: | ||
+ | |||
+ | <code c> | ||
+ | #define SENSOR_DDR __CONCAT(DDR, | ||
+ | #define SENSOR_PORT __CONCAT(PORT, | ||
+ | #define SENSOR_PIN __CONCAT(PIN, | ||
+ | </ | ||
+ | |||
+ | Mit | ||
+ | <code c> | ||
+ | #define SENSOR_PORT_LETTER A | ||
+ | </ | ||
+ | lässt sich dann der Buchstabe für alle drei Variablen anpassen. Das Makro %%__CONCAT%% ist dabei wie folgt definiert: | ||
+ | <code c> | ||
+ | #define __CONCATenate(left, | ||
+ | #define __CONCAT(left, | ||
+ | </ | ||
+ | Man kann diese Makros selbst definieren oder die Definition aus dem Header stdint.h benutzen, da man diesen sowieso fast immer inkludiert. | ||
===== Links ===== | ===== Links ===== | ||
- | * [[http:// | + | * [[http:// |
+ | * [[https://godbolt.org/|Compiler-Explorer]] | ||
+ | |||
software/avr-gcc.1375819887.txt.gz · Zuletzt geändert: 2013/08/06 22:11 von olli