-
Path: news-archive.icm.edu.pl!newsfeed.gazeta.pl!news.onet.pl!newsfeed.neostrada.pl!a
tlantis.news.neostrada.pl!news.neostrada.pl!not-for-mail
From: "T.M.F." <t...@n...mp.pl>
Newsgroups: pl.misc.elektronika
Subject: Re: Problem lekko OT, ale w WinAVR ;-)
Date: Sun, 14 Jun 2009 14:20:34 -0400
Organization: TP - http://www.tp.pl/
Lines: 32
Message-ID: <h12qge$hbr$1@nemesis.news.neostrada.pl>
References: <h0qku7$a6o$1@atlantis.news.neostrada.pl>
<h0ud45$219$1@atlantis.news.neostrada.pl> <h0udur$2j2d$1@news.mm.pl>
<h0v0bq$jmg$1@nemesis.news.neostrada.pl>
<h0vhtr$i32$1@atlantis.news.neostrada.pl>
<h0voto$eke$1@nemesis.news.neostrada.pl>
<h0vvnn$q5t$1@nemesis.news.neostrada.pl>
<8...@4...com>
<h101gv$s44$1@nemesis.news.neostrada.pl>
<7...@4...com>
<h103jc$1c4$1@nemesis.news.neostrada.pl>
<6...@4...com>
<h11av0$ivi$1@nemesis.news.neostrada.pl>
<h12dpj$5vq$1@atlantis.news.neostrada.pl>
<h12j6a$hve$1@atlantis.news.neostrada.pl>
Reply-To: t...@n...mp.pl
NNTP-Posting-Host: dvi64.neoplus.adsl.tpnet.pl
Mime-Version: 1.0
Content-Type: text/plain; charset=ISO-8859-2; format=flowed
Content-Transfer-Encoding: 8bit
X-Trace: nemesis.news.neostrada.pl 1244982606 17787 83.22.42.64 (14 Jun 2009 12:30:06
GMT)
X-Complaints-To: u...@n...neostrada.pl
NNTP-Posting-Date: Sun, 14 Jun 2009 12:30:06 +0000 (UTC)
User-Agent: Mozilla/5.0 (X11; U; Linux x86_64; en-US; rv:1.9.1b3pre) Gecko/20090513
Fedora/3.0-2.3.beta2.fc11 Thunderbird/3.0b2
In-Reply-To: <h12j6a$hve$1@atlantis.news.neostrada.pl>
Xref: news-archive.icm.edu.pl pl.misc.elektronika:565387
[ ukryj 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
- Klip testowy, jak sie to używa
- Jak sie smazy elektronike z odleglosci kilkuset metrów?
- William Shockley, co-inventor of the transistor
- Gazowy kocioł CO regulacja cyklingu i regulacja pogodowa
- Zamek elektroniczny
- szablon do pasty DIY
- Głośnik potrzebny
- Silikonowy przewód ekranowany
- Wtyk bananowy ekranowany
- Co może być gorsze od pożaru elektryka?
- daltonizm
- Mały Linux
- Superkondensator. Czy to się uda?
- Stare filmy o technice
- Zasilanie własnych konstrukcji przez PoE
Najnowsze wątki
- 2025-11-08 Klip testowy, jak sie to używa
- 2025-11-08 Warszawa => Senior Cloud Engineer - AWS <=
- 2025-11-08 Pewnie za malo zarabial, to sie musial odstresowac
- 2025-11-08 Uszkodzenie na parkingu a odpowiedzialność sprawcy z OC
- 2025-11-08 Środa Wielkopolska => SAP FI/CO Konsultant wewnętrzny <=
- 2025-11-08 Gdańsk => Senior Software Developer C++ <=
- 2025-11-08 Uszkodzenie na parkingu a odpowiedzialność sprawcy z OC
- 2025-11-08 Warszawa => Programista Microsoft Dynamics 365 Finance & Operations (D
- 2025-11-07 Warszawa => International Freight Forwarder <=
- 2025-11-07 Warszawa => C Programmer <=
- 2025-11-07 Warszawa => Starszy Programista C <=
- 2025-11-07 Warszawa => Senior Programmer C <=
- 2025-11-07 Warszawa => Developer Microsoft Dynamics 365 Finance & Operations (D36
- 2025-11-07 Warszawa => Programista C <=
- 2025-11-07 Warszawa => Asystent ds. Sprzedaży i Rozwoju Klienta <=




Elektromobilność dojrzewa. Auta elektryczne kupujemy z rozsądku, nie dla idei