Как стать автором
Обновить

19 Атрибутов Хорошего Канального Протокола Передачи Данных

Уровень сложностиПростой
Время на прочтение4 мин
Количество просмотров7K

В этом тексте я напишу атрибуты хорошего и простого Master<->Slave протокола канального уровня для пакетного обмена информацией между устройствами на общих шинах таких как RS485, CAN, LoRa, BLE, Lin или соединений типа точка-точка UART, RS232.

Несмотря на то, что есть стандартизированные канальные протоколы ModBus, DLMS, RDS, UBX, NEC, Pelco-D, yModem, многие российские компании всё же колхозят свои собственные внутренние протоколы для взаимодействия между электронными платами.

Тут представлены общие атрибуты и пожелания для таких доморощенных протоколов.

*1--M2M протокол должен быть бинарным

Это сделает трафик компактнее и проще в обработке на стороне firmware. 

*2--У пакета должна быть преамбула (синхробайты)

Преамбула нужна, чтобы программный конечный автомат приема мог выхватывать пакеты из потока байтов.

*3--Преамбула должна быть параметризируемая

Преамбулу следует параметризировать так как должна быть предусмотрена возможность туннелирования пакетов одного и того же протокола. То есть матрешка пакетов из одного и того же протокола. Это особенно полезно когда физика трансивера за раз может отправить только N байт, а сам пакет, например, M=2N байт. При этом получается N<M. В этом случае маленькими пакетами передается большой пакет как поток байтов.

*4--Должен быть порядковый номер пакета (Sequence Number)

Это позволит на стороне приемника определить потерю непрерывности потока. Порядковый номер пакета это также требование стандарта ISO-26262

*5--Должно быть поле, которое отвечает за длину полезных данных

Это позволит сделать протокол универсальным и сделает возможность передавать данные разной длинны.

6--Передавать многобайтовые поля в заголовках следует в Big Endian (optional)

Так проще анализировать сырые пакеты глазами в HEX редакторе или на осциллографе. Даже если микроконтроллер Little Endian, то производительность современных микроконтроллеров достаточно высока, чтобы инвертировать байты для всех типов на лету.

*7--В пакете должна быть контрольная сумма CRC

Это позволит проверить, что пакет не повредился в процессе передачи из-за радиопомех или дребезга контактов. 

*8--Контрольная сумма должна быть в конце пакета

Это позволит проще вычислять СRС, захватывая как данные так и заголовок.

9--Должен быть идентификатор типа полезных данных(optional)

Это позволит приемнику быстрее понять как интерпретировать полезные данные внутри пакета.

*10--Должно быть подтверждение принятого пакета (Ack)

Так Master Node(а) поймет, что Slave Node(а) точно съела пакет

*11--Должна быть повторная отправка в случае отсутствия подтверждения (ReTx)

Это повысит надежность передачи данных.

12--В заголовке должна быть TimeStamp отправки пакета миллисекундной точности (optional)

Временная отметка внутри пакета нужна для отладки хронологии диалога и оценки быстродействия обработки. Есть аппаратные способы прослушивать трафик в той же RS485. По логу надо уметь анализировать тайминги. Сортировать хронологию, оценивать паузы.

*13--Спецификацию протокола следует делать в формате общих электронных таблиц

Делать спеки протоколов в *.doc или *.pdf это уже архаично. Электронные таблицы идеально подходят для представления структуры пакетов. Электронные таблицы как будто бы и созданы для представления пакетов. Любой пакет это по факту обыкновенный массив. В электронных таблицах можно сортировать пакеты, быстро искать нужный пакет, раскрашивать поля, проверять полноту, находить свободные идентификаторы, и даже авто генерировать парсеры в виде С-кода для синтаксического разбора пакетов.

*14--Должно быть шифрование PayLoad(а)

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

*15--Пакетная синхронизация должна производится по преамбуле

Раз приняли преамбулу и CRC валидная значит пришел новый пакет. Так прошивка сможет выделять пакеты из потока байт в UART.

*16--Пакетная синхронизация должна производится также по TimeOut(у)

Также можно делать пакетную синхронизацию по TimeOut(у). То есть после продолжительного молчания на шине приемник просто сбрасывает конечный автомат приема в первоначальное состояние и ожидает новой преамбулы от нового пакета.

*17--Должен быть периодический Hello пакет для каждой node(ы) (keep alive messages)

