Перейти к содержанию

PIC18F25K22. Настройка прерываний таймера


Auratos

Рекомендуемые сообщения

Добрый день. У меня контроллер PIC18F25K22. Пытался завести таймер TMR0 с частотой прерываний 1мс. Но на деле получаю 1,31мс. И не пойму, почему так. Настройки таймера рассчитал вручную, а затем с помощью программы PIC Timer Calculator. Данные сошлись, но по факту частота не та. У меня внешний тактовый генератор 4,9152МГц с включенной PLL. От этого и отталкивался. Считал, что на CLKOUT имею 4915200Гц. Значит в 16-битном режиме для 1мс мне понадобится 4916 приращений таймера. Сделал предзагрузку 0xECCC. И получил не то, что хотел.

Вот такие у меня настройки источника тактирования:

#pragma config WDTEN = SWON        // сторожевой таймер
#pragma config WDTPS = 512        // скорость работы сторожевого таймера
#pragma config FOSC = HSMP        // частота тактового генератора
#pragma config PLLCFG = ON
#pragma config PRICLKEN = ON
#pragma config FCMEN = OFF
#pragma config IESO = OFF
#pragma config PWRTEN = ON
//#pragma config BORV = 285
#pragma config BOREN = OFF
#pragma config PBADEN = OFF
#pragma config XINST = OFF

И вот настройки таймера:

// обработка прерывания таймера TMR0
void tmr0_int(void)
{
    INTCONbits.TMR0IF = 0;	// сброс переполнения таймера

    T0CONbits.TMR0ON = 0;
    TMR0L = 0xСС;
    TMR0H = 0xEC;
    T0CONbits.TMR0ON = 1;
    LED_SW;
}

// инициализация таймера TMR0
void tmr0_init(void)
{
    T0CONbits.T08BIT = 0;   // 16-ти разрядный таймер
    T0CONbits.T0CS = 0;     // тактирование от осцилятора 4*Fosc/4
    T0CONbits.T0SE = 0;     // приращение по переднему фронту импульса
    T0CONbits.PSA = 1;      // предделитель не используется
    T0CONbits.T0PS = 0;     // коэф. предделителя не используется
    TMR0L = 0xСС;	// регистр таймера в ноль
    TMR0H = 0xEC;
    INTCON2bits.TMR0IP = 1; // приоритет прерывания TMR0 - высокий
    INTCONbits.TMR0IE = 1;	// разрешить прерывание по переполнению TMR0
    T0CONbits.TMR0ON = 1;
}

Частоту смотрю на осциллографе по светодиоду, состояние которого меняю каждое прерывание. Схема подключения внешнего тактового генератора на фотографии. Подскажите, пожалуйста, в чем может быть загвоздка? В Fosc выбрал не тот режим? Завел еще таймер TMR1. В регистре T1CONbits в бите TMR1CS  ставил и 00 и 01. После соответствующего пересчета получал все то же значение частоты. 

TMRxCS<1:0>: Timer1/3/5 Clock Source Select bits
 11 =Reserved. Do not use.
 10 =Timer1/3/5 clock source is pin or oscillator:
    If TxSOSCEN = 0:
    External clock from TxCKI pin (on the rising edge)
    If TxSOSCEN = 1:
    Crystal oscillator on SOSCI/SOSCO pins
 01 =Timer1/3/5 clock source is system clock (FOSC)
 00 =Timer1/3/5 clock source is instruction clock (FOSC/4)

Еще подскажите, пожалуйста, как начать тактироваться от внутреннего тактового генератора. Где это настраивается? В регистре OSCCON?

o3HjHrTjL_w.jpg

Ссылка на комментарий
Поделиться на другие сайты

Реклама: ООО ТД Промэлектроника, ИНН: 6659197470, Тел: 8 (800) 1000-321

13 часа назад, Auratos сказал:

Сделал предзагрузку 0xECCC. И получил не то, что хотел.

Делать точные периодические вызовы на этих таймерах - мазохизм. Посмотрите в сторону TIMER2/4/6 Они для этого как раз и предназначены.

13 часа назад, Auratos сказал:

как начать тактироваться от внутреннего тактового генератора. Где это настраивается? В регистре OSCCON?

Раздел "OSCILLATOR MODULE" даташита. Всё расписано по полочкам, даже с рисуночками...

Ссылка на комментарий
Поделиться на другие сайты

20% скидка на весь каталог электронных компонентов в ТМ Электроникс!

Акция "Лето ближе - цены ниже", успей сделать выгодные покупки!

Плюс весь апрель действует скидка 10% по промокоду APREL24 + 15% кэшбэк и бесплатная доставка!

