|
|
  |
Прерывания USART AVR32. |
|
|
|
Feb 16 2012, 10:35
|
Группа: Новичок
Сообщений: 2
Регистрация: 4-10-10
Пользователь №: 59 904

|
Здравствуйте!
Подскажите в чем может быть дело -
процессор AT32UC3A3256, прерывание по приему для одного (UART0) UART работает, для остальных нет. Чтение без прерываний работает, что подтверждает правильность настройки самого модуля.
Инициализация прерываний аналогична во всех случаях.
Что может быть причиной?
|
|
|
|
|
Feb 19 2012, 08:04
|
Участник

Группа: Участник
Сообщений: 19
Регистрация: 15-12-11
Пользователь №: 68 876

|
Доброго времени суток! Новую тему не стал заводить, название вроде подходит? кристал маленько другой  Объясните пожалуйста такую вещь: 1 случай: ldi temp , 0b00000011 ; активирую таймер с делением частоты на 64 out TCCR1B,temp ldi temp,(1<<TOIE1 ) ;активирую прерывание по переполнению! out TIMSK,temp обработчик прерывания: perepolnenie: in temp, PortB eor temp,r18 out PortB,temp reti В этом случае светодиод моргает с частотой 1 раз в скунду 2 случай: ldi temp , 0b00001101 ; запуск таймера T\C1 с делением !!! на 1024 !!! out TCCR1B,temp ; режим(CTC) сброс при совпадении ldi temp, 0xFF ;здесь записываю максимальное число out OCR1AL,temp ;по сути получается "прерывание по переполнению" ldi temp, 0xFF ; out OCR1AH,temp ; ldi temp,( 1<<OCIE1A) ; разрешение прерывание по сравнению out TIMSK,temp НО!!! в этом случае, не смотря на то что деление частоты большее, т.е. таймер должен работать медленней,а моргание происходит чаще! Как такое может быть? Работаю на отладочной плате STK500, на Atmega8515 полный код прилагаю.
|
|
|
|
|
Feb 19 2012, 09:05
|

Гуру
     
Группа: Модератор FTP
Сообщений: 4 479
Регистрация: 20-02-08
Из: Москва
Пользователь №: 35 237

|
Цитата(slavik.ksu @ Feb 19 2012, 12:04)  НО!!! в этом случае, не смотря на то что деление частоты большее, т.е. таймер должен работать медленней,а моргание происходит чаще! Как такое может быть? Может. Потому что при прерывании по переполнению счет ведется от заданного значения вверх до переполнения, а в режиме CTC - от нуля до заданного значения. И эти отрезки по длине разные! Представим себе ситуацию, что задано значение 10, а переполнение происходит после 255. При этом я считаю в 10 раз медленнее, чем вы. Но я считаю в режиме CNC от нуля до 10, а вы в режиме переполнения с 10 до 255. Кто из нас быстрее достигнет прерывания? - Я! Потому что мне надо перечислить только 10 чисел, а вам 245. И тут я со своей в десятеро медленной скоростью стравлюсь быстрее.
|
|
|
|
|
Feb 20 2012, 08:54
|
Участник

Группа: Участник
Сообщений: 19
Регистрация: 15-12-11
Пользователь №: 68 876

|
Цитата(Xenia @ Feb 19 2012, 13:05)  Может. Потому что при прерывании по переполнению счет ведется от заданного значения вверх до переполнения а это значение как задается? в каком регистре храниться?
|
|
|
|
|
Feb 20 2012, 18:03
|
Участник

Группа: Участник
Сообщений: 19
Регистрация: 15-12-11
Пользователь №: 68 876

|
Цитата(_Артём_ @ Feb 20 2012, 17:26)  При переполнении: TCNT1=<заданное значение> Чтобы после каждого прерывания счет шел с этого "заданного значения", его надо прописывать в конце обработчика? правильно я понимаю? А если его проинициализировать один раз, то счет после переполнения будет начинаться с нуля?
|
|
|
|
|
Feb 20 2012, 22:06
|

Гуру
     
Группа: Модератор FTP
Сообщений: 4 479
Регистрация: 20-02-08
Из: Москва
Пользователь №: 35 237

|
Цитата(slavik.ksu @ Feb 20 2012, 22:03)  Чтобы после каждого прерывания счет шел с этого "заданного значения", его надо прописывать в конце обработчика? правильно я понимаю? А если его проинициализировать один раз, то счет после переполнения будет начинаться с нуля? При прерывании по переполнению, TCNT1 приходится обновлять каждый раз в процедуре прерывания. Потому что TCNT1 это есть тот самый счетчик, число в котором насрастает со временем. Поэтому в процедуре прерывания там 0 (или чуть больше, т.к. сама процедура прерывания и сохранение значений рабочих регистов в ее начале тоже занимают время). А в прерываниях по совпадению (CTC) уровень в регистре OCR1 обновлять не надо, т.к. его значение при сравнениях не портится, оставаясь постоянным, а значение TCNT1 аппаратно сбрасывается на 0 в момент совпадения. Первый способ организации часов теоретически чуть менее точный, т.к. часы будут маленько отставать из-за того, что устанановить свежее значение TCNT1 точно в момент прерывания невозможно, поскольку между моментом переполнения счетчика и выполнением присваивания TCNT1 нового значения проходит какое число циклов, потребных для перехода в прерывание, сохранение значений рабочих регистов в ее начале и самой операции присваивания. Тогда как организации часов по совпадению (CTC) лишена этого недостатка, т.к. код, выполяемый в процедуре прерывания никак не участвует в ходе часов. Однако разница эта настолько мала, что ею спокойно можно пребречь.
|
|
|
|
|
Feb 21 2012, 11:04
|
Участник

Группа: Участник
Сообщений: 19
Регистрация: 15-12-11
Пользователь №: 68 876

|
Цитата(Xenia @ Feb 21 2012, 02:06)  При прерывании по переполнению, TCNT1 приходится обновлять каждый раз в процедуре прерывания. Потому что TCNT1 это есть тот самый счетчик, число в котором насрастает со временем. Поэтому в процедуре прерывания там 0 (или чуть больше, т.к. сама процедура прерывания и сохранение значений рабочих регистов в ее начале тоже занимают время). Спасибо, полностью разобрался!
|
|
|
|
|
  |
1 чел. читают эту тему (гостей: 1, скрытых пользователей: 0)
Пользователей: 0
|
|
|