|
Генерация временных интервалов., STM32F103RBT6 |
|
|
|
Nov 4 2013, 07:11
|
Профессионал
    
Группа: Участник
Сообщений: 1 778
Регистрация: 29-03-12
Пользователь №: 71 075

|
Я хочу на таймере TIM4 создать три временных события. CODE void Tim4Init(void) { NVIC_SetPriority(TIM4_IRQn, 1); NVIC_EnableIRQ(TIM4_IRQn); RCC->APB1ENR |= RCC_APB1ENR_TIM4EN; TIM4->PSC = 0x8CA0; //72Mhz/36000 = 2ms
//TIM4->ARR = 1000; //reload every 200ms TIM4->CCMR1 &= ~TIM_CCMR1_OC1M; //MODE 000 - capture/comp for time events TIM4->CCMR1 &= ~TIM_CCMR1_OC2M; TIM4->CCMR2 &= ~TIM_CCMR2_OC3M; TIM4->DIER |= (TIM_DIER_CC1IE | TIM_DIER_CC2IE| TIM_DIER_CC3IE); TIM4->CCR1 = 500; //1s TIM4->CCR2 = 1000; //2s TIM4->CCR3 = 1500; //3s TIM4->CR1 |= TIM_CR1_CEN; }
Проверяем CODE void TIM4_IRQHandler (void) { if(TIM4->SR & TIM_SR_CC1IF) { TIM4->SR &= ~TIM_SR_CC1IF; UsartSendString("CC1 Int\r"); } if(TIM4->SR & TIM_SR_CC2IF) { TIM4->SR &= ~TIM_SR_CC2IF; UsartSendString("CC2 Int\r"); } if(TIM4->SR & TIM_SR_CC3IF) { TIM4->SR &= ~TIM_SR_CC3IF; UsartSendString("CC3 Int\r"); } }
По идее каждую секунду я должен видеть capture/compare event. На самом деле таймер доходит до TIM4->ARR и только потом происходят интерапты. Как я понимаю таймер должен досчитать до TIM4->CCR1 - CCR3 регтстра и сгенерировать интерапт без всякой связи с TIM4->ARR.
|
|
|
|
|
Nov 4 2013, 08:56
|
Профессионал
    
Группа: Участник
Сообщений: 1 778
Регистрация: 29-03-12
Пользователь №: 71 075

|
Цитата(smk @ Nov 4 2013, 13:27)  В TIMx_DIER нужно разрешить прерывания по совпадению а это не оно? Код TIM4->DIER |= (TIM_DIER_CC1IE | TIM_DIER_CC2IE| TIM_DIER_CC3IE); Цитата(smk @ Nov 4 2013, 13:27)  и соответственно обработчики прописать. так прописан - void TIM4_IRQHandler (void)
|
|
|
|
|
Nov 4 2013, 11:17
|
Профессионал
    
Группа: Участник
Сообщений: 1 778
Регистрация: 29-03-12
Пользователь №: 71 075

|
Цитата(adnega @ Nov 4 2013, 14:22)  Нужно разрешить работу каналов в CCER. как я понял CCER нужен если хотим выдать сигнал наружу на соответствующую ножку. Цитата(smk @ Nov 4 2013, 14:36)  Если TIM4->CCR3 = 1500; //3s то и TIM4->ARR = должен быть более 1500
а так должно работать. Хотябы TIM4->CCR1 = 500; //1s
может дело в этом "If channel CC1 is configured as output:" Я вижу на терминале Код CC1 Int CC2 Int CC3 Int тут проходит время = TIM4->ARR CC1 Int CC2 Int CC3 Int и так далее ...... Но у меня capture/compare interrupt сравнивает значение таймера с кэпчэ\компэрэ регистром, почему вмешивается TIM4->ARR?
|
|
|
|
1 чел. читают эту тему (гостей: 1, скрытых пользователей: 0)
Пользователей: 0
|
|
|