[首页]
[文章]
[教程]
首页
Web开发
Windows开发
编程语言
数据库技术
移动平台
系统服务
微信
设计
布布扣
其他
数据分析
首页
>
其他
> 详细
SylixOS定时器测试误差分析
时间:
2018-01-31 18:22:33
阅读:
247
评论:
0
收藏:
0
[点我收藏+]
测试模型
1.1 测试流程
图 1.1 运行流程
如图 1.1所示为测试代码运行流程,通过GPIO拉高到拉低的时间来判断定时器的精准度。
1.2 测试方法
1.2.1 测试模型
利用ZYNQ内部私有定时器,设置定时时间250μs并绑定中断。在中断服务程序中拉高GPIO,下一次进入中断服务程序时拉低GPIO并且发送二进制信号量。在应用程序中创建高优先级任务接收二进制信号量并且模拟负载,创建10个中优先级任务模拟负载,连接示波器测量时间。
1.2.2 测试干扰项
其他不同优先级的中断;
其他负载程序;
二进制信号量;
1.3 测试结果
程序运行时会产生如图 1.2所示波形。
图 1.2 正常波形
使用示波器抓波功能,如图 1.3图 1.4所示抓取电平拉低与拉高的时间间隔,经过12小时抓取小于242μs的的波形未出现,经过12小时抓取大于258μs的波形未出现。
图 1.3 抓取小于242μs波形
图 1.4 抓取大于258μs波形
测试结果可以看到误差范围在242μs到258μs之间,所以误差大小为±8μs。
误差分析
从程序运行流程来看,到达定时时间250μs后:
○1中断产生;
○2响应中断服务程序;
○3拉GPIO;
(一) 如果到达250μs定时时间时,中断产生之前发生系统关中断,则中断无法响应;SylixOS最大关中断时间7μs;此时则可能产生误差;
(二) SylixOS中断响应时间平均3.6μs,最小2.9μs,最大4.1μs。分析以下场景:
第一次中断产生之前发生系统关中断情况,接着中断以最慢4.1μs时间响应,拉低GPIO;第二次中断产生前没有发生系统关中断情况,以最快2.9μs时间响应中断拉高GPIO;这个场景时间会比正常时间少7μs+1μs左右;
第一次中断产生前没有发生系统关中断情况,接着以最快2.9μs时间响应中断,拉低GPIO;第二次中断产生之前发生系统关中断情况并且以最慢4.1μs时间响应中断拉高GPIO;这个场景时间会比正常时间多7μs+1μs左右;
此误差分析正好符合测试结果±8μs。
SylixOS定时器测试误差分析
原文:http://blog.51cto.com/12558129/2067440
踩
(
0
)
赞
(
0
)
举报
评论
一句话评论(
0
)
登录后才能评论!
分享档案
更多>
2021年09月23日 (328)
2021年09月24日 (313)
2021年09月17日 (191)
2021年09月15日 (369)
2021年09月16日 (411)
2021年09月13日 (439)
2021年09月11日 (398)
2021年09月12日 (393)
2021年09月10日 (160)
2021年09月08日 (222)
最新文章
更多>
2021/09/28 scripts
2022-05-27
vue自定义全局指令v-emoji限制input输入表情和特殊字符
2022-05-27
9.26学习总结
2022-05-27
vim操作
2022-05-27
深入理解计算机基础 第三章
2022-05-27
C++ string 作为形参与引用传递(转)
2022-05-27
python 加解密
2022-05-27
JavaScript-对象数组里根据id获取name,对象可能有children属性
2022-05-27
SQL语句——保持现有内容在后面增加内容
2022-05-27
virsh命令文档
2022-05-27
教程昨日排行
更多>
1.
list.reverse()
2.
Django Admin 管理工具
3.
AppML 案例模型
4.
HTML 标签列表(功能排序)
5.
HTML 颜色名
6.
HTML 语言代码
7.
jQuery 事件
8.
jEasyUI 创建分割按钮
9.
jEasyUI 创建复杂布局
10.
jEasyUI 创建简单窗口
友情链接
汇智网
PHP教程
插件网
关于我们
-
联系我们
-
留言反馈
- 联系我们:wmxa8@hotmail.com
© 2014
bubuko.com
版权所有
打开技术之扣,分享程序人生!