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

 
 
> Что-то не так делаю с таймером, Пытаюсь вычислить частоту DCO
sterya
сообщение Jun 8 2010, 10:49
Сообщение #1





Группа: Новичок
Сообщений: 2
Регистрация: 27-12-04
Пользователь №: 1 694



Пытаюсь вычислить частоту DCO с помощью таймера и часового кварца.
Делаю так:

Код
  TACCTL0 = OUTMOD_0;
  TACTL = TASSEL_2 + TACLR;          // SMCLK, cont-mode, clear
  TACCR0 = 0xFFFF;
  TACCR1 = 0xFFFF;
  TACCR2 = 0xFFFF;
  // Используем режим захвата (CAP)
  // Сигнал CCI2B - CCR2 == ACLK (для MSP430F1232)
  TACCTL2 = CM_1 + CCIS_1 + CAP;            // CAP, ACLK

  MCU_Freq = 0;
  TACTL |= MC_1; // Старт

  while (!(CCIFG & TACCTL2));             // Wait until capture occured
  TACCTL2 &= ~CCIFG;                       // Capture occured, clear flag
  MCU_Freq = TACCR2;
  
  while (!(CCIFG & TACCTL2));             // Wait until capture occured
  TACCTL2 &= ~CCIFG;                       // Capture occured, clear flag
  
  MCU_Freq = TACCR2-MCU_Freq;
  MCU_Freq *= 32768;


Т.е. тактирую таймер от DCO. Настраиваю режим захвата по ACLK, который работает от часового кварца.

Первый проход таймера считаю сбойным, т.к. могли начать где-нибудь в середине такта кварца, а второй считаю рабочим.

DCO реально работает на частоте порядка 5МГц. Т.е. за один такт часового кварца должно проходить примерно 150 тактов DCO.

Реально я вижу, что набегают сильно разные значения. Причем, все они больше чем надо: от 200 до 250.

Собственно, что я делаю не так? Каким образом набегают лишние такты?
Go to the top of the page
 
+Quote Post
 
Start new topic
Ответов
rezident
сообщение Jun 12 2010, 19:44
Сообщение #2


Гуру
******

Группа: Свой
Сообщений: 10 920
Регистрация: 5-04-05
Пользователь №: 3 882



Уважаемый, sterya. Телепатия конечно же является обязательным свойством всех постоянных пользователей данного форума. Но вот беда, пользоваться этим свойством умеют немногие. laughing.gif Если вы хотите получить какой-то реальный результат от общения здесь, то не рассчитывайте сильно на эту телепатию.
Я лично частоту DCO не вычисляю. Калибровку.подстройку DCO по часовому кварцу - да, делал. Но принцип использовал тот же самый, который и вы реализуете. Он описан в slaa074. Все дело в мелочах этой реализации, до которых вы почему-то не опускаетесь. Приведите весь свой код, относящийся к вычислению частоты DCO, а не куски "ошибочного" кода и какие-то ненужные комментарии.
Go to the top of the page
 
+Quote Post



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

 


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


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