|
UART с управлением паритета, Опциональная передача символа Mark и Space |
|
|
|
Apr 16 2009, 14:02
|
Группа: Новичок
Сообщений: 4
Регистрация: 11-01-06
Пользователь №: 13 058

|
Доброе время суток! Кто сталкивался в LPC210x с необходимостью управления битами паритета Mark и Space, для эмуляции 9-битного варианта передачи данных? Пробовал делать путем ручного переключения этих битов и вылазит такая картина. В пошаговом режиме байты пересылаются нормально (отслеживаю по осцилу). Как только переходит в сплошной поток - то ли LPC не успевает переключаться, то ли еще что-то, но Mark и Space не изменяются.
|
|
|
|
|
Apr 16 2009, 15:06
|
Группа: Новичок
Сообщений: 4
Регистрация: 11-01-06
Пользователь №: 13 058

|
Но ведь не хочется огород городить. В обычном COM порте работает такая штука. Даже в MSP есть. А тут вот такой "Кузьмич".
|
|
|
|
|
Apr 17 2009, 16:57
|

Участник

Группа: Участник
Сообщений: 61
Регистрация: 5-10-05
Из: Зеленоград
Пользователь №: 9 268

|
Мне эта тема тоже интересна. Филипс как всегда "прорвался" и сделал офигенный супер - пуппер чип с UART по какому-то там стандарту, в результате чего сделал недоступными функции независимого управления девятым битом. Как результат, этот чип, похоже, нельзя использовать для реализации шины MDB, а как хотелось бы. Очень интересно, если из этого что-нибудь получится. Я делал подобные вещи на более простом UART на микроконтроллерах P16F628 Microchip. Правда, это не имеет отношения к ARM. Кстати, насчёт сделать UART самому - если хотите изобретать велосипед, готовьтесь быть аутсайдером  Этот форум не для Вас.
|
|
|
|
Guest_@Ark_*
|
Apr 17 2009, 17:45
|
Guests

|
Цитата(IgorMarx @ Apr 17 2009, 20:57)  ... Я делал подобные вещи на более простом UART на микроконтроллерах P16F628 Microchip. Правда, это не имеет отношения к ARM. Кстати, насчёт сделать UART самому - если хотите изобретать велосипед, готовьтесь быть аутсайдером  Этот форум не для Вас. По моему, Вы много на себя берете... Для нормального программиста на МК - UART есть всегда. Вне зависимости от того, есть соответствующий аппаратный модуль или нет. Есть кварцевый генератор или используется встроенный, либо некалиброванный внешний. Программная реализация, нередко, занимает меньше места и работает надежнее, чем обслуживание встроенного UART-а. На тех же PIC-х я делал программый UART для всей линейки: PIC10-PIC12-PIC16, с автоподстройкой под текущую частоту генератора и c автоопределением скорости обмена от 4800 до 115200... P.S. Если Вы никогда этого не делали и не знаете как (или делали один раз), то я бы на Вашем месте воздержался от оценок и советов на этом форуме.
|
|
|
|
|
Apr 17 2009, 19:00
|

Участник

Группа: Участник
Сообщений: 61
Регистрация: 5-10-05
Из: Зеленоград
Пользователь №: 9 268

|
Цитата(@Ark @ Apr 17 2009, 21:45)  P.S. Если Вы никогда этого не делали и не знаете как (или делали один раз), то я бы на Вашем месте воздержался от оценок и советов на этом форуме. Я это делал на том же PIC16F628. Мне нужно было 2 порта. Второй порт я сэмулировал, используя второй таймер и внешнее перывание. По старт биту срабатывает внешнее прерывание, затем в обработчике запускается второй таймер, дальше защёлкивание битов идёт уже по таймеру. Второй таймер очень удобен, если хотите, чтобы вообще что-то получилось. Помучался долго и сумел реализовать скорость 115200 при частоте кварца 18.432 MHz, причем задача стояла, чтобы это работало именно в прерываниях. В своё время я писал аппаратные реализации драйверов загрузки с магнитной лентой, причем с необходимостью синхронного вывода графики на некий экран. У меня есть собственные реализации алгоритма шифрования AES-128, который при чтении с COM порта расшифровывает поток "на лету". Тему я хорошо знаю, поэтому не советую заниматься этой ботвой, если только вообще нечем заняться. Один раз, хм... А сколько раз нужно на швабру наступать, если не один? aerolog, не мучайтесь с этим UARTом, @Ark прав, используйте CAPTURE регистры. Здесь готовое решение: http://www.nxp.com/acrobat_download/applic...s/AN10689_1.pdf
Сообщение отредактировал IgorMarx - Apr 17 2009, 19:13
|
|
|
|
Guest_@Ark_*
|
Apr 17 2009, 19:16
|
Guests

