背景
按键板作为用户交互入口、板载LCD,与主板通过串口通讯。接手别人留下的代码,发现存在按键响应不到的问题。
问题排查
排查方向一:debug调试
打断点,发现可以响应按键。
排查方向二:主板与按键板通过排线链接,排线比较长
换了短线,发现还是存在问题。
排查方向三:通过示波器抓按键扫描


抓按键发现,第一张图中11.2ms扫描一次按键,第二张图中会有一段时间没有在扫描按键,如图中的444ms,查看代码发现这一段时间,mcu在与主板通讯,刷新LCD等,消耗了太久的时间。
解决办法
在刷新LCD的时候,插入按键扫描。当然不能彻底解决丢键的问题,只能降低丢键的概率。
总结
这也是矩阵按键的弊端,需要及时去扫描。当然,也可以设计成外部中断方式,或者采用ADC接口扫描等其他方式。
博主在排查一个按键响应不灵敏的问题时,发现MCU在刷新LCD时会暂停按键扫描,导致可能的丢键现象。为降低丢键概率,提出在刷新LCD时插入按键扫描的解决方案,并建议考虑使用外部中断或ADC接口来优化矩阵按键的扫描方式。
9427

被折叠的 条评论
为什么被折叠?



