Хочу что бы прерывание происходило по концу передачи буфера через SPI. А оно происходит непрерывно, начиниет происходить сразу же после разрешения прерывания. Почему так ? И почему в KEIL uvison3 V3.60 в закладке Peripherals нет SPI ?
Спасибо !
__irq void SPI_interrupt(void) { int x; x= AT91C_BASE_SPI->SPI_SR; x= AT91C_BASE_SPI->SPI_RDR; x= AT91C_BASE_SPI->SPI_IMR; //читаю регистры что бы сбросить флаг прерывания *AT91C_AIC_EOICR = 0; //выход из прерывания }
void SET_SPI(void) { ***************
AT91C_BASE_AIC->AIC_SMR[AT91C_ID_SPI]|=(6<<0); AT91C_BASE_AIC->AIC_SVR[AT91C_ID_SPI]=(unsigned long)SPI_interrupt; AT91C_BASE_AIC->AIC_IECR=(1<<AT91C_ID_SPI); AT91C_BASE_SPI->SPI_IER|=AT91C_SPI_ENDTX; }
--------------------
Если у Вас нет практического опыта в данной теме- не вступайте в дискуссию и не пишите никаких теоретических рассуждений! Заранее спасибо !
|