STM32 горячая инициализация 1 таймер? - PullRequest
0 голосов
/ 15 октября 2018

Как мне выбрать правильное значение прескалера / периода, чтобы получить счет 1us?

Я работаю с платой Dicovery STM32F4 и мне нужно создать счетчик 1us и не знаю, как я могу это сделатьуменьшить шаги.

Я использую TIM10.Большое спасибо за помощь!

10us считает работы:

void 10_microSek_timer_Init() {
    GPIO_InitTypeDef GPIO_InitStructure;
    TIM_TimeBaseInitTypeDef TIM_TimeBaseInitStructure;
    TIM_OCInitTypeDef TIM_OCInitStructure;

    RCC_AHB1PeriphClockCmd(RCC_AHB1Periph_GPIOB, ENABLE);

    GPIO_InitStructure.GPIO_Pin = GPIO_Pin_8;
    GPIO_InitStructure.GPIO_OType = GPIO_OType_PP;
    GPIO_InitStructure.GPIO_Mode = GPIO_Mode_AF;
    GPIO_InitStructure.GPIO_PuPd = GPIO_PuPd_NOPULL;
    GPIO_InitStructure.GPIO_Speed = GPIO_Speed_100MHz;
    GPIO_Init(GPIOB, &GPIO_InitStructure);
    GPIO_PinAFConfig(GPIOB, GPIO_PinSource8, GPIO_AF_TIM10); // PB8 -> TIM10 Channel 1

    // TIM10 Clock enable
    RCC_APB2PeriphClockCmd(RCC_APB2Periph_TIM10, ENABLE);

    // Timer 10 Config PWM

    TIM_TimeBaseInitStructure.TIM_Period = 10- 1; //Change Orig 1 Sek: 10000-1; 1ms: 10-1; 10ms: 100-1; 100ms: 1000-1
    TIM_TimeBaseInitStructure.TIM_Prescaler = 168-1; //Change Orig 1 Sek: 16800-1
    TIM_TimeBaseInitStructure.TIM_ClockDivision = TIM_CKD_DIV1;
    TIM_TimeBaseInitStructure.TIM_CounterMode = TIM_CounterMode_Up;
    TIM_TimeBaseInit(TIM10, &TIM_TimeBaseInitStructure);

    TIM_OCStructInit(&TIM_OCInitStructure);
    TIM_OCInitStructure.TIM_OCMode = TIM_OCMode_PWM1;
    TIM_OCInitStructure.TIM_OutputState = TIM_OutputState_Enable;
    TIM_OCInitStructure.TIM_Pulse = 0;
    TIM_OCInitStructure.TIM_OCPolarity = TIM_OCPolarity_Low;
    TIM_OC1Init(TIM10, &TIM_OCInitStructure);

    TIM_OC1PreloadConfig(TIM10, TIM_OCPreload_Enable);
    TIM_ARRPreloadConfig(TIM10, ENABLE);
    TIM_Cmd(TIM10, ENABLE);
    TIM_CtrlPWMOutputs(TIM10, ENABLE);

    TIM10->CCR1 = 5;

}

Ответы [ 3 ]

0 голосов
/ 18 октября 2018

Существует три регистра: PSC, CCR и ARR.Частота ШИМ рассчитывается следующим образом:

PWM_freq = APBx_freq / (PSC + 1) (ARR + 1)

Рабочий цикл = CCR / ARR

Предполагается, что APBx_freq =168 МГц с настройкой PSC = 0 и ARR = 167 дает ШИМ с периодом 1 мкс и максимально возможным разрешением рабочего цикла, т. Е. 1/167 = 0,59%.Увеличение ARR уменьшает частоту, но увеличивает разрешение рабочего цикла.Это соотношение, к сожалению, нелинейное.

0 голосов
/ 18 октября 2018

Ошибка была в том, что мне не нужен ШИМ-сигнал, мне нужен таймер на 1 час (TIM10-> CNT).ШИМ-сигнал использовался для отладки частоты.Правильные варианты:

TIM_TimeBaseInitStructure.TIM_Period = 0xFFFF;
TIM_TimeBaseInitStructure.TIM_Prescaler = 84-1;
TIM10->CCR1 = 1<<15;
0 голосов
/ 17 октября 2018
TIM_TimeBaseInitStructure.TIM_Period = 1;
TIM_TimeBaseInitStructure.TIM_Prescaler = 84-1;

должно работать

...