|
RS232 9-ти битный формат, RS232 9-ти битный формат |
|
|
|
Apr 4 2007, 21:23
|
Участник

Группа: Участник
Сообщений: 29
Регистрация: 9-04-06
Пользователь №: 15 961

|
В микроконтроллерах в модуле UART есть 9-ти битный адресный режим. Кто-нибудь пробовал организовать связь, используя этот режим между ПК и контроллером? Непонятно как настроить такой режим последовательного порта компьютера. Между двумя контроллерами все ок, но нужно связать с ПК. Заранее благодарен за дельные советы.
|
|
|
|
|
 |
Ответов
(15 - 29)
|
Apr 5 2007, 10:49
|
Участник

Группа: Участник
Сообщений: 29
Регистрация: 9-04-06
Пользователь №: 15 961

|
Спасибо всем откликнувшимся. Будем изучать материал по вашим ссылкам.
|
|
|
|
|
Apr 5 2007, 12:55
|
Участник

Группа: Новичок
Сообщений: 29
Регистрация: 20-07-05
Из: Рязань
Пользователь №: 6 941

|
Мы наступали на подобные грабли. (В качестве 9 бита использовался бит четности, установка parityMark/paritySpace) 2 распостраненные засады: 1) Переключение с parityMark на paritySpace при выполнении программы происходит раньше, чем байт будет выдан через UART (освободится сдвиговый регистр). В результате на линию будет выдан байт с состоянием paritySpace. 2) При попытке реализации задержек с использованием функции sleep между адресным байтом и байтом данных возникает пауза, не меньшая времени переключеня задач Windows (10 мс для Win2K). Многие устройства эту паузу принимают за срыв посылки.
--------------------
...Эксперт - человек, который знает все больше и больше о все меньшем и меньшем, пока не будет знать абсолютно все абсолютно ни о чем... (с) Законы Мерфи.
|
|
|
|
|
Apr 5 2007, 13:43
|
Участник

Группа: Участник
Сообщений: 29
Регистрация: 9-04-06
Пользователь №: 15 961

|
Цитата(OgRom @ Apr 5 2007, 13:55)  Мы наступали на подобные грабли. (В качестве 9 бита использовался бит четности, установка parityMark/paritySpace) 2 распостраненные засады: 1) Переключение с parityMark на paritySpace при выполнении программы происходит раньше, чем байт будет выдан через UART (освободится сдвиговый регистр). В результате на линию будет выдан байт с состоянием paritySpace. 2) При попытке реализации задержек с использованием функции sleep между адресным байтом и байтом данных возникает пауза, не меньшая времени переключеня задач Windows (10 мс для Win2K). Многие устройства эту паузу принимают за срыв посылки. Похоже у нас то же самое. Как Вы боролись с этими проблемами?
|
|
|
|
|
Apr 5 2007, 14:03
|
Участник

Группа: Новичок
Сообщений: 29
Регистрация: 20-07-05
Из: Рязань
Пользователь №: 6 941

|
Цитата(Microdevice @ Apr 5 2007, 14:43)  Похоже у нас то же самое. Как Вы боролись с этими проблемами? 1) WIN95,98,ME - непосредственная работа с UART (контроль состояния завершения выдачи). В связи с вымиранием вышеуказанных ОС неактуально  2)NT семейство - програмная реализация задержек, без использования команд sleep, используем GetTickCount. При этом в NT семействе ни один из применявшихся нами способов избежать паузу в 10 мс между адресным и последующим байтом не позволяет...
--------------------
...Эксперт - человек, который знает все больше и больше о все меньшем и меньшем, пока не будет знать абсолютно все абсолютно ни о чем... (с) Законы Мерфи.
|
|
|
|
|
Apr 5 2007, 18:12
|
Местный
  
Группа: Свой
Сообщений: 234
Регистрация: 30-03-07
Из: Одесса
Пользователь №: 26 621

