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

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

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

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

|
Цитата(zltigo @ Apr 4 2007, 22:33)  Никак, если только речь не идет о вспомогательной функции 9бита при передаче к PC, тогда к нему можно некоторый доступ через parity получить. Описание 550 чипа не секрет - ознакомьтесь. Именно по этому пути я и пошел. Перед передачей из ПК адресного байта в Delphi: procedure SetCommandByte; begin if not Windows.GetCommState(f, dcb) then exit; dcb.Parity := 3; Windows.SetCommState(f, dcb); end; Перед обычным 8 битовым procedure SetDataByte; begin if not Windows.GetCommState(f, dcb) then exit; dcb.Parity := 4; Windows.SetCommState(f, dcb); end; И ничего не получается.
|
|
|
|
|
Apr 4 2007, 22:19
|
Участник

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

|
Цитата(rezident @ Apr 4 2007, 23:09)  Анализ бита Parity или управление им в Windows по-моему геморрой еще тот. Когда-то у нас применяли этот способ адресации при реализации протокола PiNet, но потом отказались. Windows по большому счету чихать хотела на наличие/отсутствие/нарушение parity. Поток данных от COM-порта принимается в любом случае. Речь не о приеме данных в ПК, а о передаче из него на устройство. Нужно первый байт сделать адресным, последующие обычные 8-ми битовые.
|
|
|
|
|
Apr 4 2007, 22:26
|
Участник

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

|
Цитата(zltigo @ Apr 4 2007, 23:22)  Про какой-нибудь, как обычно левый "компонет" Delphi + Штатный драйвер от MS придется почти наверняка забыть. Драйверок свой писать, ну а вррбще пожалуй Вам SLIP полагаю стоит посмотреть. Все на API без компонентов. А что такое SLIP?
|
|
|
|
|
Apr 4 2007, 22:53
|
Участник

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

|
И чем мне это поможет? Мне нужно как-то портом оперировать.
|
|
|
|
|
Apr 4 2007, 23:13
|

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

|
Цитата(Microdevice @ Apr 4 2007, 21:53)  И чем мне это поможет? Мне нужно как-то портом оперировать. Насколько я понимаю цель не "портом оперировать". Это стедство достижения цели. Какой? Полагаю цель выделить начало передачи некого фрейма/пакета? Эта цель достигается в SLIP протоколе не вводя 9 бит.
--------------------
Feci, quod potui, faciant meliora potentes
|
|
|
|
|
Apr 4 2007, 23:27
|
Участник

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

|
Нужно передать 2 байта. В первом 9-й бит (понятно что это уже не байт) должен быть установлен в "1", второй с "0" в 9-м бите. И так же 2 байта прием от контроллера.
Пардон. Речь конечно о 8-м бите. Голова уже кругом идет.
|
|
|
|
|
Apr 4 2007, 23:52
|
Участник

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

|
Можно поподробнее? Начало пакета знаем (2 по 9 бит). Прошивку в железе менять нельзя, знаем только протокол по которому можно с ней общаться.
Нужно именно 2 посылки по 9 бит.
|
|
|
|
|
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
|
|
|
|
|
Apr 6 2007, 13:42
|

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

|
C передачей полагаю уже выяснили - если вдруг с какого-то бодуна разработчики контроллера предусмотрели работу на скоростях в несколько бод, то все прекрасно складывается  . Цитата(muravei @ Apr 6 2007, 12:31)  Или полудуплекса  , или Вы читаете между строк? Просто повторил Ваши слова. Хотите полудуплекс - нехай будет, и симлекс пусть будет. Рассказывайте как принимать Break-и на стороне PC будете  .
--------------------
Feci, quod potui, faciant meliora potentes
|
|
|
|
|
Apr 9 2007, 23:39
|

Гуру
     
Группа: Модераторы
Сообщений: 8 455
Регистрация: 15-05-06
Из: Рига, Латвия
Пользователь №: 17 095

|
Цитата(muravei @ Apr 6 2007, 12:31)  Кстати, а как читаются 1-wire через компорт? Очень просто: посылается символ 0xFC и принимается эхо. Если получили 0xFC - слейв передавал единицу, если 0xF8, 0xF0, 0xE0, 0xC0, 0x80, 0x00 - слейв передавал ноль. С Presence pulse тоже самое, только на другой скорости (ну может передается не 0xFC а 0xF0). И никаких чудес. В 1-wire не нормируется время между битами.
--------------------
На любой вопрос даю любой ответ"Write code that is guaranteed to work, not code that doesn’t seem to break" ( C++ FAQ)
|
|
|
|
|
Apr 10 2007, 15:51
|

Гуру
     
Группа: Модераторы
Сообщений: 8 455
Регистрация: 15-05-06
Из: Рига, Латвия
Пользователь №: 17 095

|
Цитата(muravei @ Apr 10 2007, 14:18)  А как со стартовым битом? Стартовый бит равен нулю, стоповый 1, в UART байт передается младшим битом вперед, получается 0xFC = 0001111111, что и требуется для 1-wire. Если в "эхе" больше трех нулей в начале, значит кто-то линию "придержал", т.е передавал ноль, если столько же - передавалась 1, т.е линию никто не тянул вниз.
--------------------
На любой вопрос даю любой ответ"Write code that is guaranteed to work, not code that doesn’t seem to break" ( C++ FAQ)
|
|
|
|
3 чел. читают эту тему (гостей: 3, скрытых пользователей: 0)
Пользователей: 0
|
|
|