我正在与一个硬件设计小组一起开发一个中断处理程序,我们正在试图找出错误在哪里。我正在通过 SPI 总线以 5khz 读取芯片。芯片加载 4 个字节并触发数据就绪引脚。
我的中断处理程序唤醒并从 SPI 总线读取 4 个字节并将数据存储在缓冲区中。奇怪的是,每 17 次读取都会给出全 0 的 4 个字节,这是不对的。我们正在探索的选项之一是芯片在发送数据就绪信号时并不总是真正准备好。
所以,我知道我不能在中断处理程序中睡觉,但我想尝试引入 10 或 20 微秒的延迟。现在我有一个计数为 100,000 的 for 循环,然后处理中断。我没有看到任何变化,所以我想我可能会看看是否有人有更好的忙等待技术。或者至少是一种更好的方法来确定我应该经历多少次循环迭代,因为我不确定这需要多长时间,或者编译器是否只是在优化整个事情。