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

 
 
> Вычисление делителя для таймера.
Jenya7
сообщение Jan 23 2017, 15:48
Сообщение #1


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

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



Я хочу чтоб таймер посто тикал. Каждый тик 1 милисекунда. А я буду считывать каунтер (TIM7->CNT) и буду знать сколько милисекунд он нащелкал.
Вычисления такие. Частота кристала CPU = 72 мега. Делитель = 2 (иначе не влезем в размер прескейлер регистра). 1/72M = 13.8ns. 1ms/13.8ns/2 = 36231.
Следовательно
Код
TIM_TimeBaseInitTypeDef TIM_TimeBaseStructure;
TIM_TimeBaseStructure.TIM_Period = 0xFFFF;    
TIM_TimeBaseStructure.TIM_Prescaler = 36231;  
TIM_TimeBaseStructure.TIM_ClockDivision = TIM_CKD_DIV2;
TIM_TimeBaseStructure.TIM_CounterMode = TIM_CounterMode_Up;
TIM_TimeBaseInit(TIM7, &TIM_TimeBaseStructure);
TIM_Cmd(TIM7,ENABLE);

Правильно ли я вычисляю?

Сообщение отредактировал Jenya7 - Jan 23 2017, 16:22
Go to the top of the page
 
+Quote Post
 
Start new topic
Ответов
ViKo
сообщение Jan 25 2017, 11:06
Сообщение #2


Универсальный солдатик
******

Группа: Модераторы
Сообщений: 8 634
Регистрация: 1-11-05
Из: Минск
Пользователь №: 10 362



Уже писали, надо вычислять разность между текущим значением таймера и порогом, и сравнивать ее с нулем, тогда переполнения таймера не страшны.
Go to the top of the page
 
+Quote Post
Jenya7
сообщение Jan 25 2017, 11:19
Сообщение #3


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

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



Цитата(ViKo @ Jan 25 2017, 17:06) *
Уже писали, надо вычислять разность между текущим значением таймера и порогом, и сравнивать ее с нулем, тогда переполнения таймера не страшны.

а я проверял
Код
uint16_t var = 0Xfff0;
var += 0Xff;
printf("var is %x /n", var);

при переполнении происходит rollover.
Go to the top of the page
 
+Quote Post
ViKo
сообщение Jan 25 2017, 11:33
Сообщение #4


Универсальный солдатик
******

Группа: Модераторы
Сообщений: 8 634
Регистрация: 1-11-05
Из: Минск
Пользователь №: 10 362



Цитата(Jenya7 @ Jan 25 2017, 14:19) *
а я проверял
при переполнении происходит rollover.

Только ваша функция сравнения так не делает. Проверьте.
Go to the top of the page
 
+Quote Post
Jenya7
сообщение Jan 25 2017, 11:56
Сообщение #5


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

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



Цитата(ViKo @ Jan 25 2017, 17:33) *
Только ваша функция сравнения так не делает. Проверьте.

мда. понял. спасибо.

вобщем тут в чем проблема. переполнение можно отследить в while. как в этом примере.
Код
void delay_1us (void) {
  uint32_t start, end;
  
  start = DWT_CYCCNT;
  end = start + HCLK/1000000;
  if (end < start) while (dwt_cnt() > start);
  while (end >= dwt_cnt());
}


но если как у меня - в одном месте установили порог а в другом сравниваем - без дополнительных флагов не обойтись.

скажем такой подход не решает проблему переполнения
Код
uint32_t DWT_Get(void)
{
    return DWT_CYCCNT;
}

uint8_t DWT_Compare(int32_t tp)
{
    return (((int32_t)DWT_Get() - tp) < 0);
}

void DWT_Delay(uint32_t us) // microseconds
{
    int32_t tp = DWT_Get() + us * (SystemCoreClock/1000000));
    while (DWT_Compare(tp));
}


Сообщение отредактировал Jenya7 - Jan 25 2017, 15:12
Go to the top of the page
 
+Quote Post



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

 


RSS Текстовая версия Сейчас: 31st July 2025 - 12:50
Рейтинг@Mail.ru


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