Перейти на страницу акции

Реклама: ООО ТМ ЭЛЕКТРОНИКС, ИНН: 7806548420, info@tmelectronics.ru, +7(812)4094849

15 часов назад, Auratos сказал:

 


// обработка прерывания таймера TMR0
void tmr0_int(void)
{
    INTCONbits.TMR0IF = 0;	// сброс переполнения таймера

    T0CONbits.TMR0ON = 0;
    TMR0L = 0xСС;
    TMR0H = 0xEC;
    T0CONbits.TMR0ON = 1;
    LED_SW;
}

какое отношение эта функция имеет к прерыванию?

Ссылка на комментарий
Поделиться на другие сайты

Особенности хранения литиевых аккумуляторов и батареек

Потеря емкости аккумулятора напрямую зависит от условий хранения и эксплуатации. При неправильном хранении даже самый лучший литиевый источник тока с превосходными характеристиками может не оправдать ожиданий. Технология, основанная на рекомендациях таких известных производителей литиевых источников тока, как компании FANSO и EVE Energy, поможет организовать правильный процесс хранения батареек и аккумуляторов. Подробнее>>

Реклама: АО КОМПЭЛ, ИНН: 7713005406, ОГРН: 1027700032161

5 часов назад, IMXO сказал:

какое отношение эта функция имеет к прерыванию?

Я просто не указал место, где вызывается эта функция )

#pragma code high_vector=0x08
void interrupt_at_high_vector(void)  // с высоким приоритетом
{
_asm GOTO high_isr _endasm
}
#pragma code

#pragma interrupt high_isr
// обработчик векторов прерываний высокого приоритета
void high_isr (void)
{
    if(INTCONbits.TMR0IF & INTCONbits.TMR0IE) tmr0_int();   // прерывание по таймеру
    if(PIR1bits.TMR1IF) tmr1_int();   // прерывание по таймеру
}

 

Ссылка на комментарий
Поделиться на другие сайты

Выбираем схему BMS для корректной работы литий-железофосфатных (LiFePO4) аккумуляторов

 Обязательным условием долгой и стабильной работы Li-FePO4-аккумуляторов, в том числе и производства EVE Energy, является применение специализированных BMS-микросхем. Литий-железофосфатные АКБ отличаются такими характеристиками, как высокая многократность циклов заряда-разряда, безопасность, возможность быстрой зарядки, устойчивость к буферному режиму работы и приемлемая стоимость. Но для этих АКБ, также как и для других, очень важен контроль процесса заряда и разряда, а специализированных микросхем для этого вида аккумуляторов не так много. Инженеры КОМПЭЛ подготовили список имеющихся микросхем и возможных решений от разных производителей. Подробнее>>

Реклама: АО КОМПЭЛ, ИНН: 7713005406, ОГРН: 1027700032161

7 часов назад, Alex сказал:

Раздел "OSCILLATOR MODULE" даташита. Всё расписано по полочкам, даже с рисуночками...

Я читал этот раздел. Увидел, что внутренний генератор настраивается в регистре OSCCON. Я его настроил вот так (хотел запуститься от 4МГц):

OSCCONbits.IRCF = 0b101;
OSCCONbits.OSTS = 0;
OSCCONbits.HFIOFS = 1;
OSCCONbits.SCS = 0x10;

А в итоге не увидел на осциллографе разницы. Я, видимо, упустил какую-то маленькую, но важную деталь )

Ссылка на комментарий
Поделиться на другие сайты

это:

if(INTCONbits.TMR0IF & INTCONbits.TMR0IE) tmr0_int();

if(INTCONbits.TMR0IF && INTCONbits.TMR0IE) tmr0_int();

разные команды!!!

23 часа назад, Auratos сказал:

Значит в 16-битном режиме для 1мс мне понадобится 4916 приращений таймера.

там ни как не будет эта цифра.

вход в обработчик  2маш.цикла

переход на функцию   2маш.цикла

семафор    6 маш.циклов

установка таймера   6маш.циклов

итого   16маш.циклов

Ссылка на комментарий
Поделиться на другие сайты

2 часа назад, IMXO сказал:

там ни как не будет эта цифра.

Объясните, пожалуйста, вашу точку зрения. Цифра, задуманная мною, не будет в принципе или не будет при данном синтаксисе?

if(INTCONbits.TMR0IF & INTCONbits.TMR0IE) tmr0_int();

А если напишу if(INTCONbits.TMR0IF && INTCONbits.TMR0IE) tmr0_int();, то будет?

2 часа назад, IMXO сказал:

там ни как не будет эта цифра

