реклама на сайте
подробности

 
 
> Генерация ШИМ, STM32 и TIM1/TIM8
Jenya7
сообщение Dec 23 2013, 06:48
Сообщение #1


Профессионал
*****

Группа: Участник
Сообщений: 1 778
Регистрация: 29-03-12
Пользователь №: 71 075



Настроить TIM2-TIM5 на генерацию ШИМ довольно просто
CODE
void PwmInit(void)
{
//ch1 -PA0
GPIOA->CRL |= GPIO_CRL_MODE0; //50Mhz
GPIOA->CRL &= ~GPIO_CRL_CNF0; //clear CNF[1:0] for PA0
GPIOA->CRL |= GPIO_CRL_CNF0_1; //output Push-Pull in alternative function mode
//ch2 - PA1
GPIOA->CRL |= GPIO_CRL_MODE1; //50Mhz
GPIOA->CRL &= ~GPIO_CRL_CNF1; //clear CNF[1:0] for PA1
GPIOA->CRL |= GPIO_CRL_CNF1_1; //output Push-Pull in alternative function mode
//ch3 - PA2
GPIOA->CRL |= GPIO_CRL_MODE2; //50Mhz
GPIOA->CRL &= ~GPIO_CRL_CNF2; //clear CNF[1:0] for PA2
GPIOA->CRL |= GPIO_CRL_CNF2_1; //output Push-Pull in alternative function mode
//ch4 - PA3
GPIOA->CRL |= GPIO_CRL_MODE3; //50Mhz
GPIOA->CRL &= ~GPIO_CRL_CNF3; //clear CNF[1:0] for PA3
GPIOA->CRL |= GPIO_CRL_CNF3_1; //output Push-Pull in alternative function mode
//TIM2 Settings
RCC->APB1ENR |= RCC_APB1ENR_TIM2EN;
TIM2->CR1 |= TIM_CR1_ARPE; //autorelode mode
TIM2->CCMR1 |= TIM_CCMR1_OC1PE | TIM_CCMR1_OC2PE; //Output Compare Preload enable
TIM2->CCMR2 |= TIM_CCMR2_OC3PE | TIM_CCMR2_OC4PE;
//TIM2->PSC = 71; //1us
TIM2->ARR = 8000; // 8000*14ns = 112us = 8928Hz
TIM2->CCR1 = 4000; //ch1 1duty cycle = 50%
TIM2->CCR2 = 4000; //ch2 1duty cycle = 50%
TIM2->CCR3 = 4000; //ch2 1duty cycle = 50%
TIM2->CCR4 = 4000; //ch2 1duty cycle = 50%
//TIM2->CCER |= TIM_CCER_CC2P; //polarity of output signal
//Capture/Compare 2 output enable
TIM2->CCER |= TIM_CCER_CC1E | TIM_CCER_CC2E | TIM_CCER_CC3E | TIM_CCER_CC4E;
//Output Compare Mode - 110 - PWM mode 1
TIM2->CCMR1 |= (TIM_CCMR1_OC1M_2 | TIM_CCMR1_OC1M_1);
TIM2->CCMR1 |= (TIM_CCMR1_OC2M_2 | TIM_CCMR1_OC2M_1);
TIM2->CCMR2 |= (TIM_CCMR2_OC3M_2 | TIM_CCMR2_OC3M_1);
TIM2->CCMR2 |= (TIM_CCMR2_OC4M_2 | TIM_CCMR2_OC4M_1);
//start counting
TIM2->CR1 |= TIM_CR1_CEN;
}

Все просто все понятно.
С TIM1/TIM8 не все так понятно - там другие регистры и я, честно говоря, запутался.
Может кто нибудь работал с этими таймерами и может прояснить ситуацию? Заранее спасибо.
Go to the top of the page
 
+Quote Post
 
Start new topic
Ответов
smk
сообщение Dec 23 2013, 07:26
Сообщение #2


Гуру
******

Группа: Свой
Сообщений: 2 246
Регистрация: 17-03-05
Из: Украина, Киев
Пользователь №: 3 446



Настраивается все... что именно нужно объяснить?


--------------------
Живи днем так, чтобы ночью ты спал спокойно.
Go to the top of the page
 
+Quote Post
Jenya7
сообщение Dec 23 2013, 07:58
Сообщение #3


Профессионал
*****

Группа: Участник
Сообщений: 1 778
Регистрация: 29-03-12
Пользователь №: 71 075



Цитата(smk @ Dec 23 2013, 13:26) *
Настраивается все... что именно нужно объяснить?

желательно пример. только не на стандартной библиотеке.
Go to the top of the page
 
+Quote Post
SSerge
сообщение Dec 23 2013, 08:33
Сообщение #4


Профессионал
*****

Группа: Свой
Сообщений: 1 719
Регистрация: 13-09-05
Из: Novosibirsk
Пользователь №: 8 528



Цитата(Jenya7 @ Dec 23 2013, 14:58) *
желательно пример. только не на стандартной библиотеке.

