eGospodarka.pl
eGospodarka.pl poleca

eGospodarka.plGrupypl.misc.elektronikaZagwozdka w C Keil. › Zagwozdka w C Keil - wyjaśnienie.
  • Path: news-archive.icm.edu.pl!news.icm.edu.pl!newsfeed2.atman.pl!newsfeed.atman.pl!.P
    OSTED!not-for-mail
    From: "Irek.N." <t...@j...taki.jest.pl>
    Newsgroups: pl.misc.elektronika
    Subject: Zagwozdka w C Keil - wyjaśnienie.
    Date: Tue, 12 Feb 2019 22:39:24 +0100
    Organization: ATMAN - ATM S.A.
    Lines: 53
    Message-ID: <q3vee4$o74$1@node1.news.atman.pl>
    References: <q3q59d$hp9$1@node1.news.atman.pl>
    NNTP-Posting-Host: 77-253-172-130.adsl.inetia.pl
    Mime-Version: 1.0
    Content-Type: text/plain; charset=ISO-8859-2; format=flowed
    Content-Transfer-Encoding: quoted-printable
    X-Trace: node1.news.atman.pl 1550007556 24804 77.253.172.130 (12 Feb 2019 21:39:16
    GMT)
    X-Complaints-To: u...@a...pl
    NNTP-Posting-Date: Tue, 12 Feb 2019 21:39:16 +0000 (UTC)
    User-Agent: Thunderbird 2.0.0.24 (Windows/20100228)
    In-Reply-To: <q3q59d$hp9$1@node1.news.atman.pl>
    Xref: news-archive.icm.edu.pl pl.misc.elektronika:740960
    [ ukryj nagłówki ]

    No więc znalazłem chwilę aby podjechać do klienta i popatrzeć dokładnie
    w kod.
    Na wstępie małe usprawiedliwienie - procedura była napisana na 8051 i
    uruchomiona na jednym z pierwszych PLC jakie zrobiłem, w latach 90, ale
    stosowana też później*. W tamtych czasach wydawało mi się, że ogarniam
    podstawy C :)

    W maszynie którą diagnozowałem definicja zmiennej DEL_STEP była o zgrozo
    jako unsigned char. Nie zwróciłem na to uwagi, choć zauważyłem, że
    sprawdzany jest tylko młodszy - przekazany - bajt zmiennej z którą
    wywołano funkcję. Wygląda więc na to, że kompilator miał rację.

    Po zmianie definicji na unsigned int kompilator robi OLR na obu
    połówkach zmiennej DEL_STEP a następnie sprawdza czy wynik operacji jest
    zerowy. Bardzo ładne rozwiązanie moim zdaniem.

    Zrobiłem jeszcze jedną rzecz. Ponieważ jak zauważyliście, nie ma
    gwarancji, że sprawdzenie 16 bitów będzie poprawne w przypadku gdy
    przerwanie może je zmienić, podłączyłem oscyloskop, persystencję na
    nieskończoną i obserwowałem czas generowany przez procedurę. Zdarzały
    się błędnie odliczone interwały, ale nie za często. Zrobiłem jak Mateusz
    podpowiedział - flaga w przerwaniu modyfikującym zmienną. Nie złapałem
    żadnego błędnego odliczenia.

    Tak więc przepraszam, ale wychodzi na to, że sensacji nie ma, kompilator
    jednak dawał radę, a ja znowu się czegoś nauczyłem :)

    Dzięki wszystkim za pomoc.


    Miłego.
    Irek.N.
    * w późniejszych wersjach kodu (trochę inna wersja PLC) już była
    poprawna definicja jako typ 16 bitowy, czyli kiedyś to zauważyłem,
    poprawiłem i zapomniałem :(

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: