eGospodarka.pl
eGospodarka.pl poleca

eGospodarka.plGrupypl.misc.elektronikaZagwozdka w C Keil.Re: Zagwozdka w C Keil - wyjaśnienie.
  • Path: news-archive.icm.edu.pl!news.icm.edu.pl!news.chmurka.net!.POSTED.pi.v.chmurka.n
    et!not-for-mail
    From: q...@t...no1 (Queequeg)
    Newsgroups: pl.misc.elektronika
    Subject: Re: Zagwozdka w C Keil - wyjaśnienie.
    Date: Thu, 14 Feb 2019 10:59:24 +0000 (UTC)
    Organization: news.chmurka.net
    Message-ID: <c...@t...no1>
    References: <q3q59d$hp9$1@node1.news.atman.pl> <q3vee4$o74$1@node1.news.atman.pl>
    <5c63f185$0$476$65785112@news.neostrada.pl>
    <e...@t...no1>
    <y...@4...net>
    <q424f8$8b4$1@node2.news.atman.pl>
    <5c650c2f$0$5597$426a74cc@news.free.fr>
    <5c6544d5$0$486$65785112@news.neostrada.pl>
    NNTP-Posting-Host: pi.v.chmurka.net
    Mime-Version: 1.0
    Content-Type: text/plain; charset=ISO-8859-2
    Content-Transfer-Encoding: 8bit
    Injection-Date: Thu, 14 Feb 2019 10:59:24 +0000 (UTC)
    Injection-Info: news.chmurka.net; posting-account="gof";
    posting-host="pi.v.chmurka.net:172.24.44.20"; logging-data="12346";
    mail-complaints-to="abuse-news.(at).chmurka.net"
    User-Agent: tin/2.4.2-20171224 ("Lochhead") (UNIX) (Linux/4.4.50-v7+ (armv7l))
    Cancel-Lock: sha1:bgUn4mtgt+jA0UZOHb+74Y8hWRU=
    Xref: news-archive.icm.edu.pl pl.misc.elektronika:741018
    [ ukryj nagłówki ]

    J.F. <j...@p...onet.pl> wrote:

    > Cos w tym jest, ale z drugiej strony - skoro uzywamy volatile, to
    > wiadomo ze zmienna moze sie zmieniac w przerwaniach czy w inny
    > niekontrolowany sposob, i co - kompilator to olewa ?

    Ale co kompilator może zrobić, jak sam procesor nie obsługuje atomicznego
    dostępu do tej zmiennej (bo np. jest 8-bitowy, a zmienna 16-bitowa)?
    Zresztą nawet w przypadku zmiennych o rozmiarze równym szerokości
    magistrali danych nie ma gwarancji chociażby w przypadku operacji
    read-modify-write. Przykład:

    #v+ test.c
    volatile int i;
    void fn(void) { ++i; }
    #v-

    #v+ test.s
    ldr r3, [r2] ; odczyt zmiennej z pamięci do rejestru r3
    add r3, r3, #1 ; dodanie do rejestru r3 liczby 1
    str r3, [r2] ; zapis rejestru r3 z powrotem do pamięci
    #v-

    Zmienna może się zmienić między każdą z tych instrukcji.

    Bardziej realny przykład, AVR. Chcemy zmienić stan bitu 2 w porcie na
    przeciwny.

    #v+ avr.c
    #include <avr/io.h>
    void fn(void) { PORTB ^= _BV(2); }
    #v-

    Kompilacja: avr-gcc -mmcu=atmega8 -O2 -S avr.c

    #v+ avr.s
    in r24,0x18 ; załadowanie adresu portu do r24
    ldi r25,lo8(4) ; załadowanie wartości _BV(2) do r25
    eor r24,r25 ; wykonanie r24 xor r25, zapis do r24
    out 0x18,r24 ; wysłanie wartości z r24 do portu
    #v-

    Między każdą z tych instrukcji również może wystąpić przerwanie, które np.
    ustawi inny bit w tym porcie, który to bit zostanie ładnie wyczyszczony
    podczas otatniej operacji (zapisu r24 do portu).

    > No coz, przejsc na ARM i zapomniec o problemie ...

    Czemu? Co ma do tego ARM? Chodzi o szerokość magistrali danych? To
    rozwiązuje tylko jeden problem, ale inne (chociażby ten pierwszy
    przykład wyżej) pozostają.

    --
    Eksperymentalnie: http://facebook.com/groups/pl.misc.elektronika

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: