- 论坛徽章:
- 0
|
今天在g-bios中实现了calibrate_delay()函数,通过该函数可以计算出比较精确的loops_for_perjiffies,该值表示的是,udelay(x)延迟的时间等于
一个时钟中断间隔,loops_for_perjiffies 就是x。udelay()函数有多种实现方式,但在相同的系统上,相同的udelay测试出来的loops_for_perjiffies
几乎是相同的,calibrate_delay()函数通过两轮循环来测试loops_for_perjiffie,第一轮以一个给定数字做为loops_for_perjiffie来测试,如果测试失败
则loops_for_perjiffie = loops_for_perjiffie * 2;直到测试成功;第二轮,在前面的基础上,以测试通过的前一个loops_for_perjiffie值为基础测试,测
试 失败则loops_for_perjiffie = loops_for_perjiffie + 1;通过两轮测试,可以获取相对精确和稳定的值,以我今天在at91sam9261上测试的结果,
10次测试中,6次测试的结果都是6090,其余4个结果和6090的差值都小于3.
为了测试loops_for_perjiffies的值是否准确,我做了测试,伪代码如下:
print jiffies
udelay(loops_for_perjiffies *1000*10) //在at91sam9261系统中,每秒产生1000次时钟中断,loops_for_perjiffies *1000*10意味着延迟10秒
print jiffies
在at91sam9261系统上,测试出来的loops_for_perjiffies为6090
三次测试的实际结果如下:
2073
12059
2073
12059
2073
12059
理论上,10秒延迟,如果jiffies值原是2073,那么10秒后应该为2073 +10000 = 12073,这样,可以计算出udelay(60900000)的误差为千分之14秒。
因为udelay(6090)是一毫秒,那么延迟一微秒应该是udelay(6),这样计算,延迟一微妙的误差在14/1000 0000 000秒,约1.4纳秒。 |
|