Телесистемы
 Разработка, производство и продажа радиоэлектронной аппаратуры
На главную   | Карта сайта | Пишите нам | В избранное
Требуется программист в Зеленограде
- обработка данных с датчиков; ColdFire; 40 тыс.
e-mail:jobsmp@pochta.ru

Телесистемы | Электроника | Конференция «Микроконтроллеры и их применение»

Не надо изобретать велосипед....

Отправлено Mk - 51 19 июня 2007 г. 08:00
В ответ на: В принципе, хороший вариант:) Правда, если делать паузы между n байтами, то в худшем случае можно потерять n байт до первой паузы. Получается компромисс между скоростью передачи(< при меньшем n) и задержкой получения правильных, надежных данных (> при большем n), хотя это не проблема. Принимаются предложения и других вариантов:) отправлено <font color=gray>mayn</font> 19 июня 2007 г. 02:59

Если хочешь передавать все ненпрерывно с одним и тем же интервалом, то это делается так:

Начало посылки - например байт 0xAA, конец - например байт 0xBB, число байт в одном пакете например 32 плюс контрольная сумма пакета, тогда 32+2+1=35. Принимаем по 1 байту. Начиная от первого встретившегося 0xAA. Если 35 - 0xBB - то обрабатываем этот пакет и если контрольная сумма совпадант, то это данные, если нет ждем следующий 0xAA. В конце концов наступает синхронизация. И далее всегда за 35-м 0xBB будет приходить 0-й 0xAA. Это все, остальные варианты связаны либо с работой по запросам, либо с временными интервалами.

P.S. Выход на синхронизацию можно сделать гораздо надежнее и быстрее. Выше я описал просто схему, принцип.

Составить ответ | Вернуться на конференцию

Ответы


Отправка ответа
Имя*: 
Пароль: 
E-mail: 
Тема*:

Сообщение:

Ссылка на URL: 
URL изображения: 

если вы незарегистрированный на форуме пользователь, то
для успешного добавления сообщения заполните поле, как указано ниже:
введите число 89:

Перейти к списку ответов | Конференция | Раздел "Электроника" | Главная страница | Карта сайта

Rambler's Top100 Рейтинг@Mail.ru
 
Web telesys.ru