-
Path: news-archive.icm.edu.pl!agh.edu.pl!news.agh.edu.pl!news.cyf-kr.edu.pl!news.nask
.pl!news.nask.org.pl!news.unit0.net!news.glorb.com!peer01.iad.highwinds-media.c
om!news.highwinds-media.com!feed-me.highwinds-media.com!nx02.iad01.newshosting.
com!newshosting.com!newsfeed.neostrada.pl!unt-exc-01.news.neostrada.pl!unt-spo-
b-01.news.neostrada.pl!news.neostrada.pl.POSTED!not-for-mail
From: "michal" <...@b...pl>
Newsgroups: pl.misc.elektronika
References: <5341b961$0$2228$65785112@news.neostrada.pl>
Subject: Re: Modbus, mierzenie odstępu między znakami i paczkami
Date: Mon, 7 Apr 2014 18:16:05 +0200
X-Priority: 3
X-MSMail-Priority: Normal
X-Newsreader: Microsoft Outlook Express 6.00.2900.5512
X-MimeOLE: Produced By Microsoft MimeOLE V6.00.2900.5512
X-RFC2646: Format=Flowed; Response
Lines: 39
Message-ID: <5342cf47$0$2163$65785112@news.neostrada.pl>
Organization: Telekomunikacja Polska
NNTP-Posting-Host: 83.10.91.55
X-Trace: 1396887367 unt-rea-a-02.news.neostrada.pl 2163 83.10.91.55:20465
X-Complaints-To: a...@n...neostrada.pl
X-Received-Bytes: 2378
X-Received-Body-CRC: 3009057393
Xref: news-archive.icm.edu.pl pl.misc.elektronika:662624
[ ukryj nagłówki ]
Użytkownik "Robbo" <n...@g...com> napisał w wiadomości
news:5341b961$0$2228$65785112@news.neostrada.pl...
> Witam uprzejmie,
>
> Tworzę bibliotekę Modbus/RTU w języku C, łącze szeregowe, slave, która
> będzie działać na mikrokontrolerze ATmega. Korzystam ze sprzętowego
> USART-a w ATmega. Zgodnie ze standardem Modbus dla łącza szeregowego,
> odstęp między znakami w pojedynczej paczce nie może być większy niż 1,5 *
> czas_przesyłania_pojedynczego_znaku. Natomiast odstęp między paczkami
> powinien być większy niż 3,5 * czas_przesyłania_pojedynczego_znaku. Jest
> to pokazane na stronie nr 13 tego dokumentu:
> http://modbus.org/docs/Modbus_over_serial_line_V1_02
.pdf
> Przygotowałem ilustrację graficzną:
> http://s11.postimg.org/43qi83etf/Modbus.png
>
> Pozdrawiam,
> Robbo
czesc.
w mojej opinii (niekoniecznie prawidlowej) najprosciej zrobić to za
pomocą timera uruchamianego właśnie w obsłudze SIG_UART_RECEIVE
uruchamiasz timer i kolejne przerwanie SIG_UART_RECEIVE kasuje timer
a jak nie zdąży to w przerwaniu timera musisz ocenić czy błąd transmisji czy
koniec ramki przy czym ja zrobiłbym tylko warunek na koniec ramki (by nie
mieć
kłopotów z tym że komuś uart/(program właściwie) w drugim urządzeniu nie
wyrabia - gdy transmisja błędna to i tak wyjdzie za pomocą crc - format
ramki jest dość sztywny) tym ze przeranie jest na końcu a nie na początku
znaku
przejmowałbym się najmniej, uart jak zacznie odbierać to musi odebrać do
konca.
pozdrawiam.
michal
Następne wpisy z tego wątku
- 09.04.14 09:50 John Smith
Najnowsze wątki z tej grupy
- termostat do lodowki
- SEP 1 kV E
- Aku LiPo źródło dostaw - ktoś poleci ?
- starość nie radość
- Ataki hakerskie
- Akumulatorki Ni-MH AA i AAA Green Cell
- Dławik CM
- JDG i utylizacja sprzetu
- Identyfikacja układ SO8 w sterowniku migających światełek choinkowych
- DS1813-10 się psuje
- Taki tam szkolny problem...
- LIR2032 a ML2032
- SmartWatch Multimetr bezprzewodowy
- olej psuje?
- Internet w lesie - Starlink
Najnowsze wątki
- 2024-12-14 światła znów wlączyli
- 2024-12-14 nie lekceważ termostatu
- 2024-12-14 numer 112
- 2024-12-14 Pendrive, ale dysk
- 2024-12-12 Autocom CAN CDP+ wysokie kody błędów
- 2024-12-13 termostat do lodowki
- 2024-12-13 Gdańsk => Inżynier bezpieczeństwa aplikacji <=
- 2024-12-13 Warszawa => Head of International Freight Forwarding Department <=
- 2024-12-13 Poznań => Employer Branding Specialist <=
- 2024-12-13 Kraków => Business Development Manager - Dział Sieci i Bezpieczeńst
- 2024-12-13 Kraków => Business Development Manager - Network and Network Security
- 2024-12-13 Katowice => Regionalny Kierownik Sprzedaży (OZE) <=
- 2024-12-13 Gdańsk => Programista Full Stack .Net <=
- 2024-12-13 Warszawa => Analityk Biznesowo-Systemowy <=
- 2024-12-13 Białystok => Architekt rozwiązań (doświadczenie w obszarze Java, A