完善资料让更多小伙伴认识你,还能领取20积分哦, 立即完善>
亲爱的 ST 社区,您好,
我目前正在为 TFT 显示器开发 8 位接口。我正在为项目使用 STM32F405RGT6。 在调试我遇到的计时问题时,我发现在使用 __asm__ __volatile__("nop") 进行 ns 级延迟时有一个有趣的行为。这是代码中有趣的部分:
当使用 DELAY_5NS 运行代码时(在 168MHz 下实际约为 5.9ns),我预计会增加约 11-12ns 的周期。我得到的正是它。我也可以清楚地看到原因,因为以下两个片段在时间方面完全没有区别:
GPIO 操作之间的延迟必须至少为 DELAY_15NS 才能影响示波器上的实际信号。 所以问题显然是:为什么? 在处理复杂的时序问题时如何考虑这一点? |
|
相关推荐
1个回答
|
|
SEV 是单周期(即类似 NOP)的指令,它产生一个 1 个周期的长脉冲,这里是在 PA1 上;r2 和 r3 被设置为通过 BSRR 设置和清除 PA2;PA8 是 MCO 上的系统时钟。
请注意,虽然对 GPIOA_BSRR 的两次写操作跨越一个周期,但 PA2 上的输出脉冲是单周期的,即写操作在两个连续的周期中一个接一个地到达 BSRR。原因是,在第一次从处理器写入包含 GPIOA 的 AHB 总线后,该总线的仲裁器将写入延迟一个周期进行仲裁。由于总线在第二次写入到达时已经被处理器占用,因此不再有仲裁延迟,写入立即通过。 这一切只有在处理器的 S 端口上的写缓冲区打开时才会发生。如果使用 SCB_ACTRL.DISDEFWBUF = 1部波形,写缓冲区打开,下部波形,写缓冲区关闭)关闭,图片会发生巨大变化,因为每次写入后处理器等待直到写入完成。 |
|
|
|
只有小组成员才能发言,加入小组>>
请教:在使用UDE STK时,单片机使用SPC560D30L1,在配置文件怎么设置或选择?里面只有SPC560D40的选项
2635 浏览 1 评论
3208 浏览 1 评论
请问是否有通过UART连接的两个微处理器之间实现双向值交换的方法?
1783 浏览 1 评论
3610 浏览 6 评论
5988 浏览 21 评论
939浏览 4评论
1316浏览 4评论
在Linux上安装Atollic TRUEStudio的步骤有哪些呢?
584浏览 3评论
使用DMA激活某些外设会以导致外设无法工作的方式生成代码是怎么回事
1303浏览 3评论
1359浏览 3评论
小黑屋| 手机版| Archiver| 电子发烧友 ( 湘ICP备2023018690号 )
GMT+8, 2024-11-23 20:38 , Processed in 1.388115 second(s), Total 78, Slave 62 queries .
Powered by 电子发烧友网
© 2015 bbs.elecfans.com
关注我们的微信
下载发烧友APP
电子发烧友观察
版权所有 © 湖南华秋数字科技有限公司
电子发烧友 (电路图) 湘公网安备 43011202000918 号 电信与信息服务业务经营许可证:合字B2-20210191 工商网监 湘ICP备2023018690号