|
USART на ATMega 16, На комп выдает непонятные символы |
|
|
3 страниц
1 2 3 >
|
 |
Ответов
(1 - 44)
|
Feb 3 2006, 14:40
|
Участник

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

|
У меня та же самая проблема, только с Atmega8
|
|
|
|
|
Feb 6 2006, 10:05
|

Профессионал
    
Группа: Свой
Сообщений: 1 301
Регистрация: 30-11-04
Из: Россия, Н.Новгород
Пользователь №: 1 264

|
Преобразователи типа: max232 ничего к передаваемой последовательности не добавляют/урезают. В этом случае единственное, что Вы не понимаете внешней вид посылки на линии RS232 (логические уровни, kay сегодня Вам их уже разъяснял). Так же у Вас может быть в схеме одно излишнее инвертирование (или 'не доинвертирование') , которое даст эффект изменения кода (к стати приемники и передатчики max232 с инвертированием)... Так же при возникновении таких ошибок приемник и передатчик могут иметь разные настройки (скорость передачи, длина посылки, паритеты, стоп-биты...)
Сообщение отредактировал BVU - Feb 6 2006, 10:09
--------------------
Не корысти ради, не в целях наживы, а во исполнение велений души!
|
|
|
|
|
Feb 6 2006, 13:15
|
Участник

Группа: Свой
Сообщений: 45
Регистрация: 8-01-06
Из: Петербург
Пользователь №: 12 944

|
2 ILYCHOFF Цитата(ILYCHOFF @ Feb 6 2006, 12:54)  12:46:39> xяЂ ... 12:47:52> 78 00 FF 80 12:47:52> 00 Вообще эти символы (FF и 80) при неправильной работе с УАПП появляются очень часто. FF вместо данных получается, например, если baudrate приемника в ~10 раз больше baudrate передатчика. т.е. пока передатчик отправил только один бит=1, приемник получил все 10. Для предотвращения подобных ситуаций как раз и используют stop-биты. Вторая ошибка может заключатся в лишнем инвертировании сигнала по пути от передатчика к приемнику, например нечто подобное получал, когда делал гальваническую развязку на оптронах и перепутал местами два диода. попробуйте поизменять baudrate на компе и посмотрите на полученные данные, с большой вероятностью проблема решится.
|
|
|
|
|
Feb 6 2006, 14:30
|

Профессионал
    
Группа: Свой
Сообщений: 1 301
Регистрация: 30-11-04
Из: Россия, Н.Новгород
Пользователь №: 1 264

|
Цитата(ILYCHOFF @ Feb 6 2006, 16:41)  у меня стоит кварц 4 МГц скорость 9600 ошибка составляет 0,2 % как CV пишет, может из-за этого такое происходить? смотрю осциллографом при передачи 0x01 с контроллера выходит стартовый бит лог. 0 затем первый бит данных - лог. 1 и до следующей посылки а после MAX232 сигнал полностью инвертирован, т. е. стартовый бит лог. 1, а не 0, так и должно быть ? для компа стартовый бит должен быть лог. 1 ??? Вам же уже написали, что MAX232 - инвертирует!!! У ПК приемник с линии RS232 тоже должет инвертировать... значит данные должны приходить в нормальном виде (двойная инверсия - означает, что принятые данные не инвертированы). Анализировать их необходимо после приемника... И вникнуть ,что у Вас приемник считал на ПК. Пользуйтесь программными анализаторами протокола (для COM порта). На форуме по ним ссылок было достаточно.
--------------------
Не корысти ради, не в целях наживы, а во исполнение велений души!
|
|
|
|
|
Feb 6 2006, 14:32
|

Участник

Группа: Свой
Сообщений: 58
Регистрация: 6-06-05
Пользователь №: 5 781

|
попробуй открыть ком порт на разных скоростях, у тебя похоже скорости приёмника/передатчика несовпадают. а если не поможет, то собери кабель вот по этой схеме. я такой для сотового телефона делал, работает замечательно, главное включить сигналы DTR или RTS, а то питания не будет. А можно питание отдельно прикрутить, как описано тут.
Сообщение отредактировал kay - Feb 6 2006, 14:34
|
|
|
|
|
Feb 6 2006, 14:52
|

Профессионал
    
