免费注册 查看新帖 |

Chinaunix

  平台 论坛 博客 文库
最近访问板块 发新帖
查看: 1489 | 回复: 1
打印 上一主题 下一主题

[操作系统] 统计中断关闭时间 [复制链接]

论坛徽章:
0
跳转到指定楼层
1 [收藏(0)] [报告]
发表于 2014-10-13 11:11 |只看该作者 |倒序浏览
在ARM&linux平台上如何统计代码流程当中
spin_lock_irqsave  -> spin_unlock_irqrestore
关中断的大概时间, 起码能够精确到毫秒级别

在x86的平台上可以使用rdtsc这类硬件的高精度定时器来获取高精度的动态时间, 但是在ARM上应该如何操作那, 请各位ARM高手给点建议。

目前使用的HZ是128, NO_HZ配置打开。
我看了一些获取时间的接口例如current_kernel_time/do_gettimeofday等等。
但是感觉他们的精度应该是达不到需要, 因为我看有些时间是依赖中断去更新的, 因此在关中断的上下文里面获取这个时间
即使静态的精度再高都没有意义。

查了一部分信息, 感觉可行的可能有
1. 访问PMU, 获取CPU cycle用来转换时间
2. 通过特定的watchdog 定时器
3. 通过RTC(但是不缺定RTC的精度能符合需求)

但是对ARM 实在不怎么熟悉, 目前使用的CPU平台是瑞萨的R8A7791, 请各位指教啊。
多谢~

论坛徽章:
1
申猴
日期:2014-12-23 16:52:51
2 [报告]
发表于 2014-10-15 22:46 |只看该作者
看CPU的外设有哪个高精度的timer就用哪个。
PMU是最高的了,没有的话可以是一些外设上面的timer,一般是主频的N分频。
您需要登录后才可以回帖 登录 | 注册

本版积分规则 发表回复

  

北京盛拓优讯信息技术有限公司. 版权所有 京ICP备16024965号-6 北京市公安局海淀分局网监中心备案编号:11010802020122 niuxiaotong@pcpop.com 17352615567
未成年举报专区
中国互联网协会会员  联系我们:huangweiwei@itpub.net
感谢所有关心和支持过ChinaUnix的朋友们 转载本站内容请注明原作者名及出处

清除 Cookies - ChinaUnix - Archiver - WAP - TOP