реклама на сайте
подробности

 
 
> Опять UART, надоело городить самопальные протоколы
Tsvetik
сообщение Mar 14 2016, 11:08
Сообщение #1


Участник
*

Группа: Участник
Сообщений: 21
Регистрация: 25-10-06
Пользователь №: 21 663



Нужно передавать массивы двоичных данных по UART между двумя устройствами.

Так как полезная нагрузка не помещается в пределы 1 байта, необходимо поверх UART использовать некоторый логический протокол, который будет разделять фреймы и как-то управлять потоком.

Следовательно из 256 вариантов байта необходимо зарезервировать несколько значений для признаков начала (или конца) фрейма и, возможно, каких-то других управляющий символов.

Один из вариантов это /xon /xoff. Его минусы в том, что символы /xon /xoff могут встретиться в передаваемых двоичных данных и их надо экранировать. Плюс этого метода в том, что экранирование можно проводить "на лету" при приеме. Промежуточный буфер для этого не требуется.

Второй вариант использовать для кодирования двоичных данных некоторую кодировку. Например, BASE64 или семибитную кодировку, а старшие биты пристегивать отдельным байтом.
Тогда символы, не входящие в алфавит BASE64 или со взведенным старшим битом можно считать управляющими. На них можно повесить функции управления протоколом, начала-конца фрейма, повтора передачи, может-быть и адреса устройства и т.п. Обычно кодирование-декодирование требует промежуточного буфера и вносит дополнительные временные издержки.

Так вот, подскажите какие-нибудь популярные реализации логических протоколов поверх UART.
Необходимы легковесные протоколы, которые будут работать довольно быстро на Tiny AVR.

Да, желательно без 9-го бита UART, чтобы с PC было проще отлаживаться

Сообщение отредактировал Tsvetik - Mar 14 2016, 11:37
Go to the top of the page
 
+Quote Post
 
Start new topic
Ответов
Baser
сообщение Mar 14 2016, 13:58
Сообщение #2


Просто Che
*****

Группа: Свой
Сообщений: 1 567
Регистрация: 22-05-07
Из: ExUSSR
Пользователь №: 27 881



Цитата(zltigo @ Mar 14 2016, 15:11) *
Ни то, ни другое - НИКОГДА не ссылаться на "промышленных автоматизаторов" в качестве хоть какого-то авторитета.

Тут я позволю себе обратить вминание на то, что это была моя личная точка зрения основанная на личном практическом опыте:
Цитата
Но 99% протоколов промышленного применения, что я видел, ...

Я не претендую на истинность и не считаю себя большим авторитетом. Ну, да и ладно rolleyes.gif

Цитата(zltigo @ Mar 14 2016, 15:11) *
Глупостей и ошибок всегда можно наделать до бесконечности и еще чуть чуть. Но разумных и продуманно-сбалансированных вариантов ничтожно мало sad.gif

Вот с этим я совершенно согласен.

Цитата(Corvus @ Mar 14 2016, 15:33) *
Ну так назовите этот самый "разумный". Или это недостижимая мечта вроде коммунизма? rolleyes.gif

Не возьмусь рекомендовать что-то конкретное,
т.к. считаю, что задача и область применения устройства, для которого выбирается протокол, определяет его структуру.
Невозможно придумать один универсальный протокол подходящий на все случаи жизни.

Случай из жизни.
Лет 7 назад мы с коллегой решили разработать новый универсальный протокол для применения в приборах нашей фирмы
(для конкретной области применения, а не вообще),
написали свои пожелания, я все продумал, написал проект, обсудили, утвердили.
Я его даже реализовал в ОДНОМ макете, который не пошел дальше макета. И все, лежит, уже интегрированый в наши тестовые программы.
Всем замечательный протокол, очень гибкий. Но немного сложноват в реализации.
Так что мы так и применяем то, что уже применяли на фирме лет 20 - минималистический протокол с коротким фиксированным пакетом.
А где нужно больше данных гонять, начали применять по просьбе заказчиков MODBUS, хотя мне и сильно не нравиться его регистровая направленность.

Так что не скажу я вам, что ОБЯЗАТЕЛЬНО нужно изучать. Я просто по работе сталкивался то с одним, то с другим протоколом, так и нахватался отрывистых знаний.
Теоретического курса по протоколостроению никогда не слушал. laughing.gif

Go to the top of the page
 
+Quote Post

