eGospodarka.pl
eGospodarka.pl poleca

eGospodarka.plGrupypl.misc.elektronikaAVR ATmega, pomiar częstotliwości przebiegu, prośba o sprawdzenie koduRe: AVR ATmega, pomiar częstotliwości przebiegu, prośba o sprawdzenie kodu
  • Path: news-archive.icm.edu.pl!news.gazeta.pl!newsfeed.pionier.net.pl!newsfeed.straub-
    nv.de!news.mixmin.net!eweka.nl!hq-usenetpeers.eweka.nl!193.201.147.79.MISMATCH!
    hitnews.eu!feeder2.cambriumusenet.nl!feed.tweaknews.nl!209.197.12.242.MISMATCH!
    nx01.iad01.newshosting.com!newshosting.com!newsfeed.neostrada.pl!unt-exc-01.new
    s.neostrada.pl!unt-spo-a-02.news.neostrada.pl!news.neostrada.pl.POSTED!not-for-
    mail
    Date: Thu, 10 Feb 2011 19:35:49 +0100
    From: Zbych <a...@o...pl>
    User-Agent: Mozilla/5.0 (Windows; U; Windows NT 5.1; pl; rv:1.9.2.13) Gecko/20101207
    Thunderbird/3.1.7
    MIME-Version: 1.0
    Newsgroups: pl.misc.elektronika
    Subject: Re: AVR ATmega, pomiar częstotliwości przebiegu, prośba o sprawdzenie
    kodu
    References: <4d528e6b$0$2436$65785112@news.neostrada.pl>
    <4d52df8e$0$2452$65785112@news.neostrada.pl>
    <4d53ffa7$0$2504$65785112@news.neostrada.pl>
    <4d540151$0$2457$65785112@news.neostrada.pl> <ij1236$va6$1@news.onet.pl>
    In-Reply-To: <ij1236$va6$1@news.onet.pl>
    Content-Type: text/plain; charset=ISO-8859-2; format=flowed
    Content-Transfer-Encoding: 8bit
    Lines: 27
    Message-ID: <4d543005$0$2448$65785112@news.neostrada.pl>
    Organization: Telekomunikacja Polska
    NNTP-Posting-Host: 83.5.58.161
    X-Trace: 1297362949 unt-rea-b-01.news.neostrada.pl 2448 83.5.58.161:1138
    X-Complaints-To: a...@n...neostrada.pl
    Xref: news-archive.icm.edu.pl pl.misc.elektronika:604611
    [ ukryj nagłówki ]

    W dniu 2011-02-10 17:00, Michoo pisze:
    > W dniu 10.02.2011 16:16, Zbych pisze:
    >> Nie używaj cli i sei do robienia sekcji atomowych, te makra nie są
    >> zabezpieczone przed optymalizacją i kompilator może zmienić kolejność
    >> instrukcji (choć oczywiście nie musi).
    > Chyba nie - definicja wyglądają tak:
    > # define sei() __asm__ __volatile__ ("sei" ::)
    > # define cli() __asm__ __volatile__ ("cli" ::)
    >
    > Co zabrania kompilatorowi zamiany kolejności ewaluacji wyrażeń.

    volatile zabrania usunięcia, optymalizacji, ale nie zabroni przesunięcia
    czegoś co jest pomiędzy sei i cli, czyli z kodu
    cli();[coś];sei();
    może wyjść:
    cli();sei(); [coś];

    Dodatkowo taka konstrukcja nie zmusza kompilatora do zapisania wartości
    tymczasowych trzymanych w rejestrach do pamięci, więc może się okazać,
    że zapis wielobajtowej zmiennej nastąpi już przy włączonych przerwaniach.

    Przykłady można znaleźć na liście dyskusyjnej avr-gcc.

    > Dziwne swoją drogą, że nie jest to zapisane na wszelki wypadek jako
    > # define sei() __asm__ __volatile__ ("sei" :::"memory")

    No właśnie o tę barierę na pamięci chodzi.

Podziel się

Poleć ten post znajomemu poleć

Wydrukuj ten post drukuj


Następne wpisy z tego wątku

Najnowsze wątki z tej grupy


Najnowsze wątki

Szukaj w grupach

Eksperci egospodarka.pl

1 1 1

Wpisz nazwę miasta, dla którego chcesz znaleźć jednostkę ZUS.

Wzory dokumentów

Bezpłatne wzory dokumentów i formularzy.
Wyszukaj i pobierz za darmo: