Помощь - Поиск - Пользователи - Календарь
Полная версия этой страницы: Нет прерываний от DMA
Форум разработчиков электроники ELECTRONIX.ru > Микроконтроллеры (MCs) > ARM
777777
Импульсы таймера 8 запускают DAC, он с помощью DMA загружает число из памяти и формирует сигнал. Но по окончании цикла прерывание от DMA не приходит.

Чего здесь не хватает:
Код
void DACSetup(void)
    {
    RCC->AHBENR |= RCC_AHBENR_DMA2EN;                    // DMA clock enable
    RCC->APB2ENR |= RCC_APB2ENR_TIM8EN;                    // TIM8 Periph clock enable
    RCC->APB1ENR |= RCC_APB1ENR_DACEN;                    // DAC Periph clock enable

    // TIM8
    TIM8->PSC = 0;                                        // Prescaler = 0
    TIM8->ARR = 18;                                        // Auto reload value (18+1)*80/72 = 21.12 us
    TIM8->CR2 = TIM_CR2_MMS(2);                            // Select the TRGO source

    // DMA
    DMA2_Channel3->CCR = DMA_CCR_PL(3) |
                         DMA_CCR_MSIZE(1) |
                         DMA_CCR_PSIZE(1) |
                         DMA_CCR_MINC |
                         DMA_CCR_CIRC |
                         DMA_CCR_DIR |
                         DMA_CCR_HTIE |
                         DMA_CCR_TCIE;
    DMA2_Channel3->CNDTR = 80;
    DMA2_Channel3->CPAR = (u32)&DAC->DHR12R1;            // Peripheral address, page 45 of RM0008 manual
    DMA2_Channel3->CMAR = (u32)&Sine;                    // DMA 2 channel 4 memory address register
    NVIC->ISER[1]  = 1 << (DMA2_Channel3_IRQChannel & 0x1F); // DMA2 Channel 3 global Interrupt

    // DAC
    DAC->CR = DAC_CR_TSEL1(1)|DAC_CR_TEN1|DAC_CR_BOFF1;    // Trigger = Timer 8 TRGO

      // Enable everything
    DMA2_Channel3->CCR |= DMA_CCR_EN;                    // Enable DMA 2 channel 3
    DAC->CR |= DAC_CR_DMAEN1|DAC_CR_EN1;                 // Enable DAC Channel 1
    TIM8->CR1 |= TIM_CR1_CEN;                            // CEN: Counter enable bit
    }

Обработчик прерывания:
Код
DMAChannel3_IRQHandler()
    {
    DMA2->IFCR = DMA_IFCR_CTCIF3;
    {
    int volatile xx;
    GPIOA->ODR |= 0x04;
    for(xx=0; xx < 10; ++xx)
        __nop();
    GPIOA->ODR &= ~0x04;
    }
    }
-JonnS-
Цитата(777777 @ Sep 29 2011, 14:55) *
DMAChannel3_IRQHandler()

По моему опечатка:
DMA2Channel3_IRQHandler()
777777
Цитата(-JonnS- @ Sep 29 2011, 20:04) *
По моему опечатка:
DMA2Channel3_IRQHandler()

Нет, прерывания отличаются только Channel-ами. Разные DMA пользуются одинаковыми прерываниями.
-JonnS-
Цитата(777777 @ Sep 30 2011, 06:44) *
Разные DMA пользуются одинаковыми прерываниями.

Может что не догоняю но в "RM0008 REFERENCE MANUALS" (стр 193)
указано: DMA2 Channel3 global interrupt -> Position: 58, Адрес: 0x0000_0128
а скажем для DMA1 Channel3 global interrupt -> Position: 13, Адрес: 0x0000_0074
Ето разные прерывания.
777777
Цитата(-JonnS- @ Sep 29 2011, 20:04) *
По моему опечатка:
DMA2Channel3_IRQHandler()

Кажется вы где-то правы. В даташите действительно описаны отдельные прерывания для разных DMA, но в файле STM32F10x.s список прерываний заканчивается на USBWakeUp_IRQHandler. Я нашел другой стартап в CMSIS и все заработало. Какой-то кейл недоделанный, и не всю периферию показывает при отладке, и стартап не полный.
Для просмотра полной версии этой страницы, пожалуйста, пройдите по ссылке.
Invision Power Board © 2001-2025 Invision Power Services, Inc.