реклама на сайте
подробности

 
 
3 страниц V  < 1 2 3 >  
Reply to this topicStart new topic
> USART на ATMega 16, На комп выдает непонятные символы
Sergio66
сообщение Feb 6 2006, 10:35
Сообщение #16


Местный
***

Группа: Свой
Сообщений: 235
Регистрация: 9-02-05
Пользователь №: 2 526



Так вроде бы никаких ошибок в настройках нет. А как настроена приемная часть? И, если я правильно понял, то на 1 переданный байт приходится аж 5 принятых. А что будет, если изменить передачу. Например, передавать такие коды: 0х01, 0х02, 0х04, и т.д. Что будет на приеме? Попробуйте передать 7 байт вот таким образом и посмотрите, что на приемнем конце. И еще - проверьте структуру и в частности битовое поле USCRA.5!
Go to the top of the page
 
+Quote Post
ivan2006
сообщение Feb 6 2006, 13:15
Сообщение #17


Участник
*

Группа: Свой
Сообщений: 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 на компе и посмотрите на полученные данные, с большой вероятностью проблема решится.
Go to the top of the page
 
+Quote Post
ILYCHOFF
сообщение Feb 6 2006, 13:41
Сообщение #18


Частый гость
**

Группа: Свой
Сообщений: 78
Регистрация: 5-07-05
Из: Великий Новгород
Пользователь №: 6 536



у меня стоит кварц 4 МГц скорость 9600 ошибка составляет 0,2 % как CV пишет, может из-за этого такое происходить?
смотрю осциллографом при передачи 0x01 с контроллера выходит стартовый бит лог. 0 затем первый бит данных - лог. 1 и до следующей посылки а после MAX232 сигнал полностью инвертирован, т. е. стартовый бит лог. 1, а не 0, так и должно быть ? для компа стартовый бит должен быть лог. 1 ???
Go to the top of the page
 
+Quote Post
BVU
сообщение Feb 6 2006, 14:30
Сообщение #19


Профессионал
*****

Группа: Свой
Сообщений: 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 порта). На форуме по ним ссылок было достаточно.


--------------------
Не корысти ради, не в целях наживы, а во исполнение велений души!
Go to the top of the page
 
+Quote Post
kay
сообщение Feb 6 2006, 14:32
Сообщение #20


Участник
*

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



попробуй открыть ком порт на разных скоростях, у тебя похоже скорости приёмника/передатчика несовпадают.

а если не поможет, то собери кабель вот по этой схеме. я такой для сотового телефона делал, работает замечательно, главное включить сигналы DTR или RTS, а то питания не будет. А можно питание отдельно прикрутить, как описано тут.

Сообщение отредактировал kay - Feb 6 2006, 14:34
Go to the top of the page
 
+Quote Post
BVU
сообщение Feb 6 2006, 14:52
Сообщение #21


Профессионал
*****

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



Цитата(kay @ Feb 6 2006, 17:32) *
попробуй открыть ком порт на разных скоростях, у тебя похоже скорости приёмника/передатчика несовпадают.

а если не поможет, то собери кабель вот по этой схеме. я такой для сотового телефона делал, работает замечательно, главное включить сигналы DTR или RTS, а то питания не будет. А можно питание отдельно прикрутить, как описано тут.

Да проблема уже понятна давным-давно! Но советы и рекомендации инициатор темы не воспринимает... angry.gif
Уважаемый, ILYCHOFF.
Это выглядит так: (МК[передатчик/приемник] - RS232 - [передатчик/приемник]ПК): скорость приема (Baud Rate), количество бит данных (Data), бит паритета (Parity), стоповые биты (SBit) - должны быть одинаковыми!!!
В первую очередь заняться надо проверкой именно этого.
Выкладывайте код инициализации UART для МК и ПК, будем смотреть!

P.S. А кабель пока надо попробовать по нуль-модемному варианту.


--------------------
Не корысти ради, не в целях наживы, а во исполнение велений души!
Go to the top of the page
 
+Quote Post
AVR
сообщение Feb 6 2006, 22:09
Сообщение #22


фанат Linux'а
*****

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



Где можно скачать программу RS 232 Pro? Существует ли подобная программа для RS 485?


--------------------
Go to the top of the page
 
+Quote Post
defunct
сообщение Feb 6 2006, 22:56
Сообщение #23


кекс
******

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



Цитата(ILYCHOFF @ Feb 6 2006, 11:54) *
UDR = ('1');
...

Это в ASCII

12:46:38> xяЂ

Это в HEX

12:47:52> 78 00 FF 80