Регистры TIM2 это просто подмножество регистров TIM1.
У Вас не хватает этой строчки:
TIM1->BDTR |= TIM_BDTR_MOE;
вот прямо из текущего прожекта,
если не нужен DMA, часть текста после //DMA Init можно выбросить, .
CODE
void InitTIM1(int enable)
{
TIM1->CR1 = TIM_CR1_ARPE | TIM_CounterMode_Up;
TIM1->ARR = 5*24-1; // период повторения, 0 - останов
TIM1->PSC = 0; // прескалер на 1, один тик = 1/24 мкс
TIM1->RCR = 0; //TIM_RepetitionCounter;

// OC1
TIM1->CCR1 = 12; // 0.5мкс.
TIM1->CCMR1 = TIM_OCMode_Toggle; //TIM_OCMode_PWM2;
TIM1->CCER = TIM_OCPolarity_High | TIM_OutputState_Enable;
// OC2
TIM1->CCR2 = 24; // 1.0us
TIM1->CCMR1 |= TIM_OCMode_Toggle << 8;
TIM1->CCER |= (TIM_OCPolarity_High | TIM_OutputState_Enable) <<4;
// OC 3
TIM1->CCR3 = 36; // 1.5us.
TIM1->CCMR2 |= TIM_OCMode_PWM1;
TIM1->CCER |= ( TIM_OCPolarity_High | TIM_OutputState_Enable
| TIM_OCNPolarity_Low | TIM_OutputNState_Enable)<<8;
// OC4
TIM1->CCR4 = 24; // 1us
TIM1->CCMR2 |= TIM_OCMode_PWM1 << 8;
TIM1->CCER |= (TIM_OCPolarity_High | TIM_OutputState_Enable) <<12;

TIM1->EGR = TIM_EGR_UG; // генерируем update event для загрузки всех теневых регистров
TIM1->BDTR |= TIM_BDTR_MOE + 12; // разрешение выходных сигналов OCx + dead-time 0.5us

// DMA Init
TIM1->DIER = TIM_DIER_UDE;
TIM1->DCR = (0<<8) | (&(TIM1->ARR) - &(TIM1->CR1))/sizeof(TIM1->CR1);
DMA1_Channel5->CCR = 0
| 0*DMA_CCR1_EN // Channel enable
| 0*DMA_CCR1_TCIE // Transfer complete interrupt enable
| DMA_CCR1_DIR // Data transfer direction 1: Mem --> Periph
| DMA_CCR1_CIRC // Circular mode
| 0*DMA_CCR1_PINC // Peripheral increment mode
| DMA_CCR1_MINC // Memory increment mode
| DMA_PeripheralDataSize_Word // DMA_CCR1_PSIZE PSIZE[1:0] bits (Peripheral size)
| DMA_MemoryDataSize_HalfWord // DMA_CCR1_MSIZE MSIZE[1:0] bits (Memory size)
| (3<<12) //*DMA_CCR1_PL // PL[1:0] bits(Channel Priority level)
| 0*DMA_CCR1_MEM2MEM; // Memory to memory mode

DMA1_Channel5->CNDTR = 2;
DMA1_Channel5->CPAR = (uint32_t)&(TIM1->DMAR);
DMA1_Channel5->CMAR = (uint32_t) dmabuf;
DMA1_Channel5->CCR |= DMA_CCR1_EN; // Channel enable
// end DMA Init

if(enable) TIM1->CR1 |= TIM_CR1_CEN; // разрешаем счёт
}


--------------------
Russia est omnis divisa in partes octo.
Go to the top of the page
 
+Quote Post

Сообщений в этой теме
- Jenya7   Генерация ШИМ   Dec 23 2013, 06:48
- - smk   Кодvoid Timer1_Init (void) { RCC->APB...   Dec 23 2013, 08:24
- - Jenya7   спасибо большое. сейчас проверю.   Dec 23 2013, 08:46
- - Jenya7   спасибо все классно работает.   Dec 23 2013, 19:27
|- - smk   Цитата(Jenya7 @ Dec 23 2013, 21:27) спаси...   Dec 24 2013, 07:54
|- - Jenya7   Цитата(smk @ Dec 24 2013, 12:54) Рад за В...   Dec 24 2013, 16:09
|- - bzx   Цитата(Jenya7 @ Dec 24 2013, 20:09) ...за...   Dec 24 2013, 23:15
|- - Jenya7   Цитата(bzx @ Dec 25 2013, 05:15) Ерундой ...   Dec 25 2013, 07:00
|- - smk   Цитата(Jenya7 @ Dec 25 2013, 09:00) а есл...   Dec 25 2013, 07:52
|- - Jenya7   Цитата(smk @ Dec 25 2013, 13:52) Так диод...   Dec 25 2013, 08:04
|- - smk   Цитата(Jenya7 @ Dec 25 2013, 10:04) то ес...   Dec 25 2013, 08:23
- - Vendict   Делаю на stm32 (именно на STM32F103C8) кассу для с...   Sep 1 2014, 09:01
- - Golikov A.   RCC_APB1PeriphClockCmd(RCC_APB2Periph_TIM1, ENABLE...   Sep 1 2014, 09:50
- - Vendict   Цитата(Golikov A. @ Sep 1 2014, 13:50) RC...   Sep 1 2014, 10:11
- - Golikov A.   там надо по всем функциям пройтись особенно где вы...   Sep 1 2014, 10:18
- - Vendict   Цитата(Golikov A. @ Sep 1 2014, 14:18) ос...   Sep 1 2014, 10:31
- - Vendict   Вот мои ошибки: Цитата(Vendict @ Sep 1 2014,...   Sep 1 2014, 20:49


Reply to this topicStart new topic
1 чел. читают эту тему (гостей: 1, скрытых пользователей: 0)
Пользователей: 0

 


RSS Текстовая версия Сейчас: 20th July 2025 - 01:34
Рейтинг@Mail.ru


Страница сгенерированна за 0.0139 секунд с 7
ELECTRONIX ©2004-2016