Группа: Свой
Сообщений: 1 301
Регистрация: 30-11-04
Из: Россия, Н.Новгород
Пользователь №: 1 264

|
Цитата(kay @ Feb 6 2006, 17:32)  попробуй открыть ком порт на разных скоростях, у тебя похоже скорости приёмника/передатчика несовпадают. а если не поможет, то собери кабель вот по этой схеме. я такой для сотового телефона делал, работает замечательно, главное включить сигналы DTR или RTS, а то питания не будет. А можно питание отдельно прикрутить, как описано тут. Да проблема уже понятна давным-давно! Но советы и рекомендации инициатор темы не воспринимает... Уважаемый, ILYCHOFF. Это выглядит так: (МК[передатчик/приемник] - RS232 - [передатчик/приемник]ПК): скорость приема (Baud Rate), количество бит данных (Data), бит паритета (Parity), стоповые биты (SBit) - должны быть одинаковыми!!! В первую очередь заняться надо проверкой именно этого. Выкладывайте код инициализации UART для МК и ПК, будем смотреть! P.S. А кабель пока надо попробовать по нуль-модемному варианту.
--------------------
Не корысти ради, не в целях наживы, а во исполнение велений души!
|
|
|
|
|
Mar 15 2006, 02:53
|

кекс
     
Группа: Свой
Сообщений: 3 825
Регистрация: 17-12-05
Из: Киев
Пользователь №: 12 326

|
Цитата(AVR @ Mar 15 2006, 01:43)  С другой стороны com порт воспринимает +11 В как единицу и -11 В как ноль. Выполняют ли такое преобразование микросхемы типа max232 (помимо инверсии)? Да. max232 - это преобразователь уровней RS <-> TTL. Цитата(AVR @ Mar 15 2006, 01:43)  Насколько я понимаю, на выходе TXD контроллера низкий логический уровень ~0 В, а высокий около напряжения питания (например 5 В). С другой стороны com порт воспринимает +11 В как единицу и -11 В как ноль. Думаю, если Вы не делаете промышленное устройство, то простого инвертора на одном транзисторе (по каждому каналу) будет достаточно. Из собственных экпериментов точно знаю, что COM порт компьютера нормально воспринимает уровни TTL так: меньше 3V- лог. 1 больше 3V -лог. 0
|
|
|
|
|
Mar 17 2006, 08:46
|
Участник

Группа: Свой
Сообщений: 60
Регистрация: 8-11-05
Пользователь №: 10 602

|
У тебя не согласована скорость между компьютером и микроконтроллером. Еще внимательнее проверь настройки USART
|
|
|
|
|
Mar 17 2006, 09:49
|

фанат Linux'а
    
Группа: Свой
Сообщений: 1 353
Регистрация: 23-10-05
Из: SPB.RU
Пользователь №: 10 008