Просто когда я поправил порядок инициализации (TMR0H и TMR0L поменял местами), как посоветовали, то результат улучшился. Теперь я на осциллографе увидел, что прерывания срабатывают каждую  1.045мс, вместо предыдущих 1.3мс. Хотя я подбирал предзагрузку для 1.0001мс, но результат уже определенно лучше

Ссылка на комментарий
Поделиться на другие сайты

От переполнения таймера, до его переустановки проходит n-ное кол-во тактов (их описал IMXO). По этому и возникает ошибка.
Ещё раз посоветую - используйте другие таймеры, специально для этого предназначенные. Они сами, аппаратно, переустанавливаются при переполнении.

Ссылка на комментарий
Поделиться на другие сайты

2 часа назад, Auratos сказал:

Просто когда я поправил порядок инициализации (TMR0H и TMR0L поменял местами)

все проще, в хедерах уже прописана переменная TMR1  размерностью 16бит

в коде после конфига достаточно прописать что-то типа

#define CONSTANT_TMR1  45 - 4916 //  где первое число поправочный коэф. 
                                 // второе расчетное кол-во тактов  
  
// перезагрузка таймера
      INTCONbits.TMR0IF = 0;	// сброс переполнения таймера
      T0CONbits.TMR0ON = 0;
      TMR1 = CONSTANT_TMR1;  
      T0CONbits.TMR0ON = 1;

 

Ссылка на комментарий
Поделиться на другие сайты

Спасибо большое. Теперь я со всем разобрался. Убрал лишнее из обработчика прерываний, назначил на все это дело TMR2, и все запело ))

Ссылка на комментарий
Поделиться на другие сайты

Присоединяйтесь к обсуждению

Вы можете написать сейчас и зарегистрироваться позже. Если у вас есть аккаунт, авторизуйтесь, чтобы опубликовать от имени своего аккаунта.
Примечание: Ваш пост будет проверен модератором, прежде чем станет видимым.

Гость
Unfortunately, your content contains terms that we do not allow. Please edit your content to remove the highlighted words below.
Ответить в этой теме...

×   Вставлено с форматированием.   Восстановить форматирование

  Разрешено использовать не более 75 эмодзи.

×   Ваша ссылка была автоматически встроена.   Отображать как обычную ссылку

×   Ваш предыдущий контент был восстановлен.   Очистить редактор

×   Вы не можете вставлять изображения напрямую. Загружайте или вставляйте изображения по ссылке.

Загрузка...
  • Последние посетители   0 пользователей онлайн

    • Ни одного зарегистрированного пользователя не просматривает данную страницу
  • Сообщения

    • Читайте внимательнее вопрос темы - мне не нужна рабочая программа, мне нужны доказательства её присутствия в памяти или отсутствия. Запрос пароля означает присутствие рабочей программы в памяти Logo, что дает основания заниматься этом Logo и далее. 
    • Так с паролями на Лого вроде не было проблем, есть программы для взлома.
    • Думаю оставить такой вариант (модельку ручки на резистор не стал делать). Сделаю ещё крышку на измерительную головку, чтоб пылью не покрывалась от частого использования :-) .  
    • на самом деле понятно но не до конца...  я так понимаю будет следующее: низкое сопротивления катушки может привести к падению напряжения на блоке питания, что в свою очередь  повлечет что цепи питания каскадов раскачки, будут продолжать держать напряжение на базах выходных транзисторов. На коллекторах которых окажется напряжение ниже, чем на базе. Следом выходники резко перебрасывают основной ток из цепи К-Э, на цепь Б-Э, следом горит регулировка уровня ("краник") в открытом состоянии, ни и вся дурь из банок БП ломится как оголтелая, что приведет к красивому но ужасному бадабум... успеет ли удержать этот процесс защита тоже вопрос. Или Вы имели в веду чем выше насыщение, тем выше ток в ООС, что тоже приведёт к плачевным результатам...   Если не прав, прошу поправить, проседаю я в схемотехники... 
    • ОБР выходников.
    • Это "классика жанра".  Аналоговые стабилизаторы поэтому до сих пор еще существуют, потому что они не дают импульсных помех. Даже если после импульсного понижающего стабилизатора поставить аналоговый, все равно идет генерация от катушек трансформаторов. Если вы в это время налаживаете какой-то прибор у которого полезный сигнал измеряется единицами милливольт, например вход радиоприемника, то представьте себе источник помех рядом. Задавить такой источник помех не так просто. Иначе можно было бы просто использовать полностью импульсный блок питания и не возиться с тем чтобы обеспечить малую разность напряжения на регулирующем транзисторе. Самый простой вариант - это автоматическое переключение обмоток как в схеме Шелестова.
×
×
  • Создать...