'1' = $31 (00110001) у Вас растягивается в 0000000111111111000000001111, следовательно два варианта, либо частота чипа меньше в 4 раза, либо делитель уарта больше в 4 раза. Последнее исключается, т.к. в программе четко видно как Вы задаете делитель УАРТа. Остается только вариант с пониженной частотой тактирования чипа в 4 раза. 4Mhz/4 = 1Mhz. 1Mhz - это частота внутреннего RC генератора, и именно на работу от внутреннего генератора Mega16 настраивается заводом-изготовителем.

Запрограммируйте Low Fuse Byte, биты CKSEL=1111 для тактирования чипа от кварца.

Сообщение отредактировал defunct - Feb 6 2006, 23:08
Go to the top of the page
 
+Quote Post
ILYCHOFF
сообщение Feb 7 2006, 07:50
Сообщение #24


Частый гость
**

Группа: Свой
Сообщений: 78
Регистрация: 5-07-05
Из: Великий Новгород
Пользователь №: 6 536



Разобрался. Всем большое спасибо, особенно defunct , причина была именно в этом проц считал с частотой 1 МГц. Тему можно закрывать. еще раз всем большое спасибо.....
Go to the top of the page
 
+Quote Post
AVR
сообщение Mar 14 2006, 23:43
Сообщение #25


фанат Linux'а
*****

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



Посоветуйте, пожалуйста, недорогую микросхему в DIP корпусе для того чтобы подключить контроллер с uart к com порту ПК на расстоянии одного метра и скоростью 57600 бит/с. Насколько я понимаю, на выходе TXD контроллера низкий логический уровень ~0 В, а высокий около напряжения питания (например 5 В). С другой стороны com порт воспринимает +11 В как единицу и -11 В как ноль. Выполняют ли такое преобразование микросхемы типа max232 (помимо инверсии)?


--------------------
Go to the top of the page
 
+Quote Post
defunct
сообщение Mar 15 2006, 02:53
Сообщение #26


кекс
******

Группа: Свой
Сообщений: 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
Go to the top of the page
 
+Quote Post
AVR
сообщение Mar 16 2006, 21:02
Сообщение #27


фанат Linux'а
*****

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



Цитата(defunct @ Mar 15 2006, 05:53) *
Думаю, если Вы не делаете промышленное устройство, то простого инвертора на одном транзисторе (по каждому каналу) будет достаточно. Из собственных экпериментов точно знаю, что COM порт компьютера нормально воспринимает уровни TTL так:
меньше 3V- лог. 1
больше 3V -лог. 0

Большое спасибо за совет, такой вариант действительно работает wink.gif
Правда при приёме (при передаче такого не наблюдается) на компьютере периодически (раз в пол минуты и длится секунд десять) в rs232pro видно как набегают помехи, что видимо связано с малым запасом помехоустойчивости (у меня "1" - ~0 В, "0" - +5 В). Можно ли это как-то побороть?


--------------------
Go to the top of the page
 
+Quote Post
defunct
сообщение Mar 17 2006, 04:23
Сообщение #28


кекс
******

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



Цитата(AVR @ Mar 16 2006, 23:02) *
в rs232pro видно как набегают помехи, что видимо связано с малым запасом помехоустойчивости (у меня "1" - ~0 В, "0" - +5 В). Можно ли это как-то побороть?

Pull-up на коллектор транзистора "сбоящего" канала поменьше поставьте ~500om-1kom..

Сообщение отредактировал defunct - Mar 17 2006, 04:24
Go to the top of the page
 
+Quote Post
alekseykoj
сообщение Mar 17 2006, 08:46
Сообщение #29


Участник
*

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



У тебя не согласована скорость между компьютером и микроконтроллером. Еще внимательнее проверь настройки USART
Go to the top of the page
 
+Quote Post
AVR
сообщение Mar 17 2006, 09:49
Сообщение #30


фанат 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

Скорость нормально согласована, т.к. когда я непрерывно в течении нескольких минут что-то передаю в компьютер, вся посылка доходит без каких-либо искажений, когда же ничего не передаю, временами принимается "каша"...


--------------------
Go to the top of the page
 
+Quote Post

3 страниц V  < 1 2 3 >
Reply to this topicStart new topic
1 чел. читают эту тему (гостей: 1, скрытых пользователей: 0)
Пользователей: 0

 


RSS Текстовая версия Сейчас: 23rd July 2025 - 09:03
Рейтинг@Mail.ru


Страница сгенерированна за 0.59498 секунд с 7
ELECTRONIX ©2004-2016