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

 
 
> Что-то не так делаю с таймером, Пытаюсь вычислить частоту 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
Ответов (1 - 3)
rezident
сообщение Jun 8 2010, 13:30
Сообщение #2


Гуру
******

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



Во-первых, следует использовать таймер в Continuous mode, а не в Up mode. Во-вторых, где у вас настройка источников тактирования и выбор коэффициентов деления SMCLK и ACLK? В-третьих, какую размерность у вас имеет переменная MCU_Freq? Она должна быть типа unsigned long. Именно беззнаковой и 32-х битной! Ну и не мешало бы при расчете ввести еще одну временную переменную, куда сохранять промежуточное значение TACCR2 перед вычислениями.
Go to the top of the page
 
+Quote Post
sterya
сообщение Jun 9 2010, 03:25
Сообщение #3





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



Цитата(rezident @ Jun 8 2010, 17:30) *
Во-первых, следует использовать таймер в Continuous mode, а не в Up mode. Во-вторых, где у вас настройка источников тактирования и выбор коэффициентов деления SMCLK и ACLK? В-третьих, какую размерность у вас имеет переменная MCU_Freq? Она должна быть типа unsigned long. Именно беззнаковой и 32-х битной! Ну и не мешало бы при расчете ввести еще одну временную переменную, куда сохранять промежуточное значение TACCR2 перед вычислениями.



Режим использую именно Continuous, просто вкралась ошибка именно в сообщение сюда на форум.
Далее, источники настраиваются так:
Код
// XT1 = 32.8 KHz
// XT2 = OFF
//
// DCO = 5000 KHz
// ACLK = XT1 = 32768 Hz
// MCLK = DCO = 5000 KHz
// SMCLK = DCO = 5000 KHz


Т.е. делители везде единички.
Переменная: unsigned long MCU_Freq;
Зачем вводить вторую переменную не понимаю. Компилятор прекрасно сам разберется с такой тривиальной конструкцией.

На самом деле, было бы интересно посмотреть как кто делает в своих проектах вычисление частоты DCO. Именно через таймер.
Go to the top of the page
 
+Quote Post
rezident
сообщение Jun 12 2010, 19:44
Сообщение #4


Гуру
******

Группа: Свой
Сообщений: 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 - 20:44
Рейтинг@Mail.ru


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