-
Data: 2009-06-14 18:20:34
Temat: Re: Problem lekko OT, ale w WinAVR ;-)
Od: "T.M.F." <t...@n...mp.pl> szukaj wiadomości tego autora
[ pokaż wszystkie nagłówki ]>> Alez byla. Twoja zmienna jest typu int, czyli ma 2 bajty. AVR nie ma
>> instrukcji ladowania z pamieci 2 bajtow jednoczesnie, a wiec takie
>> przeslanie nie jest atomowe. Dlatego musisz okreslic ta zmienna jako
>> volatile i zapewnic atomowosc operacji przez blokowanie przerwan.
>> Zauwaz, ze gdyby uzyte przeslanie 16-bitowe bylo atomowe to blokowanie
>> przerwan w ogole nie byloby potrzebne.
>
> No dokładnie taki był mój tok rozumowania. Ponieważ pobranie zmiennej
> int wymaga dwóch rozkazów blokuję możliwość przerwania tej operacji
> przez inny wątek poprzedzając je rozkazem cli wstawionym "z palca". W
> momencie gry program staje się jednowątkowy trudno mówić o ulotności
> zmiennych.
Teoretycznie tak. Problem w tym, ze skad kompilator ma wiedziec, ze
wartosc zmiennej moze sie zmieniac poza glownym ciagiem instrukcji? Do
tego wlasnie sluzy volatile. Bez tego kompilator nic nie wie, ze cos
moze zmienic twoja zmienna np. w przerwaniu, w efekcie optymalizuje to
sobie jak uwaza za stosowne i z tego punktu widzenia umiejscowienie cli
w stosunu do pobrania zmiennej jest bez znaczenia.
> P.S. Choroba... w WinAVR_20071221 program wynikowy zajmował 15023 bajty,
> a po skompilowaniu w WinAVR_20090313 wyszło już 16154. Całe szczęście,
> że to nie ATmega16 ;-)
Zapewne problem z bardziej agresywnym inlinowaniem funkcji. Mozna to
wylaczyc.
--
Inteligentny dom - http://idom.wizzard.one.pl
http://idom.sourceforge.net/
Teraz takze forum dyskusyjne
Zobacz, wyslij uwagi, dolacz do projektu.
Następne wpisy z tego wątku
Najnowsze wątki z tej grupy
- Historia pewnego miernika kalibratora
- Ustym 4k Pro i wyświetlacz
- Czemu rozwaliło celę?
- Wojna w portfelu
- Jaki trojfazowy licznik tuya lub podobny?
- Problem z dekoderem adresów
- Intel się wyprzedaje: po 10latach pchnęli pakiet kontrolny Altery za 1/4 kwoty zakupu
- Korekcja perspektywy
- Wentylator zabija zasilacze LEDek?
- Re: Kompensacja mocy biernej przy 230VAC
- Totaliztyczny obowiązek naprawy maszyn i urządzeń
- Niby uziom ale nie
- Położyłem dwa telefony obok siebie
- Przekaźnik na szynę DIN (?)
- Taśma LED
Najnowsze wątki
- 2025-04-22 Drukara a wifi
- 2025-04-22 Rekordowy dług świata w 2024 roku
- 2025-04-22 Miliony nowych, czystych, wypranych ubrań trafiają do kontenerów PCK, aby biedni ich nie dostali
- 2025-04-22 Romanowski
- 2025-04-22 Warszawa => Scrum Master <=
- 2025-04-22 Anrdroid 14 przełączanie aplikacji
- 2025-04-22 Warszawa => Solution Architect <=
- 2025-04-22 Warszawa => Software Solution Architect <=
- 2025-04-22 Warszawa => Senior Account Manager <=
- 2025-04-22 Warszawa => Senior Account Manager <=
- 2025-04-22 Warszawa => Tester Automatyzujący <=
- 2025-04-22 Warszawa => Test Automation Engineer <=
- 2025-04-22 Warszawa => Manual tester <=
- 2025-04-22 Warszawa => Administrator Systemów OSS <=
- 2025-04-22 Kto chce produkować wodór z solarów w południe, gdy sieć odłącza solary >?