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

 
 
> Опять 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
Ответов
iosifk
сообщение Mar 14 2016, 11:38
Сообщение #2


Гуру
******

Группа: Модераторы
Сообщений: 4 011
Регистрация: 8-09-05
Из: спб
Пользователь №: 8 369



Цитата(Tsvetik @ Mar 14 2016, 14:08) *
Нужно передавать массивы двоичных данных по UART между двумя устройствами.

....

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

Стандартно либо передаете данные символьными кодами. А возврат каретки и перевод строки - это конец сообщения. Медленно, т.к. один байт передается двумя посылками, но просто... И годится любая терминалка на хосте...
Либо байт-стаффинг. Например WAKE от Ридико... Исходники и описания Леонид выложил...
Делать бит-стаффинг нет смысла, т.к. сдвигать массив данных на микроконтроллере долго...


--------------------
www.iosifk.narod.ru
Go to the top of the page
 
+Quote Post
jcxz
сообщение Mar 15 2016, 12:59
Сообщение #3


Гуру
******

Группа: Свой
Сообщений: 5 228
Регистрация: 3-07-08
Из: Омск
Пользователь №: 38 713



Цитата(iosifk @ Mar 14 2016, 17:38) *
Делать бит-стаффинг нет смысла, т.к. сдвигать массив данных на микроконтроллере долго...

Это смотря какой микроконтроллер.... sm.gif
Недавно делал опцию отображения содержимого LCD 320x240x4bpp на МК в окно приложения под виндой. Соответственно - периодическая передача содержимого видеоОЗУ (по обновлению оного) в комп по
USB.
Просто гнать массив - довольно накладно получалось - порядка ~40кБ. А картинка на LCD - это обычный юзер-интерфейс без пиксельной графики - результат вывода текста + линии/многоугольники и т.п.
Сделал сжатие картинки на лету на МК - стало гораздо бодрее wink.gif
Траффик упал в неск. раз и МК не помер. Ресурсов это заняло немного. А сжатие - сплошные манипуляции с битами и преобразование в битовый поток.
Хотя МК канеш не AVR - LPC4370 с тактовой до 204МГц wink.gif

Цитата(Baser @ Mar 14 2016, 18:04) *
Обычно для простейших протоколов применяют разделение пакетов по тайм-аутам.
Самый простой и удобный метод.

Годится только для "железного" UART, коих на ПК практически не осталось.
Как только пропускаем эти пакеты через UART-USB - все ваши разделения идут лесом.
А если автор захочет этот поток например через GPRS-канал пропустить с его непредсказуемыми задержками???......
Go to the top of the page
 
+Quote Post
zltigo
сообщение Mar 15 2016, 12:59
Сообщение #4


Гуру
******

Группа: Свой
Сообщений: 13 372
Регистрация: 27-11-04
Из: Riga, Latvia
Пользователь №: 1 244



QUOTE (jcxz @ Mar 15 2016, 14:54) *
Сделал сжатие картинки на лету на МК - стало гораздо бодрее wink.gif

Ну экраны с пользовательскими интерфейсами жать на лету с очень заметным эффектом можно очень простыми алгоритмами ввиду офигительной избыточности.


--------------------
Feci, quod potui, faciant meliora potentes
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
|- - 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
|- - 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
- - Baser   Цитата(zltigo @ Mar 14 2016, 15:11) Ни то...   Mar 14 2016, 13:58
|- - 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 Текстовая версия Сейчас: 23rd July 2025 - 04:54
Рейтинг@Mail.ru


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