Подключаем наши девайсы к компьютеру. Обсуждаются: порты, протоколы, драйвера, языки программирования и т.д.
Ответить

Потери при передаче через UART.

Пн июн 05, 2017 22:34:38

Нужно от МК передавать большие объемы данных в ПК. Скорость - 1 байт с интервалами от 10 до 20 мкс. Направление только от устройства в ПК. Для связи настраиваю UART микроконтроллера на передачу со скоростью 3 Мбит. Далее переходник UART-USB (FT232) для ввода в компьютер, а там софт работает через виртуальный COM порт. Уже при интервале 25 мкс теряется примерно 0.1% данных. При интервале 30 мкс все стабильно. То есть компьютер не успевает обрабатывать всего 40 кБ/с! Пробовал увеличивать размер приемного буфера - не помогло.
Какие будут идеи?

Re: Потери при передаче через UART.

Вт июн 06, 2017 08:21:00

Какие будут идеи?
3 Мбит это нестандартная скорость UART. Уверены что ее поддерживает FT232 с величиной ошибки 0%?
В коде МК ошибок нет? Перед загрузкой нового байта в UART проверяете что предыдущий был передан?
Проверьте логическим анализатором что на линии MK - FT232.

Re: Потери при передаче через UART.

Вт июн 06, 2017 10:31:21

Какая операционная система на ПК - реального времени ? Сомневаюсь. Видимо, в этом корень зла - ПК не успевает перерабатывть инфу в темпе ее поступления. И как ни увеличивай размер буфера - не поможет : как ни велика бочка, но если в нее вливается больше, чем вытекает - затопит соседей снизу по любому :(
Идеи - а предварительную обработку на стороне МК нельзя, чтобы отправлять слегка сжатые данные ?

Re: Потери при передаче через UART.

Вт июн 06, 2017 16:14:47

Можно попробовать уменьшить длину проводов и/или заменить их на какие-нибудь хитровыделанные, типа витой пары.
У меня PL2303 тоже нет-нет, да и выдавал те же 0,1% ошибок на 4,5Mbs.
Потом радикально укоротил ему провода и заработало, да еще и на 6Mbs.

Re: Потери при передаче через UART.

Вт июн 06, 2017 22:23:52

Потом радикально укоротил ему провода и заработало, да еще и на 6Mbs.

А вот с этого места хотелось бы поподробнее. С какой частотой вы отправляли байты?

Re: Потери при передаче через UART.

Вт июн 06, 2017 22:51:17

Я не слал по одному байту. Резервировал буфер размером 240х320х2=153600 байт, заполнял его, а потом слал целиком.

Re: Потери при передаче через UART.

Ср июн 07, 2017 05:12:33

А попробовать использовать для обмена любой известный протокол обмена с коррекцией ошибок не пробовали? :)

Re: Потери при передаче через UART.

Ср июн 07, 2017 10:24:51

As писал(а):А попробовать использовать для обмена любой известный протокол обмена с коррекцией ошибок не пробовали?

+100500...Ну, это первое, что приходит в голову любому человеку, который не хочет секса на ровном месте :)...Даже TCP поверх RS232 есть :). Но начать надо с того (т.к. упоминается МК), чтобы посмотреть, а нормальный ли там RS? Обычно любители секаса “3-хпроводковый” пользуют...А вообще, последовательный порт не для высокой скорости...- пользуйте SPI ну либо, ethernet - дотаборды даже для аруинщиков продаются....

Re: Потери при передаче через UART.

Ср июн 07, 2017 20:02:41

А попробовать использовать для обмена любой известный протокол обмена с коррекцией ошибок не пробовали? :)

Микроконтроллер у меня - мега48. Со сложными алгоритмами обработки там не разгуляешься. Мне надо проверять некоторый импульсный сигнал с временной модуляцией. МК просто засекает импульсы таймером в режиме захвата и отправляет содержимое ICR1 в UART. А вся обработка идет в компьютере.

Добавлено after 2 minutes 47 seconds:
Я не слал по одному байту. Резервировал буфер размером 240х320х2=153600 байт, заполнял его, а потом слал целиком.

А еще вопрос. Направление передачи какое? От МК в компьютер или наоборот?

Re: Потери при передаче через UART.

Ср июн 07, 2017 22:41:50

Конечно, там на месте виднее, но мне видятся 2 пути:
- Упираться в мегу8, которой в обед сто лет, и пытаться заставить ее гнать немыслимые объемы инфы в ПК.
- Взять какой-нить STM с ресурсами на порядок большими при сравнимой цене и загрузить его частью интеллектуальной работы.
Я так и не увидел метода, как при самых коротких и сверхэкранированных витых парах обеспечить обработку пришедшего большего количества информации, чем сможет ПК с нереалтаймовой (не так ли?) операционкой.

Re: Потери при передаче через UART.

Чт июн 08, 2017 01:54:57

А еще вопрос. Направление передачи какое? От МК в компьютер или наоборот?
От ПК к МК (PIC18F2520).

Re: Потери при передаче через UART.

Чт июн 08, 2017 08:56:34

paskal писал(а):Микроконтроллер у меня - мега48
У него быстродействия хватит для прима и передачи
paskal писал(а):со скоростью 3 Мбит
Для обмена с такой скоростью нужна частота тактирования МК повыше и наличие DMA.

Re: Потери при передаче через UART.

Чт июн 08, 2017 09:01:20

FT232 подключается через USB 2.0, для которого даже 10 Мбит ерунда, все дело в правильной буферизации (при условии, что данные не пропадают на линии UART), а именно в правильной работе с буфером SerialPort. Как Вы читаете данные из буфера ?

Re: Потери при передаче через UART.

Чт июн 15, 2017 21:34:11

Как Вы читаете данные из буфера ?

Как из обычного ком порта - функцией ReadFile. Анализ потерь показывает что данные теряются непрерывными блоками. О есть идет прием вообще без потерь. Потом вдруг кусок данных пропадает, потом снова прием без потерь.
Ответить