gpt4 book ai didi

c - PIC24F16KA102 上的定时器 1 不工作

转载 作者:行者123 更新时间:2023-11-30 14:53:10 25 4
gpt4 key购买 nike

我想配置PIC24F16KA102的timer1来计数。时钟源必须是8 MHz 的内部时钟。我配置了寄存器T1CON并将TON位设置为高电平以启动定时器。 Timer1 设置为每 100 us 溢出一次,然后用一个 while 周期增加变量计数。我不明白,因为timer1不工作,我观察到它没有增加。为什么?

   #include <xc.h>
#include "config.h"

int count = 0;

void main(void) {

TRISB = 0;

T1CON = 0; //TRM1 stopped, internal clock source, prescaler 1:1

_TON = 1;
TMR1 = 65135; //overflow of TM1 every 100 us (400 counts)

while (1) {

if (TMR1 == 65535) {

count++; // increase every 100 us
TMR1 = 65135;

}

}
}

最佳答案

尝试设置定时器 1 周期寄存器 (PR1) 并使用中断,而不是 try catch 并重新加载 TMR1 的最终计数。您试图在恰好 65535 上捕获 TMR1,但这几乎永远不会起作用,因为一旦 TMR1 达到 65535,它就会溢出并再次从 0 开始计数。编辑:当然,这是假设它很重要。我不知道当您将周期寄存器保留为 0 时,定时器的行为是什么。它可能只是简单地计数到最大值 65535,然后重置为 0,或者它可能根本不会计数并连续将 PRx 加载到 TMRx 中,因为它们匹配于 0

PRx 旨在定义给定计时器所需的周期,在本例中为 100uS。 PR1 = 400。一旦 TMR1 = PR1,定时器将自动重置并引发中断以提醒您定时器已过。

volatile unsigned int count = 0;   //Vars that change in an ISR should be volatile
PR1 = 400; //Set Period for Timer1 (100us)
T1CON = 0x8000; //Enable Timer1

IEC0bits.T1IE = 1; //Enable Timer1 Interrupt
IPC0bits.T1IP = 0b011;

将其与 ISR 函数配对,以便在计时器到期时增加计数:

void __attribute__ ((interrupt,no_auto_psv)) _T1Interrupt (void)
{
count++;
IFS0bits.T1IF = 0; //Make sure to clear the interrupt flag
}

您也可以在没有任何中断的情况下尝试类似的操作:

void main(void){
unsigned int count = 0;
TMR1 = 0;
T1CON = 0x8000; //TON = 1

while(1){
if (TMR1 >= 400){
count++;
TMR1=0;
}
}
}

但是我建议使用 PR 寄存器和 ISR。这就是它的目的。

编辑:我还建议阅读有关定时器的 PIC24F 引用手册: Here

关于c - PIC24F16KA102 上的定时器 1 不工作,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/47366107/

25 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com