Пытаюсь вычислить частоту 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.
Собственно, что я делаю не так? Каким образом набегают лишние такты?