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

 
 
 
Reply to this topicStart new topic
> Быстрый ответ на пакет данных по UART, оптимизация скорости пакетной передачи UART
lolikandr
сообщение Mar 27 2015, 13:55
Сообщение #1


Участник
*

Группа: Свой
Сообщений: 56
Регистрация: 25-06-05
Пользователь №: 6 300



Сначала опишу ситуацию:
Микроконтроллер (МК) подключен по UART к AT91SAM9XE512 (Linux 3.0.4).
У микроконтроллера ограничено ОЗУ, поэтому реализован обмен пакетами динамического размера - от 3 до 48 байт.
При скорости 500000 бод время передачи пакета не более 1мс.
В Linux написали приложение в юзерспейсе (кушает 2...5%CPU).
И теперь ответный пакет (3-5байт) из Linux приходит не сразу, а с задержкой до 10 мс (подозрение на переключение контекста).
Работать без ответов нельзя - МК должен убедиться, что доставил пакет в Linux приложение.
При этом МК тратит на обработку пакета до 80 мкс.
В итоге средняя скорость данных - около 4700 байт/сек.
Что хочется сделать:
Главное - максимально быстро дать знать МК, что пакет принят.
Теоретически, если бы в большинстве случаев (иногда задержки до 10 мс допустимы) Linux по UART-у отвечал так же быстро, как и МК, то:
- в течении 10 мс может прийти до 10 пакетов и нужно сделать 10 ответов.
- скорость может быть почти 41000 байт/сек, то есть почти в 9 раз больше!
- обработку собранных пакетов можно сделать и позже (приемлемо до 100 мс).
Теперь собственно вопрос:
Как в Linux сделать быстрый ответ по UART? В данном случае уже всё равно - userspace or kernelspace.
Изучая этот вопрос, склоняюсь к написанию специальной line discipline, однако не могу найти вразумительное описание как это делается.
Go to the top of the page
 
+Quote Post
Lerk
сообщение Mar 27 2015, 14:35
Сообщение #2


Местный
***

Группа: Свой
Сообщений: 339
Регистрация: 5-05-11
Пользователь №: 64 797



Вопрос сходу. Почему не сделать обмен, например, по 10 пакетов за раз? Linux отвечает один раз с указанием того, какие пакеты принял. Учитывая скорость передачи и скорость обработки пакета на МК, сэкономите кучу времени. Как проводить идентификацию пакетов в группе и обрабатывать нештатные ситуации - на свое усмотрение.
Go to the top of the page
 
+Quote Post
BaN
сообщение Mar 27 2015, 14:44
Сообщение #3


Частый гость
**

Группа: Участник
Сообщений: 144
Регистрация: 28-08-07
Пользователь №: 30 111



Пункт 4.4:
https://www.osadl.org/fileadmin/dam/rtlws/12/Brown.pdf

Сообщение отредактировал BaN - Mar 27 2015, 14:46
Go to the top of the page
 
+Quote Post
lolikandr
сообщение Mar 27 2015, 15:31
Сообщение #4


Участник
*

Группа: Свой
Сообщений: 56
Регистрация: 25-06-05
Пользователь №: 6 300



Цитата(Lerk @ Mar 27 2015, 17:35) *
Вопрос сходу. Почему не сделать обмен, например, по 10 пакетов за раз? Linux отвечает один раз с указанием того, какие пакеты принял. Учитывая скорость передачи и скорость обработки пакета на МК, сэкономите кучу времени. Как проводить идентификацию пакетов в группе и обрабатывать нештатные ситуации - на свое усмотрение.

Вы прямо читаете наш код )) В МК уже сделали передачу по 32 пакета.
Осталось сделать группировку пакетов с подтверждением на Linux, однако есть непонимание, по какому принципу начинать отправку пакетов потдверждения, поскольку поток не регулярный.
То есть можем собрать 8 ответов и недопустимо долго ждать следующего пакета. Придётся какой-то таймер завести.
Да и в Linux пока такое безобразие не добавлено.
Думалось, может можно как-то на корню решить проблему быстродействия (пусть даже kernelspace) и выкинуть код не заморачиваться передачей много пакетов за раз.
to BaN
Спасибо за статистику, весьма совпадает с реальностью нашего Linux и userspace. Посмотрим, что за зверь этот xenomai.
Go to the top of the page
 
+Quote Post
Lerk
сообщение Mar 27 2015, 17:27
Сообщение #5


Местный
***

Группа: Свой
Сообщений: 339
Регистрация: 5-05-11
Пользователь №: 64 797



Цитата(lolikandr @ Mar 27 2015, 18:31) *
Осталось сделать группировку пакетов с подтверждением на Linux, однако есть непонимание, по какому принципу начинать отправку пакетов потдверждения, поскольку поток не регулярный.

Ну, вам виднее - без знания того, откуда берутся данные для посылки сложно что-то предполагать. Но даже так можно представить структуру: буфер, данные которого по расписанию(по таймеру), отправляются на linux. А содержимое буфера обновляется по готовности. (Соотв-но, если не обновилось, отсылаем что было - linux уже сам разберется что к чему по ID пакета) Так будет постоянный поток данных, что теоретически может сильно нагрузить и мк и linux, но с другой стороны наличие расписания может сыграть хорошую службу в плане ответных пакетов.
Go to the top of the page
 
+Quote Post

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

 


RSS Текстовая версия Сейчас: 16th June 2025 - 17:00
Рейтинг@Mail.ru


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