Помощь - Поиск - Пользователи - Календарь
Полная версия этой страницы: прерывания в CrossStudio
Форум разработчиков электроники ELECTRONIX.ru > Микроконтроллеры (MCs) > ARM
TeO
Недавно начал осваивать CrossStuduo, пишу программку в нём под LPC2132 и что-то не могу понять, почему прерывания не работают, мож кто подскажет, что я мог упустить...



#include <targets\LPC213x.h>
#include <__armlib.h>

static void Tim0Match (void) __attribute__ ((interrupt ("IRQ")));
static void Tim0Match (void)
{
static int i;
IO0PIN = i;
i = ~i;
T0IR = 0xF;
VICVectAddr = 0;
}

void InitTimer0()
{


VICIntSelect &= ~(1<<4); /* Timer 0 interrupt is an IRQ interrupt */
VICVectCntl3 = (4)|(1<<5); //слот 3 на 4 канал (TIMER0)
VICVectAddr3 = (unsigned int)Tim0Match; //передаём слоту адрес обработчика
VICIntEnable = (1<<4); //разрешаем прерывания от 4 канала

T0CTCR = 0x0; //Тактирование от генератора
T0PR = 0x0; //Предделитель = 1
T0MR0 = 30000000-1; // Регистр совпадения
T0MCR = (1 << 0) | (1 << 1); //прерывание и сброс по совпадению с MR0
T0TCR = 0x3; //Сброс таймера
T0TCR = 0x1; //Запуск таймера

}

int main (void)
{
int i;
IO0DIR = (1<<15)|(1<<13)|(1<<12);
for (i=0;i<100000;i++);
IO0PIN = (1<<15)|(1<<13)|(1<<12);
InitTimer0();
__ARMLIB_enableIRQ();
while(1)
{
// Tim0Match();
// VICSoftInt = (1<<4);
}
}
asergey
Была та же проблема. Делаешь все правильно. Сам только что начал изучать вообще эти RISC. В стартуп коде есть строчки которые я подправил, развлетвление по сборке #ifdef VECTORED_IRQ_HANDLER.
(пишу на память могу обшибиться :-))
закоментируй это ветвление и оставь только первые - слово с контрольной суммой и загрузку в pc. Тупо конечно, но пока времени нет сочинять что то другое - проект горит :-) Добавление типа #define ..... почему то не помогло, надо ползать по Cross-у есть подозрение что этот деф нужно в переменные компилятора добавить.
У меня заработало. Если надо могу вырезку из файлов пропостить.
Для просмотра полной версии этой страницы, пожалуйста, пройдите по ссылке.
Invision Power Board © 2001-2025 Invision Power Services, Inc.