Hallo, ich habe wieder mal Probleme mit dem NC30 Compiler von Renesas: Ich verwende viele Bits für verschiedene Einstellungen, die ich über ein Struct deklariere: struct { char Wert1 : 1; char Wert2 : 1; char Wert3 : 1; char Wert4 : 1; char Wert5 : 1; char Wert6 : 1; char Wert7 : 1; char Wert8 : 1; } Settings; Das ganze belegt genau ein Byte an Speicherplatz. Die Einstellungen sollen beim Abschalten in einem EEPROM gesichert werden. Kann man irgendwie sowas machen: EEPSave (Settings); Das funktioniert nicht, da Settings ja keine eigene Variable ist. Da die Daten aber sowiso als Byte im Speicher stehen, wäre es sinnlos die Bits einzeln abzufrage und ein Byte zu konstruieren. Das geht doch bestimmt einfacher ?
union { struct { char Wert1 : 1; char Wert2 : 1; char Wert3 : 1; char Wert4 : 1; char Wert5 : 1; char Wert6 : 1; char Wert7 : 1; char Wert8 : 1; } sSettings; char cSettings; } u; [..] EEPsave(u.cSettings); [..] So in etwa (untested) ...
Du machst das sehr umständlich. Der Zugriff auf Bits mittels Structuren kostet einiges an Rechenzeit. Bei Codevision kann man das so machen: //Makros definieren: #define Tog_Bit(Byte,Led) Byte ^= (1<<Led) //Toggeld Charbit #define Set_Bit(Byte,Led) Byte |= (1<<Led) //Bit setzen #define Clr_Bit(Byte,Led) Byte &= ~(1<<Led) //Bit löschen char Settings; flash char EE_Settings; //Flashvariable definieren Set_Char (Settings,2); //Bit 2 in Settings wird gesetzt Clr_Char (Settings,2); //Bit 2 in Settings wird gelöscht EE_Settings = Settings; //schreiben in Flash Settings = EE_Settings ; //lesen aus Flash //Abfrage der Bits mittels Bitmasken Sg Josef
@ Josef: >Du machst das sehr umständlich. Der Zugriff auf Bits mittels >Structuren kostet einiges an Rechenzeit. Bei uC ohne Bitfunktionen mag dass sein, aber beim M16C wird aus Settings.Wert1=1 bset 0, 543h (bedeutet: setze Bit 0 an Adresse 543h) @OldBug Danke, das könnte funktionieren (zumindest kommt kein Fehler, Settings taucht nirgends bei den Speicherplatzbelegenden Variablen auf und u benötigt genau ein Byte.) Ich werde es dann mal testen ob auch wirklich dasselbe in cSettings steht wie in sSettings.
Das kannst Du allerdings nicht unbedingt einfach durch Maskieren der Bits 0..7 in cSettings machen, da es dem Compiler überlassen ist, wo er welches Bit anlegt. Du musst das dann über sSettings Prüfen! Also Speichern und wieder auslesen. Danach muss in u.sSettings.Wert1 der alte Inhalt stehen usw...
Hi Benedikt, schau Dir mal den Code an, wenn Du schreibst: my_var |= (1<<bit_pos); Ich habe beim nc30 noch nicht geschaut, aber der AVR-gcc macht daraus auch einen einzelnen Bitsetz-Befehl (beim mega8) (natürlich nur bei Registern, die per Bitsetz-Befehl adressierbar sind): 136:buskoppler.c **** led_ddr |= _BV(led_bit); 414 .LM18: 415 004e 8F9A sbi 49-0x20,7 137:buskoppler.c **** led_port |= _BV(led_bit); 417 .LM19: 418 0050 979A sbi 50-0x20,7 Viele Grüße, Stefan
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
Mit Google-Account einloggen
Noch kein Account? Hier anmelden.