Перейти к содержанию
    

RS232 9-ти битный формат

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

Поделиться сообщением


Ссылка на сообщение
Поделиться на другие сайты

Непонятно как настроить такой режим последовательного порта компьютера.

Никак, если только речь не идет о вспомогательной функции 9бита при передаче к PC, тогда к нему

можно некоторый доступ через parity получить. Описание 550 чипа не секрет - ознакомьтесь.

Поделиться сообщением


Ссылка на сообщение
Поделиться на другие сайты

Никак, если только речь не идет о вспомогательной функции 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;

 

И ничего не получается. :(

Поделиться сообщением


Ссылка на сообщение
Поделиться на другие сайты

Никак, если только речь не идет о вспомогательной функции 9бита при передаче к PC, тогда к нему

можно некоторый доступ через parity получить. Описание 550 чипа не секрет - ознакомьтесь.

Анализ бита Parity или управление им в Windows по-моему геморрой еще тот. Когда-то у нас применяли этот способ адресации при реализации протокола PiNet, но потом отказались. Windows по большому счету чихать хотела на наличие/отсутствие/нарушение parity. Поток данных от COM-порта принимается в любом случае.

Поделиться сообщением


Ссылка на сообщение
Поделиться на другие сайты

Анализ бита Parity или управление им в Windows по-моему геморрой еще тот. Когда-то у нас применяли этот способ адресации при реализации протокола PiNet, но потом отказались. Windows по большому счету чихать хотела на наличие/отсутствие/нарушение parity. Поток данных от COM-порта принимается в любом случае.

Речь не о приеме данных в ПК, а о передаче из него на устройство. Нужно первый байт сделать адресным, последующие обычные 8-ми битовые.

Поделиться сообщением


Ссылка на сообщение
Поделиться на другие сайты

Перед передачей из ПК адресного байта в Delphi:

Про какой-нибудь, как обычно левый "компонет" Delphi + Штатный драйвер от MS придется почти наверняка забыть.

Драйверок свой писать, ну а вррбще пожалуй Вам SLIP полагаю стоит посмотреть.

Поделиться сообщением


Ссылка на сообщение
Поделиться на другие сайты

Про какой-нибудь, как обычно левый "компонет" Delphi + Штатный драйвер от MS придется почти наверняка забыть.

Драйверок свой писать, ну а вррбще пожалуй Вам SLIP полагаю стоит посмотреть.

Все на API без компонентов. А что такое SLIP?

Поделиться сообщением


Ссылка на сообщение
Поделиться на другие сайты

И чем мне это поможет? Мне нужно как-то портом оперировать.

Насколько я понимаю цель не "портом оперировать". Это стедство достижения цели. Какой?

Полагаю цель выделить начало передачи некого фрейма/пакета? Эта цель достигается в SLIP протоколе не вводя 9 бит.

Поделиться сообщением


Ссылка на сообщение
Поделиться на другие сайты

Нужно передать 2 байта. В первом 9-й бит (понятно что это уже не байт) должен быть установлен в "1", второй с "0" в 9-м бите. И так же 2 байта прием от контроллера.

 

Пардон. Речь конечно о 8-м бите. Голова уже кругом идет.

Поделиться сообщением


Ссылка на сообщение
Поделиться на другие сайты

В первом 9-й бит (понятно что это уже не байт) должен быть установлен в "1", второй с "0" в 9-м бите.

Опять средство :)

Перевожу на понятный язык - нужно передать пакет из двух байт (16 бит). Начало пакета надо знать.

Его отметка 9м битом лишь один из вариантов реализации задачи. Задача отметки битом нормально не реализуема на стороне PC+Windows. Значит придется добавлять байтстаффинг (SLIP), или UUE кодирование, или подобное.

Поделиться сообщением


Ссылка на сообщение
Поделиться на другие сайты

Можно поподробнее? Начало пакета знаем (2 по 9 бит). Прошивку в железе менять нельзя, знаем только протокол по которому можно с ней общаться.

 

Нужно именно 2 посылки по 9 бит.

Поделиться сообщением


Ссылка на сообщение
Поделиться на другие сайты

Прошивку в железе менять нельзя

Пишите нормальный драйвер ориентированный на выделение двухбайтовых посылок для Win.

Либо пытайтесь выделять прием в PC без 9бита (по крайней мере только иногда по нему подсинхронизироваться удастся) и постоянное перепрограммирование порта перемежающееся flush(). Да, и FIFO отключите.

Поделиться сообщением


Ссылка на сообщение
Поделиться на другие сайты

zltigo, да не запутывайте вы окончательно товарища! Не понимает он с ходу термина "битстаффинг" и принципов транспортного протокола. Отсутствие опыта не порок и дело наживное ИМХО. Если на SLIP ссылку не даете, так хоть на Wake дайте. Зря что ли Леонид Иванович старался, статью писал, примеры и dll-ки выкладывал? ;)

Спецификация протокола WAKE

Поделиться сообщением


Ссылка на сообщение
Поделиться на другие сайты

Присоединяйтесь к обсуждению

Вы можете написать сейчас и зарегистрироваться позже. Если у вас есть аккаунт, авторизуйтесь, чтобы опубликовать от имени своего аккаунта.

Гость
Ответить в этой теме...

×   Вставлено с форматированием.   Вставить как обычный текст

  Разрешено использовать не более 75 эмодзи.

×   Ваша ссылка была автоматически встроена.   Отображать как обычную ссылку

×   Ваш предыдущий контент был восстановлен.   Очистить редактор

×   Вы не можете вставлять изображения напрямую. Загружайте или вставляйте изображения по ссылке.

×
×
  • Создать...