基于VxWorks下的多重定时器设计

时间:2011-11-22来源:网络

3.2 主要实现代码
一个三重定时器的主要实现代码如下:


以上程序中通过sysClkRateSet(100)将最小延时单位tick修改成10 ms,它是几个定时时间(30 ms、40 ms、60ms)的最大公约数。通过抓包软件Ethereal抓包,查看发送时间。以30 ms为例,抓包100次的平均定时时间在25 ms左右。出现这种情况的原因是,延时N个tick实际是延时(N-1)tick~N·tick。由于是等可能概率,则它的数学期望是(N+1/2)。对于tick为10 ms,30 ms即N=3,数学期望为25 ms。示意图如图4所示。

延时精度为1/N秒,N越大越精确。于是调用函数synClkRateSet(500),可以使定时的最大误差不超过2 ms。但是如果时钟频率太高,会造成系统在时钟中断处理方面开销太大,影响系统的任务调度,最好通过实验选用较为合适的时钟频率。这里选用sysClkRate-Set(200)。


结 语
本文针对VxWorks下UDP网络通信中的可靠传输问题,提出了一个支持重传和定时等待确认的协议,并利用VxWorks系统提供的信号量同步、消息队列和看门狗定时器等多种机制,综合设计了一种可扩展的三重定时器。针对遇到的具体问题,笔者还进行了一定的优化处理。这种多重定时器模型已在笔者所研究的项目中得到利用,验证了其可行性和相对稳定性。这种多重定时器模型并不完全适合所有环境,需要根据具体情况改进和优化。

1 2

关键词: 设计 定时器 多重 VxWorks 基于

加入微信
获取电子行业最新资讯
搜索微信公众号:EEPW

或用微信扫描左侧二维码

相关文章

查看电脑版