|
Цитата(IgorMarx @ Apr 17 2009, 23:00)  Я это делал на том же PIC16F628... Тему я хорошо знаю... Я Вам еще раз предлагаю воздержаться от оценок и советов, поскольку тему реализации программного UART-а Вы не знаете (без обид). В экстремальном случае все делается и на 4МГц и даже без использования таймеров... Но это крайний случай... Я просто Вам ответственно могу заявить - для нормального программера не бывает такой ситуации - нет UART-а. UART есть всегда! По определению.
|
|
|
|
|
Apr 17 2009, 19:25
|

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

|
Цитата(aerolog @ Apr 16 2009, 17:02)  В пошаговом режиме байты пересылаются нормально (отслеживаю по осцилу). Как только переходит в сплошной поток - то ли LPC не успевает переключаться, то ли еще что-то, но Mark и Space не изменяются. Дело скорее всего в том, что там имеется FIFO, в которое попадают данные, но не бит управления четностью. Когда вы отлаживаете пошагово, байт успевает передаться и влияние FIFO незаметно. Надо отключить FIFO.
--------------------
На любой вопрос даю любой ответ"Write code that is guaranteed to work, not code that doesn’t seem to break" ( C++ FAQ)
|
|
|
|
|
Apr 17 2009, 19:59
|

Участник

Группа: Участник
Сообщений: 61
Регистрация: 5-10-05
Из: Зеленоград
Пользователь №: 9 268

|
Споры - дело дурное. Каждый в любом случае останется при своём мнении. Очень интересно, получится ли управлять девятым битом. Сейчас мне заняться этим просто некогда, но если что-то выйдет, поделюсь. Соответственно, надеюсь, что тут будет опубликован результат, если у кого что получится. P.S. А может, любезный @Ark найдёт решение? Спец же по портам  Будем ему благодарны aerolog, попробуйте, как говорит Сергей, отключить фифо и перед записью в THR выставлять требуемые значения битов Parity Select регистра LCR со включенным Parity Enable. Возможно перед этим нужно дожидаться, чтобы освободился буфер передатчика (установился бит THRE или TEMT (какой конкретно нужнопроверять).
|
|
|
|
|
Apr 17 2009, 20:36
|

Местный
  
Группа: Участник
Сообщений: 219
Регистрация: 20-11-07
Пользователь №: 32 484

|
Цитата(Сергей Борщ @ Apr 17 2009, 23:25)  Надо отключить FIFO. Зачем же Вы плохое советуете? Код UART0 FIFOs are disabled. Must not be used in the application.
|
|
|
|
|
Apr 17 2009, 20:46
|

читатель даташитов
   
Группа: Свой
Сообщений: 853
Регистрация: 5-11-06
Из: Днепропетровск
Пользователь №: 21 999

|
Цитата(meister @ Apr 17 2009, 23:36)  Зачем же Вы плохое советуете? Код UART0 FIFOs are disabled. Must not be used in the application. Имеется в виду установить Trigger level 0 (1 character or 0x01). Неоднократо обсуждалось.
|
|
|
|
Guest_@Ark_*
|
Apr 17 2009, 22:48
|
Guests

|
Цитата(IgorMarx @ Apr 17 2009, 23:59)  ... А может, любезный @Ark найдёт решение? Спец же по портам  Будем ему благодарны  Если верить тому, что написано в ДШ на этот камень, его UART совместим по регистрам со стандартом 16550. В PC такой же UART стоит на COM-портах (точнее, стоял). Известная вещь. Берем описание и читаем... Перед выбором режима управления четностью рекомендуется очистить очередь приемника и передатчика - установкой 1-го и 2-го бита соответственно в регистре управления буферизацией... Кстати, управлять напрямую значением девятого бита нельзя, можно лишь выбрать один из режимов - контроль четности, контроль нечетности, нет контроля. Если в последнем случае задать 2 стоп бита, то девятый бит всегда будет 1... Итого: если хотите самостоятельно управлять девятым битом, придется FIFO отключить совсем. Перед передачей каждого байта выбирать режим четность/нечетность таким образом, чтобы девятый бит принимал нужное значение... Короче - геморрой. Проще сделать программно...
|
|
|
|
1 чел. читают эту тему (гостей: 1, скрытых пользователей: 0)
Пользователей: 0
|
|
|