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

 
 
 
Reply to this topicStart new topic
> Проблема в обработке GPIO прерываний.
koss
сообщение Sep 5 2008, 10:26
Сообщение #1





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



Есть следующая проблема:
В обработчике прерываний от PIOE в самом начале считываю статусный регистр PIOE_ISR, и иногда получаю ноль, хотя прерывание вызывается. При этом больше нигде этот регистр не читаю, поэтому резетиться он не должен. Ноль получается достаточно случайно. Тестирую подачей квадратурного сигнала с периодом ~100мкс, иногда получаются редкие пропуски по 2-3 раза из 20 фронтов в разных местах, независимо от того спад это или нарастание, иногда подряд 10-15 раз.

Код прост:
_INTERRUPT void vKeyboard_IT_Handler(void)
{
int tmp;
unsigned long u4Temp_ISR;

// Здесь читаю этот регистр
u4Temp_ISR = *AbsPIOE_ISR;

if(u4Temp_ISR == 0)
{
// u4Temp_ISR = 1; // так все работает
}

// Определяю какая из ног дернула (0 или 2)
u4Temp_ISR &= 0x05;

// Determine interrupt source
if(u4Temp_ISR & 0x01)
{
// для тестирования осцилом зажигаю седьмой пин, когда все ОК
*AbsPIOE_SODR = 0x80;
// просто задержка ~10мкс
for(tmp = 50; tmp > 0; tmp--);
}

*AbsPIOE_CODR = 0x80;
}

Проц не совсем обычный, секьюрный Atmel SO101.
Может ли что-то портить JTAG Emulator?

Буду благодарен за любую помощь...
Go to the top of the page
 
+Quote Post
Сергей Борщ
сообщение Sep 5 2008, 11:36
Сообщение #2


Гуру
******

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



Цитата(koss @ Sep 5 2008, 13:26) *
Может ли что-то портить JTAG Emulator?
Если у вас открыто окно, в котором просматривается содержимое PIOE_ISR, то может. Раз чтение сбрасывает флаги в этом регистре, то неважно, как это чтение происходит - ядром или автоматом JTAG.


--------------------
На любой вопрос даю любой ответ
"Write code that is guaranteed to work, not code that doesn’t seem to break" (C++ FAQ)
Go to the top of the page
 
+Quote Post
BSVi
сообщение Sep 5 2008, 12:08
Сообщение #3


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

Группа: Свой
Сообщений: 76
Регистрация: 18-12-07
Из: Киев
Пользователь №: 33 391



А квадратурный сигнал не с энкодера? Может контакты там звенят?


--------------------
http://bsvi.ru/ - блог эмбеддера
Go to the top of the page
 
+Quote Post
koss
сообщение Sep 5 2008, 13:58
Сообщение #4





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



Все, эмулятор не виноват, - без него та же ерунда.
Источником должна быть PS/2 клава, но сейчас, для тестирования, квадратурный сигнал генерю другим выходом в фоне и перемычкой кидаю на ногу с прерыванием.
По виду сигналы, когда распознается источник не отличаются от тех, когда не распознается. Спад, либо нарастание - ~15 наносекунд, дребезга не видно.
Go to the top of the page
 
+Quote Post
koss
сообщение Sep 5 2008, 15:51
Сообщение #5





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



Всем спасибо, проблему решил.
Виноватым оказался внутренний генератор, который пытались запустить на 50МГц, при использовании внешнего кварца на 24МГц все работает.
Go to the top of the page
 
+Quote Post

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

 


RSS Текстовая версия Сейчас: 24th June 2025 - 11:04
Рейтинг@Mail.ru


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