Помощь - Поиск - Пользователи - Календарь
Полная версия этой страницы: Прерывание IAR
Форум разработчиков электроники ELECTRONIX.ru > Сайт и форум > В помощь начинающему > ARM, 32bit
DigitalM
Прерывание отрабатывает только один раз. Потом молчит.
Вот код:

Код
__ramfunc  void ISR_TC0(void)
{
  LED_Set(2);
  WT=0;
}


Вектор настраивается так:
Код
*(volatile unsigned int*)0xFFFFF0B0=(unsigned int)&ISR_TC0;

Чего здесь не хватает?
Сергей Борщ
Цитата(DigitalM @ Feb 24 2010, 10:43) *
Чего здесь не хватает?
Не хватает кода обработчика исключения IRQ. По нему можно судить, какие действия выполняет он, а какие возложены на обработчик прерывания. Вот, возможные варианты обработчика исключения описаны здесь (правда для AT91SAM7, но идея абсолютно та же, только другие имена регистров).
DigitalM
Ошибочка получается:
(void (*)(void))(AT91C_BASE_AIC->AT91C_AIC_IVR)();
Error[Pe109]: expression must have (pointer-to-) function type

А как асм код вставить?
Сергей Борщ
Цитата(DigitalM @ Feb 27 2010, 23:02) *
Ошибочка получается:
(void (*)(void))(AT91C_BASE_AIC->AT91C_AIC_IVR)();
Error[Pe109]: expression must have (pointer-to-) function type
Тупое копирование редко дает рабочий результат. Я ведь предупредил - там код для совершенно другого процессора, с другим контроллером прерываний и другими именами регистров.

Ссылку давал, чтобы показать, что обработка прерывания состоит из двух этапов - из обработчика исключения IRQ и обработчика конкретного прерывания. Вы показали только обработчик прерывания, но не показали обработчик исключения, поэтому ничего конкретного посоветовать вам никто не сможет - телепатические способности участников этого форума далеки от совершенства.
Цитата(DigitalM @ Feb 27 2010, 23:02) *
А как асм код вставить?
Куда вставить? Читайте выше про телепатов, формулируйте вопрос развернуто, пожалуйста.
DigitalM
Код
#pragma vector = 0x0000018
__irq __arm void IRQ_Switch() {
  unsigned int* IR;
  unsigned int Vec;
  IR=(void(*))0xFFFFF100;
  Vec=*IR;
  (*(void(*)(void))(Vec))();
}

__irq __arm void ISR_TC0()
{
  LED_Set(2);
WT=0;
*(volatile unsigned int*)0xFFFFF130=0x00000000; //AT91C_BASE_AIC->AIC_EOICR = 0;
}


IAR. Отрабатывает только один раз. AT91SAM7S256
sergeeff
Вы же помещаете адрес функции ISR_TC0() в контроллер прерывания. Он вам этот адрес возвращает при чтении регистра 0xFFFFF100. Посему функция ISR_TC0() должна быть объявлена просто как void ISR_TC0().
DpInRock
Если в старапе поставить на 18 векторе команду LDR PC, [PC, #-0x0120]
то тогда самый первый исходный вариант будет работать, если добавить в обработчик команду конца прерываний вика. Ну и оформлять ее как __irq.
DigitalM
Проблема была в другом. Надо было по прерыванию считать статус таймера, чтоб снять флаг его личного прерывания.
Ой, а вычислите код этой команды: LDR PC, [PC, #-0x0120]. Ведь его просто можно по адресу 0х18 зиписать и все.
Сергей Борщ
Цитата(DigitalM @ Mar 1 2010, 21:36) *
Ой, а вычислите код этой команды: LDR PC, [PC, #-0x0120]. Ведь его просто можно по адресу 0х18 зиписать и все.
А почему бы тогда не вычислить коды всех остальных команд? И компилятор не нужен будет, и ассемблер с линкером...
Для просмотра полной версии этой страницы, пожалуйста, пройдите по ссылке.
Invision Power Board © 2001-2025 Invision Power Services, Inc.