串口中断读取定时器中断变量值来计算事件时间不准咋办?

2020-01-22 12:14发布

单片机C8051F020,设置:晶振是22.11814MHZ,串口1波特率是9600,定时器4是每隔2ms中断一次,每到100ms的时候,定时器中的变量T++;16位自动重装模式,串口1的中断优先级标志位置1。
  如题,在串口中断里面当检测到传来了指令A后,就将此时刻的变量T的值记录下来,收到指令B后将此时刻的变量T的值记录下来(A指令只来一次,B指令有多次)。在主函数里面处理串口收到的数据的时候再计算两个记录值的差,得到AB间的时间。在1分钟左右的时候,误差在0.3秒左右,但到了2分钟的时候误差就到了0.6秒左右,3分钟误差是0.9秒左右,4分钟误差在1秒左右了。不知道这是为什么,按照我想的,当进入串口有数据的时候,会马上进入中断,并读取变量值,因此误差不应该这么大呀。
  按照我的分析,既然误差逐渐偏大, 且时间差都是以以A指令记录的变量值为基准,那么造成误差逐渐偏大的原因就是进入串口中断的时间在逐渐变长或者是定时器的误差在逐渐的变大,但我用手机秒表跟定时器计时1分钟进行比对,定时器1分钟还是挺准的。也试过在中断函数中利用using关键字,但没什么效果。
  试着改变两个中断的优先级,误差依然有,不知道该怎么办了,求助!

我试过用定时器0,16位定时,也是同样的采用读取100ms变量值的方式,但发现同样情况下,误差更大。怀疑是不是定时器的问题,换了块板子,也是一样的情况。
友情提示: 此问题已得到解决,问题已经关闭,关闭后问题禁止继续编辑,回答。
9条回答
yunmenghan
2020-01-23 06:36
steaven2000 发表于 2014-9-2 08:56
(1)你如何得知实际2次发送串口指令的时间差,不要告诉我你是串口助手定时发送。要知道WINDOWS的这个定 ...

(1)这是一个天康跑步测试仪(测跑800/1000米所用时间),它有控制台和前端组成,控制台设定要跑的圈数还有哪些跑道,然后告诉前台。前台有传感器,当规定的圈数跑完后,串口发送指令B到控制台,此时控制台显示该跑道所用时间,我是以这个显示出来的时间为准的,看单片机测出来的时间跟这个一不一样。控制台能记录年月日等时间信息,因此里面应该有时钟芯片(今天拆开来看了一下,确实有,是用的pf85163)
(2)试过用10ms的计时变量累加值,也试过20ms和50ms,结果都是相似的
(3)串口中断里有一个if语句,查询收到的字节是不是指令中的特有字节,是的话就将此时刻的变量累加值记录到数组里。不是串口收到数据,然后主函数里去查询是否收到指令的。一开始的时候是这样做的,但想了想还是放在中断里吧,实时性比较高一点。

用示波器观察定时器中断的执行时间只有10us(串口中断执行时间没看,应该也差不多吧),手头上没有示波器,示波器是跑到一个公司里去测试的,设备也带不过去,联调的时候就只能想象哪里出问题了,悲催。

一周热门 更多>