Мастер должен периодически опрашивать каждую Node(у) даже если нет PayLoad для этой Node(ы). (Требование ISO-26262). Это позволит убедиться, что есть link. То есть что провода не оторвались, софт не завис. В случае пропадания link(а) сгенерировать событие аварии и предложить предпринять меры по ремонту сети. В UWB это, например, называется Blink пакеты.

18--В пакете должен быть адрес отправителя и адрес получателя

Это как на почте на конвертах. Правило здравого смысла. Если в пакете есть адреса, то можно делать топологию общая шина, отвечать может только тот кому этот пакет принадлежит.

19--Сторожевой таймер на потерю соединения

Каждый раз когда приходит пакет надо обнулять программный сторожевой таймер, который работает для этого конкретного соединения. Этот таймер считает вверх. Если сторожевой таймер досчитал до определенного таймаута, то надо выдать в консоль предупреждение, что возможно что-то не так с link(ом).

Вывод
Это основные требования к выбору кибернетики очередного бинарного протокола передачи данных. Протокола для M2M взаимодействий. Вообще не надо изобретать очередной проприетарный протокол. Воспользуйтесь спецификацией любого уже существующего канального протокола. Вероятно вам подойдет ModBus, Can, DLMS, RDS, UBX, xModem, EtherCAT. Стандартизированный протокол добавит вашему устройству совместимость с другим оборудованием и софтом. Можно будет взять программную реализацию с GitHub и просто покрыть ее своими модульными тестами.

Если вам известны еще особенные атрибуты хорошего канального протокола передачи данных, то пишите их в комментарии.

Также пишите про те стандартизированные канальные протоколы с которыми вам приходилось сталкиваться и делитель впечатлениями от работы с разными протоколами канального уровня.

Только зарегистрированные пользователи могут участвовать в опросе. Войдите, пожалуйста.
У вас в компании есть собственный протокол передачи данных?
54.81% да57
45.19% нет47
Проголосовали 104 пользователя. Воздержались 14 пользователей.
Только зарегистрированные пользователи могут участвовать в опросе. Войдите, пожалуйста.
Вы добавляете в заголовок пакета порядковый номер пакета?
44.19% да38
55.81% нет48
Проголосовали 86 пользователей. Воздержались 23 пользователя.
Только зарегистрированные пользователи могут участвовать в опросе. Войдите, пожалуйста.
Какой порядок байт вы используете в многобайтовых полях бинарного протокола?
50.7% Big Endian36
49.3% Little Endian35
Проголосовал 71 пользователь. Воздержались 36 пользователей.
Только зарегистрированные пользователи могут участвовать в опросе. Войдите, пожалуйста.
Вы добавляете в заголовок пакета TimeStamp?
23.46% да19
76.54% нет62
Проголосовал 81 пользователь. Воздержались 25 пользователей.
Только зарегистрированные пользователи могут участвовать в опросе. Войдите, пожалуйста.
Вы используете электронные таблицы для составления спецификаций бинарных протоколов?
31.65% да25
68.35% нет54
Проголосовали 79 пользователей. Воздержались 22 пользователя.
Только зарегистрированные пользователи могут участвовать в опросе. Войдите, пожалуйста.
Вы используете CRC для защиты данных бинарного протокола?
81.01% да64
18.99% нет15
Проголосовали 79 пользователей. Воздержался 21 пользователь.
Только зарегистрированные пользователи могут участвовать в опросе. Войдите, пожалуйста.
Вы добавляете шифрование в бинарные протоколы?
27.63% да21
72.37% нет55
Проголосовали 76 пользователей. Воздержались 23 пользователя.
Только зарегистрированные пользователи могут участвовать в опросе. Войдите, пожалуйста.
Вам приходилось делать туннелирование протокола?
38.96% да30
61.04% нет47
Проголосовали 77 пользователей. Воздержались 19 пользователей.
Теги:
Хабы:
Всего голосов 11: ↑6 и ↓5+4
Комментарии28

Публикации

Истории

Работа

Программист С
36 вакансий

Ближайшие события

27 августа – 7 октября
Премия digital-кейсов «Проксима»
МоскваОнлайн
11 сентября
Митап по BigData от Честного ЗНАКа
Санкт-ПетербургОнлайн
19 сентября
CDI Conf 2024
Москва
24 сентября
Конференция Fin.Bot 2024
МоскваОнлайн
25 сентября
Конференция Yandex Scale 2024
МоскваОнлайн
28 – 29 сентября
Конференция E-CODE
МоскваОнлайн
28 сентября – 5 октября
О! Хакатон
Онлайн
30 сентября – 1 октября
Конференция фронтенд-разработчиков FrontendConf 2024
МоскваОнлайн