eGospodarka.pl
eGospodarka.pl poleca

eGospodarka.plGrupypl.misc.elektronikaC++ ośla łączkaRe: C++ ośla łączka
  • Path: news-archive.icm.edu.pl!news.icm.edu.pl!newsfeed.pionier.net.pl!2.eu.feeder.erj
    e.net!feeder.erje.net!feeds.phibee-telecom.net!weretis.net!feeder8.news.weretis
    .net!eternal-september.org!reader01.eternal-september.org!.POSTED!not-for-mail
    From: heby <h...@p...onet.pl>
    Newsgroups: pl.misc.elektronika
    Subject: Re: C++ ośla łączka
    Date: Wed, 15 Feb 2023 23:10:46 +0100
    Organization: A noiseless patient Spider
    Lines: 31
    Message-ID: <tsjl9d$30gq5$1@dont-email.me>
    References: <16qbnwht7z74n.8802zax2iioq$.dlg@40tude.net>
    <63dad430$0$9589$65785112@news.neostrada.pl>
    <trelrs$g0p$1$Janusz@news.chmurka.net>
    <trgbkf$st9$1$PiotrGalka@news.chmurka.net>
    <63dbd22e$0$9601$65785112@news.neostrada.pl>
    <ts6rps$roo$1$PiotrGalka@news.chmurka.net>
    <63e9f424$0$19625$65785112@news.neostrada.pl>
    <tsg6eb$96a$1$PiotrGalka@news.chmurka.net> <tsgv8m$2kn8s$1@dont-email.me>
    <tsiqth$55n$1$PiotrGalka@news.chmurka.net> <tsj9if$2v62r$1@dont-email.me>
    <a...@n...neostrada.pl>
    MIME-Version: 1.0
    Content-Type: text/plain; charset=UTF-8; format=flowed
    Content-Transfer-Encoding: 8bit
    Injection-Date: Wed, 15 Feb 2023 22:10:53 -0000 (UTC)
    Injection-Info: reader01.eternal-september.org;
    posting-host="25c5ba5bef0debf53e9a5c9a9067ab32";
    logging-data="3162949";
    mail-complaints-to="a...@e...org";
    posting-account="U2FsdGVkX1/pAfqngaMC/oFZU4IeO3iB"
    User-Agent: Mozilla/5.0 (Windows NT 10.0; Win64; x64; rv:102.0) Gecko/20100101
    Thunderbird/102.7.2
    Cancel-Lock: sha1:luVau4ydQms551gxse4Q3txjcMY=
    In-Reply-To: <a...@n...neostrada.pl>
    Content-Language: en-US
    Xref: news-archive.icm.edu.pl pl.misc.elektronika:778352
    [ ukryj nagłówki ]

    On 15/02/2023 22:14, Marek wrote:
    >> nie oznaczą go volatile. A to generuje sideeffect, na przykąłd jak
    >> czytamy bufor typu UART.
    > Czyli konkretnie  jaki side effect z tym UARTem?

    Na przykład, w wielu uartach odczytanie bajtu z bufora wejściowego
    możliwe jest dokładnie *raz* na każdy odebrany bajt, hardware traktuje
    taki odczyt jako procedurę odebrania wiadomości i nastepny odczyt może
    odczytać coś z dalszej pozycji bufora. W ogólnym wypadku, operacja na
    rejestrze *może* spowodować zmianę stanu hardware. Rejestr to nie jest
    pamięć.

    Taka ciekawostka: MC68000 i MC68020 rózniły się tym, że pierwszy w
    niektórych instrukcjach asm zapisywał *dwukrotnie* to samo do pamieci, a
    drugi racz zapisywał a drugi raz odczytywał i w obu wypadkach jedna z
    tych operacji była bez sensu algorytmicznego. To cecha magiczna
    magistrali 6[8|5]00/68000, każdy cykl jest dostępem do pamięci i
    procesor *coś* musi zrobić w każdym cyklu, nawet jak nie miało to sensu,
    bo nie miał co wymienić z pamięcią.

    Był to spory problem, kiedy okazało się, że jeśli ktoś akurat zapisuje
    do rejestru hardwareowego, który ma sideefect np. uruchamiania DMA,
    program działał inaczej w zależności od CPU, mimo że efekt końcowy był
    identyczny z punktu widzenia ASM.

    Ten problem z MC680x0 to sprzętowy odpowiednik "problemów" z C, gdzie
    też pewne operacje mogą pojawić się i zniknąc w wyniku optymalizacji, co
    nie przeszkadza w modelu pamięciowym, ale może powodować katastrofy w
    modelu rejestrów sprzętowych. Dlatego jest słowo volatile. I swoją drogą
    tylko dlatego ;)

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: