驱动中延时问题

发布于 2022-10-15 06:16:38 字数 528 浏览 20 评论 0

我在驱动模块文件中包含过文件linux/delay.h,使用GPIO软件延时函数实现一个方波输出,但是发现驱动中延时有问题,

使用udelay(1)延时,每个方波周期=2 个udelay(1)即2us,用示波器量波形发现频率确实在500KHz附件小范围波动,正常
使用udelay(2)延时,每个方波周期=2 个udelay(2)即4us,用示波器量波形发现频率确实在250KHz附件小范围波动,正常
使用udelay(4)延时,每个方波周期=2 个udelay(4)即8us,用示波器量波形发现频率确实在125KHz附件小范围波动,正常

延时改为ndelay(100),这样的话方波周期=2个ndelay(100)即200ns,频率应该为5MHz才对,但是实测只有250KHz,GPIO支持最高输出频率为10MHz方波,
改为ndelay(200),这样的话方波周期=2个ndelay(200)即400ns,频率应该为2.5MHz才对,但是实测还是250KHz

不知道是不是ndelay()函数的问题,arm-linux, 2.6.18内核

如果你对这篇内容有疑问,欢迎到本站社区发帖提问 参与讨论,获取更多帮助,或者扫码二维码加入 Web 技术交流群。

扫码二维码加入Web技术交流群

发布评论

需要 登录 才能够评论, 你可以免费 注册 一个本站的账号。

评论(6

温柔一刀 2022-10-22 06:16:38

值得关注

妄断弥空 2022-10-22 06:16:38

正常,ndelay 如果没有硬件支持,很难精确啊。
在延时前禁止调度试试...

夏末的微笑 2022-10-22 06:16:38

关中断试试吧,实在不行只能使用定时器了。

伤痕我心 2022-10-22 06:16:38

回复 4# EZWORD

    使用了spin_lock_irqsave()/spin_lock_irqrestore(),中断关了,调度也关了,还是一样的现象。

极度宠爱 2022-10-22 06:16:38

你看下这个函数的定义把
2.6.35里是这样
#define MAX_UDELAY_MS 2

#define udelay(n)                                                        \
        (__builtin_constant_p(n) ?                                        \
          ((n) > (MAX_UDELAY_MS * 1000) ? __bad_udelay() :                \
                        __const_udelay((n) * ((2199023U*HZ)>>11))) :        \
          __udelay(n))

#endif /* defined(_ARM_DELAY_H) */

千寻… 2022-10-22 06:16:38

我觉的是ndelay(100)是不是超过最大值了你可以试一下10 20之类的,也看看源码是怎么定义的

~没有更多了~
我们使用 Cookies 和其他技术来定制您的体验包括您的登录状态等。通过阅读我们的 隐私政策 了解更多相关信息。 单击 接受 或继续使用网站,即表示您同意使用 Cookies 和您的相关数据。
原文