|
Цитата(defunct @ Mar 17 2006, 07:23)  Pull-up на коллектор транзистора "сбоящего" канала поменьше поставьте ~500om-1kom.. У меня вместо транзистора схема 3ИЛИ-НЕ (другой под рукой не оказалось =( ) с объединенными тремя входами в один. Цитата(alekseykoj @ Mar 17 2006, 11:46)  У тебя не согласована скорость между компьютером и микроконтроллером. Еще внимательнее проверь настройки USART Скорость нормально согласована, т.к. когда я непрерывно в течении нескольких минут что-то передаю в компьютер, вся посылка доходит без каких-либо искажений, когда же ничего не передаю, временами принимается "каша"...
--------------------
|
|
|
|
|
Mar 17 2006, 21:13
|

Знающий
   
Группа: Свой
Сообщений: 697
Регистрация: 26-07-05
Из: Могилев
Пользователь №: 7 095

|
2 AVR Если нет под рукой преобразователя уровней RS232, то советую применить схему "токовая петля" (см. в прикрепленном файле), она во-первых, обеспечивает корректное преобразование уровней, во-вторых, обеспечивает гальваническю развязку между AVR и РС, в-третьих, простая. Для того, чтобы заработало в RS232pro выставьте уровни сигналов DTR и RTS как показано на схеме. Если все-таки остановитесь на схеме предложенной defunct, то советую параллельно переходу база-эмиттер транзистора, подключенного базой к Тх ком-порта, подключить диод катодом к базе, дабы защитить переход база-эмиттер от отрицательного напряжения (которое может на некоторых портах достигать -12В, а на базе транзистора в схеме -6В, что уже многовато будет...)
Эскизы прикрепленных изображений
|
|
|
|
|
Jun 30 2006, 05:48
|
Группа: Новичок
Сообщений: 5
Регистрация: 22-02-06
Пользователь №: 14 590

|
Я тоже пытался связаться по 232, правда МК у меня AT90S2313, микросхема МАХ 232. Использовал Advanced Serial Port Monitor и RS232pro, и еще что-то(не помню). Если я правильно помню, то в ДШ на конкретный МК есть таблицы ошибок скоростей передачи при стандартных частотах кварца. Кварц у меня 3.579545Mhz, по ДШ и Applicatiom Builder-у это ошибка в 1.3%, однако у меня данные передавались и принимались без ошибок. Затем я поставил кварц (в ту же схему) на 4Mhz, и уменя пошли всякие кракозябры... ХОТЯ по ДШ и Апп Билдеру ошибка составляет 0.2%...странно Я сам новичок, но мне кажется что дело может быть в кварце. Я думаю что огромное значение имеет производитель. (кварц с которым все работало стоил 15р, а скоторым нет-2р  ) Может быть поможет замена кварца? Удачи!
|
|
|
|
|
Jun 30 2006, 07:12
|
Местный
  
Группа: Новичок
Сообщений: 232
Регистрация: 24-06-06
Пользователь №: 18 332

|
Цитата(ILYCHOFF @ Feb 3 2006, 17:32)  Проц мега16, кварц 4 МГц. Проверьте правильность установки бадрейта, убедитесь что мега работает на нужно частоте.
|
|
|
|
|
Jun 30 2006, 07:36
|
Местный
  
Группа: Новичок
Сообщений: 232
Регистрация: 24-06-06
Пользователь №: 18 332

|
Цитата(AVR @ Mar 19 2006, 20:12)  Глупый вопрос не по теме (прошу не судить строго новичка): Существует ли в интернете электронный каталог, в котором бы все электронные компоненты были отсортированы по их функционального назначению? Например, если в магазине нет какой-то микросхемы, чтобы можно было бы найти её аналог. я видел обзор таких каталогов на [banned]/01.htm
|
|
|
|
|
Jun 30 2006, 09:05
|
Местный
  
Группа: Свой
Сообщений: 263
Регистрация: 22-03-05
Из: г. Харьков, Украина
Пользователь №: 3 598

|
Цитата(Alex3742 @ Jun 30 2006, 08:48)  Я тоже пытался связаться по 232, правда МК у меня AT90S2313, микросхема МАХ 232. Использовал Advanced Serial Port Monitor и RS232pro, и еще что-то(не помню). Если я правильно помню, то в ДШ на конкретный МК есть таблицы ошибок скоростей передачи при стандартных частотах кварца. Кварц у меня 3.579545Mhz, по ДШ и Applicatiom Builder-у это ошибка в 1.3%, однако у меня данные передавались и принимались без ошибок. Затем я поставил кварц (в ту же схему) на 4Mhz, и уменя пошли всякие кракозябры... ХОТЯ по ДШ и Апп Билдеру ошибка составляет 0.2%...странно Я сам новичок, но мне кажется что дело может быть в кварце. Я думаю что огромное значение имеет производитель. (кварц с которым все работало стоил 15р, а скоторым нет-2р  ) Может быть поможет замена кварца? Удачи! Может меня специалисты поправят, но RS протокол работает сносно и при 3% ошибки (где-то когда-то прочитал)! А от кварца требуется стабильность выдаваемой частоты. А для отладки обмена предлагаю следующий метод (сам периодически пользуюсь): Приемник и передатчик постоянно передает по своей линии байт 0х55 (или 0хАА) и двухлучевым осциллографом сравниваются длительности и количество стартовых и стоповых бит. Все наглядно!
|
|
|
|
|
Jun 30 2006, 10:48
|
Группа: Новичок
Сообщений: 5
Регистрация: 22-02-06
Пользователь №: 14 590

|
Цитата(IEC @ Jun 30 2006, 15:05)  Цитата(Alex3742 @ Jun 30 2006, 08:48)  Я тоже пытался связаться по 232, правда МК у меня AT90S2313, микросхема МАХ 232. Использовал Advanced Serial Port Monitor и RS232pro, и еще что-то(не помню). Если я правильно помню, то в ДШ на конкретный МК есть таблицы ошибок скоростей передачи при стандартных частотах кварца. Кварц у меня 3.579545Mhz, по ДШ и Applicatiom Builder-у это ошибка в 1.3%, однако у меня данные передавались и принимались без ошибок. Затем я поставил кварц (в ту же схему) на 4Mhz, и уменя пошли всякие кракозябры... ХОТЯ по ДШ и Апп Билдеру ошибка составляет 0.2%...странно Я сам новичок, но мне кажется что дело может быть в кварце. Я думаю что огромное значение имеет производитель. (кварц с которым все работало стоил 15р, а скоторым нет-2р  ) Может быть поможет замена кварца? Удачи! Может меня специалисты поправят, но RS протокол работает сносно и при 3% ошибки (где-то когда-то прочитал)! А от кварца требуется стабильность выдаваемой частоты. А для отладки обмена предлагаю следующий метод (сам периодически пользуюсь): Приемник и передатчик постоянно передает по своей линии байт 0х55 (или 0хАА) и двухлучевым осциллографом сравниваются длительности и количество стартовых и стоповых бит. Все наглядно! То есть все-таки стабильность частоты?
|
|
|
|
|
Sep 30 2008, 02:35
|
Участник

Группа: Участник
Сообщений: 30
Регистрация: 20-09-08
Пользователь №: 40 344

|
Добрый день. Кто может помочь? Пользуюсь терминалом версии 1.9 Б. Пытаюсь организовать кольцо, чтобы сигнал с компьютера дошел до меги16, и обратно в терминал. Столкнулся с рядом трудностей. Первое когда пишешь программу типа с = UDR PORTA = 55 ОНа работает, светодиоды горят как надо. КОгда пишешь что-то типа С = UDR UDR = C ТЕрминал коннектиться и постоянно получает <0>, не остановить, ни чего сделать не реально. И наконец когда приводишь что ни будь типа этого: #include <avr/io.h> #include <avr/delay.h> #include <avr/interrupt.h> // для доступа к функции сей #include <avr/signal.h> // для доступа к макросу интерупт #include <stdio.h> #include <string.h> int c;
INTERRUPT(SIG_UART0_RECV) { c = UDR; PORTB = c; }
int main (void) //начало программы { DDRB = 0xFF; // все выводы порта B - выходы UBRRH = 0; UBRRL = 71; UCSRA = 0x00; UCSRB |= (1<<RXCIE)|(1<<TXCIE)|(1<<RXEN)|(1<<TXEN);// прерывание на прием, прием UCSRC |= (1<<URSEL); // асинхронный, UCSRC |= (1<<UCSZ1)|(1<<UCSZ0);
sei(); c = 0; while (1); } Терминал так же конектиться, и получает тот же символ <0>, но в момент отправки символа останавливается. Однако светодиоды, подключенные к порту, свое состояние не меняют. И потом, АВРстудия, вообще отказывается толково реагировать на флаг "Прием завершен", перескакивает в самое начало программы и начинает заново - это ненормально потому как нарушается вообще принцип прерывания. И что насчет инверсии, МАХ правда инвертирует сигнал, или нет? Заранее спасибо.
|
|
|
|
|
Sep 30 2008, 07:33
|
Частый гость
 
Группа: Участник
Сообщений: 149
Регистрация: 2-06-08
Из: Москва
Пользователь №: 38 003

|
Цитата(_Ie0nid @ Sep 30 2008, 06:35)  Добрый день. Кто может помочь? ... Может быть проблема в том, что у вас не описан обработчик прерывания по завершению передачи байта? Судя по настройкам у вас включены и приемник и передатчик, и разрешены прерывания от них. Насколько я помню у М16 отдельный адрес для прерывания по событию прием байта завершен и отдельный адрес для прерывания по событию передача байта завершена в векторе прерывания. Также есть адрес по событию пуст регистр УДР. Если АВР студия некорректно симулирует прерывания, то скорее всего это ваша недоработка, вроде переход по вектору должен осуществляться правильно.
|
|
|
|
1 чел. читают эту тему (гостей: 1, скрытых пользователей: 0)
Пользователей: 0
|
|
|