Сообщений в этой теме
- Tsvetik   Опять UART   Mar 14 2016, 11:08
- - Александр1   Цитата(Tsvetik @ Mar 14 2016, 15:08) ... ...   Mar 14 2016, 11:22
|- - Tsvetik   Цитата(Александр1 @ Mar 14 2016, 14:22) Н...   Mar 14 2016, 11:32
- - iosifk   Цитата(Tsvetik @ Mar 14 2016, 14:08) Нужн...   Mar 14 2016, 11:38
|- - Tsvetik   За WAKE спасибо.   Mar 14 2016, 11:58
||- - iosifk   Цитата(Tsvetik @ Mar 14 2016, 14:58) А эт...   Mar 14 2016, 12:03
|- - zltigo   QUOTE (iosifk @ Mar 14 2016, 13:38) Медле...   Mar 14 2016, 12:46
||- - Tsvetik   Цитата(zltigo @ Mar 14 2016, 15:46) Могу ...   Mar 14 2016, 12:52
|- - jcxz   Цитата(iosifk @ Mar 14 2016, 17:38) Делат...   Mar 15 2016, 12:59
|- - zltigo   QUOTE (jcxz @ Mar 15 2016, 14:54) Сделал ...   Mar 15 2016, 12:59
|- - iosifk   Цитата(jcxz @ Mar 15 2016, 15:59) Это смо...   Mar 15 2016, 13:02
- - Baser   Цитата(Tsvetik @ Mar 14 2016, 13:08) Один...   Mar 14 2016, 12:04
|- - Tsvetik   Цитата(Baser @ Mar 14 2016, 15:04) Что вы...   Mar 14 2016, 12:20
|- - Baser   Цитата(Tsvetik @ Mar 14 2016, 14:20) Байт...   Mar 14 2016, 12:27
||- - zltigo   QUOTE (Baser @ Mar 14 2016, 14:27) Но 99%...   Mar 14 2016, 12:38
|||- - Baser   Цитата(zltigo @ Mar 14 2016, 14:38) Людое...   Mar 14 2016, 12:49
|||- - zltigo   QUOTE (Baser @ Mar 14 2016, 14:49) Я вот ...   Mar 14 2016, 13:11
|||- - Corvus   Цитата(zltigo @ Mar 14 2016, 16:11) Глупо...   Mar 14 2016, 13:33
||||- - Ruslan1   разделение на фреймы: SLIP (RFC1055) https://tools...   Mar 14 2016, 13:56
|||- - Огурцов   Цитата(zltigo @ Mar 14 2016, 14:11) Адрес...   Mar 15 2016, 16:23
|||- - zltigo   QUOTE (Огурцов @ Mar 15 2016, 18:23) заче...   Mar 15 2016, 16:31
||- - Tsvetik   Цитата(Baser @ Mar 14 2016, 15:27) Ну так...   Mar 14 2016, 12:39
||- - jcxz   Цитата(Tsvetik @ Mar 14 2016, 18:39) Длин...   Mar 15 2016, 13:05
||- - Tsvetik   Цитата(jcxz @ Mar 15 2016, 16:05) Не смеш...   Mar 15 2016, 17:34
||- - jcxz   Цитата(Tsvetik @ Mar 15 2016, 23:34) С од...   Mar 16 2016, 06:01
||- - Ruslan1   У меня в одном устройстве используется по приему к...   Mar 16 2016, 07:43
|- - iosifk   Цитата(Tsvetik @ Mar 14 2016, 15:20) Байт...   Mar 14 2016, 13:30
- - Kaligooola   В 8b/10b кодировании есть признаки старта / стопа ...   Mar 14 2016, 12:16
|- - zltigo   QUOTE (Baser @ Mar 14 2016, 15:58) Тут я ...   Mar 14 2016, 14:17
- - mempfis_   Цитата(Tsvetik @ Mar 14 2016, 15:08) Так ...   Mar 15 2016, 14:05
- - sigmaN   ЦитатаС одной стороны, когда DMA не знает ничего о...   Mar 15 2016, 20:05
- - =AK=   Цитата(Tsvetik @ Mar 14 2016, 21:38) След...   Mar 17 2016, 05:26
- - Tsvetik   Цитата(=AK= @ Mar 17 2016, 08:26) Если ма...   Mar 17 2016, 06:35
- - AlexandrY   Цитата(Tsvetik @ Mar 17 2016, 08:35) COBS...   Mar 17 2016, 07:30
- - Tsvetik   Цитата(AlexandrY @ Mar 17 2016, 10:30) Од...   Mar 17 2016, 07:31
- - zltigo   QUOTE (AlexandrY @ Mar 17 2016, 09:30) Од...   Mar 17 2016, 07:47


Reply to this topicStart new topic
1 чел. читают эту тему (гостей: 1, скрытых пользователей: 0)
Пользователей: 0

 


RSS Текстовая версия Сейчас: 29th July 2025 - 08:42
Рейтинг@Mail.ru


Страница сгенерированна за 0.01434 секунд с 7
ELECTRONIX ©2004-2016