Linux下timer延时的使用

因笔者工作在嵌入式平台上(非x386),下面给出的结论仅在arm平台上测试过。


1. 在原子上下文,延迟应该少于100微秒。

使用udelay

2. 在非原子上下文延迟的使用

0-100us: 使用udelay

100us以上: 使用usleep_range

20ms以上且不要求精确: 使用msleep


msleep不精确,完全可以用usleep_range代替。


可以参考的文档:Documentation/timers/timers-howto.txt


下面是在Freescale i.mx6Q (arm Cortex A9, 1.0Ghz, Qual-core)平台上的测试结果,

使用的内核版本是: 3.7.0-rc1+


10us delaycompare: udelay:10:usleep_range:31

100us delaycompare: udelay:99:usleep_range:119

1ms delaycompare: mdelay:998: msleep10429: usleep_range:1017

5ms delaycompare: mdelay:5004: msleep18480: usleep_range:5017

10ms delaycompare: mdelay:9991: msleep19431: usleep_range:10020

20ms delaycompare: mdelay:19987: msleep24205: usleep_range:20019

25ms delaycompare: mdelay:24995: msleep39140: usleep_range:25021

 

10us delaycompare: udelay:10:usleep_range:31

100us delaycompare: udelay:100:usleep_range:119

1ms delaycompare: mdelay:998: msleep10404: usleep_range:1017

5ms delaycompare: mdelay:5003: msleep18486: usleep_range:5017

10ms delaycompare: mdelay:9993: msleep19455: usleep_range:10027

20ms delaycompare: mdelay:19990: msleep24168: usleep_range:20021

25ms delaycompare: mdelay:25004: msleep39137: usleep_range:25020

 

10us delaycompare: udelay:10:usleep_range:31

100us delaycompare: udelay:100:usleep_range:119

1ms delaycompare: mdelay:998: msleep10340: usleep_range:1017

5ms delaycompare: mdelay:5005: msleep18480: usleep_range:5016

10ms delaycompare: mdelay:9990: msleep19427: usleep_range:10014

20ms delaycompare: mdelay:19999: msleep24205: usleep_range:20013

25ms delaycompare: mdelay:24996: msleep39144: usleep_range:25024

 

10us delaycompare: udelay:10:usleep_range:33

100us delaycompare: udelay:100:usleep_range:116

1ms delaycompare: mdelay:998: msleep10387: usleep_range:1014

5ms delaycompare: mdelay:5007: msleep18484: usleep_range:5013

10ms delaycompare: mdelay:9997: msleep19454: usleep_range:10024

20ms delaycompare: mdelay:19990: msleep24179: usleep_range:20020

25ms delaycompare: mdelay:24997: msleep39140: usleep_range:25018

 

10us delaycompare: udelay:10:usleep_range:35

100us delaycompare: udelay:100:usleep_range:119

1ms delaycompare: mdelay:998: msleep10330: usleep_range:1017

5ms delaycompare: mdelay:5005: msleep18482: usleep_range:5016

10ms delaycompare: mdelay:9991: msleep19433: usleep_range:10021

20ms delaycompare: mdelay:19989: msleep24203: usleep_range:20020

25ms delaycompare: mdelay:24993: msleep39145: usleep_range:25022

 

10us delaycompare: udelay:10:usleep_range:31

100us delaycompare: udelay:100:usleep_range:120

1ms delaycompare: mdelay:998: msleep10383: usleep_range:1017

5ms delaycompare: mdelay:5004: msleep18486: usleep_range:5017

10ms delaycompare: mdelay:9994: msleep19451: usleep_range:10023

20ms delaycompare: mdelay:19991: msleep24171: usleep_range:20022

25ms delaycompare: mdelay:24998: msleep39141: usleep_range:25020

 



  • 0
    点赞
  • 2
    收藏
    觉得还不错? 一键收藏
  • 2
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论 2
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值