完善资料让更多小伙伴认识你,还能领取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部波形,写缓冲区打开,下部波形,写缓冲区关闭)关闭,图片会发生巨大变化,因为每次写入后处理器等待直到写入完成。 |
|
|
|
|
只有小组成员才能发言,加入小组>>
stm32mp157的异核通信的rpmsg_sdb的m4固件和a7驱动该如何编写?
1474 浏览 0 评论
stm32f103用freertos对一个采样率为1kHz的传感器,进行采样,数据出差
1529 浏览 0 评论
请教:在使用UDE STK时,单片机使用SPC560D30L1,在配置文件怎么设置或选择?里面只有SPC560D40的选项
3676 浏览 1 评论
3868 浏览 1 评论
请问是否有通过UART连接的两个微处理器之间实现双向值交换的方法?
2483 浏览 1 评论
STM32H7打开DCache后,出现了串口接收信息为空的现象,是哪里出了问题?
757浏览 5评论
用NANO STM32F103RBT6的开发板烧录不了是哪里出了问题?
688浏览 5评论
732浏览 5评论
外部中断触发类型为双边沿触发,进入中断回调后有什么办法判断该边沿是上升沿还是下降沿?
985浏览 5评论
STM32L071CBT6低温环境下无法正常工作是什么原因引起的?
786浏览 5评论
/9
小黑屋| 手机版| Archiver| 电子发烧友 ( 湘ICP备2023018690号 )
GMT+8, 2025-12-17 17:06 , Processed in 0.685498 second(s), Total 72, Slave 55 queries .
Powered by 电子发烧友网
© 2015 bbs.elecfans.com
关注我们的微信
下载发烧友APP
电子发烧友观察
版权所有 © 湖南华秋数字科技有限公司
电子发烧友 (电路图) 湘公网安备 43011202000918 号 电信与信息服务业务经营许可证:合字B2-20210191

淘帖
730