eGospodarka.pl
eGospodarka.pl poleca

eGospodarka.plGrupypl.misc.elektronikaAVR ATmega, pomiar częstotliwości przebiegu, prośba o sprawdzenie kodu › Re: AVR ATmega, pomiar częstotliwości przebiegu, prośba o sprawdzenie kodu
  • Path: news-archive.icm.edu.pl!news.rmf.pl!agh.edu.pl!news.agh.edu.pl!news.onet.pl!new
    s.nask.pl!news.nask.org.pl!newsfeed2.atman.pl!newsfeed.atman.pl!newsfeed.neostr
    ada.pl!unt-exc-01.news.neostrada.pl!unt-spo-a-02.news.neostrada.pl!news.neostra
    da.pl.POSTED!not-for-mail
    Date: Fri, 11 Feb 2011 08:36:54 +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>
    <4d543005$0$2448$65785112@news.neostrada.pl> <ij1leg$ciq$1@news.onet.pl>
    In-Reply-To: <ij1leg$ciq$1@news.onet.pl>
    Content-Type: text/plain; charset=ISO-8859-2; format=flowed
    Content-Transfer-Encoding: 8bit
    Lines: 37
    Message-ID: <4d54e717$0$2460$65785112@news.neostrada.pl>
    Organization: Telekomunikacja Polska
    NNTP-Posting-Host: 83.10.188.79
    X-Trace: 1297409815 unt-rea-a-01.news.neostrada.pl 2460 83.10.188.79:1377
    X-Complaints-To: a...@n...neostrada.pl
    Xref: news-archive.icm.edu.pl pl.misc.elektronika:604643
    [ ukryj nagłówki ]

    W dniu 2011-02-10 22:31, Michoo pisze:

    > Tylko jeżeli [coś] jest kiepskim kodem ;) - Używanie w sekcji krytycznej
    > czegoś co nie jest volatile i nie zawiera bariery na przesyłanej
    > zmiennej jest sprzeczne zarówno ze standardem jak i ze zdrowym rozsądkiem.

    Pokaż mi gdzie jest to napisane w standardzie. Ja wtykanie volatile
    wszędzie gdzie się da uważam co najmniej za lenistwo. Jak już muszę użyć
    to często robię unię zmiennej volatile i bez volatile. Dzięki czemu nie
    mam nadmiarowego kodu np. w przerwaniach.

    >> 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.
    > Masz może linkę? Bo na szybko nie mogłem znaleźć.

    Nie chce mi się szukać. Musisz przejrzeć daty w okolicach dodania makr
    ATOMIC do biblioteki. Te makra powstały właśnie po tym jak ludzie
    zaczęli zgłaszać błędy związane przenoszeniem operacji poza blok
    cli()-sei().

    >>> 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.
    > Tylko bariera jest wolna i nieoptymalna.

    Ta bariera nie jest wolniejsza niż używanie volatile. Wymusza tylko
    zrzut i pobranie zmiennych.

    > cli();[operacje bez synchronizacji]sei();
    > - robi to co programista napisał a nie to co chciał, ale C jest znane z
    > tego że pozwala się postrzelić w stopę

    Tia, temat na kolejne bicie piany :-)

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: