|
Непонятный глюк с Atxmega64A3U, Зависает часть периферии |
|
|
|
Mar 14 2013, 16:40
|

Гуру
     
Группа: Свой
Сообщений: 2 720
Регистрация: 24-03-05
Пользователь №: 3 659

|
Привет всем!
Есть устройство в котором задействовано множество периферии. На PORTD бит 5 является выходом. Используется как стробирующий выход. Пассивное состояние - 0. Управляется программой. На PORTE задействовано два USART - USARTE0 (для связи с периферийным устройством) и USARTE1 (как отладочный порт для вывода на РС сообщений).
Программа работает следующим образом 1. Инициализируется вся периферия (порты ввода-вывода, USART, таймеры и т.п.) 2. Далее подается строб на PORTD5.
Ситуация следующая: 1. Если питание подано в первый раз то после перехода строба из 0 в 1 вся периферия вешается! Т.е. оба USART не работают и еще часть периферии так же не работает. Программа может зависнуть.
2. Если сбросить процессор не снимая питания, то все работает как задумано.
Отрезал провода от USARTE0, от PORTD5 - ничего не помогло! Начал разбираться с программой. Оказалось, что если я не разрешаю приемник USARTE1, т. е. в регистре CTRLB не устанавливаю бит RXEN то при первой подаче питания все работает как положено. Далее установил, что если после того, как программа сгенерирует строб, разрешить приемник, то тоже все работает замечательно.
Два дня ломаю голову, чтобы это могло быть? Есть какие нибудь идеи?
--------------------
|
|
|
|
|
Mar 14 2013, 17:27
|

Гуру
     
Группа: Свой
Сообщений: 2 720
Регистрация: 24-03-05
Пользователь №: 3 659

|
Цитата(kovigor @ Mar 14 2013, 23:01)  -Какие-то из множества выводов питания и земли МК по ошибке остались недодключенными. -На выводы МК подаются высокие лог. уровни до того, как появляется питание. -Проблема с питанием, например, оно слишком шумное, или стабилизатор питания возбуждается ... 1. Все выводы питания подключены 2. Выводы МК все отрезал от периферии. Прозвонил. Ничего не коротит ни на землю, ни на питание. 3. Питание не шумное, вполне себе нормальное. Кстати, строб подается через 2 секунды после подачи питания, т.е. ни каких пусковых всплесков.
--------------------
|
|
|
|
|
Mar 14 2013, 18:42
|
Местный
  
Группа: Участник
Сообщений: 313
Регистрация: 2-07-11
Пользователь №: 66 023

|
Вероятно ошибка в программе и аппаратные эффекты не при чём. Цитата(prottoss @ Mar 14 2013, 19:40)  1. Если питание подано в первый раз то после перехода строба из 0 в 1 вся периферия вешается! Т.е. оба USART не работают и еще часть периферии так же не работает. Программа может зависнуть. 2. Если сбросить процессор не снимая питания, то все работает как задумано. При сбросе процессора не снимая питания, ОЗУ не стирается. Если какая-нибудь переменная используется без инициализации, такое может быть. Но глабальные переменные всё обнуляются в статовом коде. А стек - не обнуляется. То есть скорее это может быть связано с стековой переменной, или с обращением по указателю совсем мимо.
|
|
|
|
|
Mar 15 2013, 10:50
|

Гуру
     
Группа: Свой
Сообщений: 2 076
Регистрация: 10-09-08
Пользователь №: 40 106

|
Цитата(prottoss @ Mar 15 2013, 13:17)  Состояние PORTD5 не анализируется, ибо это выход. А что, выход нельзя анализировать? Цитата(prottoss @ Mar 15 2013, 13:17)  До обработчкив программа не доходит. Почему? Прерывания запрещены? Цитата(prottoss @ Mar 15 2013, 13:17)  Объясняю еще раз. Оставлена только инициализация периферии и пустой цикл. Все. Нет никакой программы, ни каких переменных. Ничего. Если нет ничего то как Вы знаете что все либо работает либо не работает?
|
|
|
|
|
Mar 15 2013, 12:26
|

Гуру
     
Группа: Свой
Сообщений: 2 720
Регистрация: 24-03-05
Пользователь №: 3 659

|
Цитата(zombi @ Mar 15 2013, 16:50)  А что, выход нельзя анализировать? Можно но не нужно. Я его анализирую с помощью осциллографа. Цитата(zombi @ Mar 15 2013, 16:50)  Почему? Прерывания запрещены? Нет не запрещены. А какие должны возникать прерывания если программа еще не дошла до основного цикла? Цитата(zombi @ Mar 15 2013, 16:50)  Если нет ничего то как Вы знаете что все либо работает либо не работает? В основном цикле есть моргалка светодиодом. задержка пол-секунды, инвертирование состояния светодиода и т.д. Так вот я вижу, что если светодиод моргает, значит программа не висит. Если зависла, то светодиод не моргает. Кстати, анализировал программу в симуляторе AVRStudio - ни каких глюков не выявил.
--------------------
|
|
|
|
|
Mar 16 2013, 13:26
|

Гуру
     
Группа: Свой
Сообщений: 2 720
Регистрация: 24-03-05
Пользователь №: 3 659

|
С глюком разобрался. Прав был уважаемый zombi - моя ошибка в программе. Поясню. Оба USART работают на прерываниях. Так вот, согласно даташита ATXMEGA_AU прерывание по приему (RXC) будет возникать до тех пор, пока не будет прочитан DATA регистр. У меня в обработчике было сделано так, что этот регистр не читался, если была ошибка Frame Error, Buffer Overflow или Parity Error. Строб (скорее всего из-за разводки печатной платы) производит наводку на линии приемника USARTE0. Приемник принимает байт с ошибкой, но так как программа не читает DATA регистр, это прерывание возникает постоянно. Переделал программу. Сначала читаю DATA за тем проверяю ошибки. Нет ошибок, складываю данные в буфер, есть ошибка - выхожу из обработчика. Все стало работать как задумано. Вот такие пироги  Спасибо всем кто откликнулся.
--------------------
|
|
|
|
1 чел. читают эту тему (гостей: 1, скрытых пользователей: 0)
Пользователей: 0
|
|
|