|
Идея использовать 9-й бит, конечно заманчива, но почитайте историю наступания на данные грабли. Предположим, возьмем Виндоуз ХР. Все будет работать, при соблюдении двух условий: если порт открыт, как overlapped и... система достаточно чистая. Алгоритм следующий: 1. Инициализируем DCB как 9 бит с пробелом. 2. Пишем в порт 1 байт. 3. Опять переиниализируем DCB как 9 бит, но уже с маркером. 4. Пишем данные. Можно еще лапкой дергать RTS для управления 485 драйвером, все работает. Но. Если не дай бог, на машине вдруг будет установлен модем, либо драйвер считывателя штрих-кодов, либо виртуальный КОМ, начинается развлекуха. Порт на таком алгоритме просто виснет. В логах системы появляется сообщение, что драйвер устройства выполнил некорректную операцию и выгружен. КОМ порт исчезает из системы. Обойти эту залипуху можно, если между вторым и третьим пунктом воткнуть операцию Sleep(1); Пауза между первым(адресным) байтом и остальным пакетом составляет 5-20 мСек, а если запущен Winamp, то и все 50. Посему я расслабился использовать этот способ адресации на компортах и никому бы не советовал напрягаться. Проще использовать механизм от MODBUS.
Sorry, поправка, я пробел с маркером перепутал.
|
|
|
|
|
Apr 5 2007, 20:43
|

Гуру
     
Группа: Свой
Сообщений: 2 538
Регистрация: 13-08-05
Пользователь №: 7 591

|
Цитата(zltigo @ Apr 5 2007, 21:39)  Рассказывайне как там "тупо" под WINNT API чем-нибудь дергать и так-же "тупо" опрашивать. Тупо так. hCom=CreateFile(COM.c_str(),GENERIC_READ|GENERIC_WRITE, 0, NULL, OPEN_EXISTING, 0, NULL); EscapeCommFunction(hCom,SETBREAK); //1 EscapeCommFunction(hCom,CLRBREAK); //0
|
|
|
|
|
Apr 6 2007, 10:20
|

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

|
Цитата(muravei @ Apr 6 2007, 08:23)  Не Break, а SETBREAK и CLRBREAK Нет именно Break. Set и Clear это уже управление Break-ом - посылкой длинного стартового бита с длительностью гарантированно превыщающей длительность всего фрейма (включая стоповые биты) на заданной скорости. Никаких аппаратных или драйверных средств для задания и соблюдения длительности Break и тем более паузы между Break не предусмотрено. Определения длительности Break (полько пороговое превышение) и пауз между Break-ами тоже не предусмотрено, что ставит крест на приеме. "Простейшие программаторы" закончили свое существование на Win9x. На WinNT они уже не жильцы, если, естествено, под них не написан свой драйвер. Написание своего драйвера снимает и проблему с передачей 9 бита через Parity.
--------------------
Feci, quod potui, faciant meliora potentes
|
|
|
|
|
Apr 6 2007, 11:34
|

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

|
Цитата(muravei @ Apr 6 2007, 10:15)  ...до момента пока не будет послан противоположный. Естественно, поскольку, как я уже писал, НИКАКИХ средств для управления длительностью не предоставляется - все на уровне приложения. К чему это Ваша ремарка? К тому, что если махать Break раз, например, в минуту, (ну ладно с временными интервалами более-менее точно обеспечиваемыми Win и его RS232 драйвером) то оно "прокатит" для медленнооооой передачи? Цитата Кстати , про скорость и про дуплекс никто не намекал. Да не намекал. Намеком это действительно назвать сложно: Цитата И так же 2 байта прием от контроллера. Это прямое указание на необходимость дуплекса.
--------------------
Feci, quod potui, faciant meliora potentes
|
|
|
|
|
  |
1 чел. читают эту тему (гостей: 1, скрытых пользователей: 0)
Пользователей: 0
|
|
|