背景:解析串口的一个字节,如果这个字节为5,则让一个引脚产生一个脉冲信号
先画了个波形图:
波形图中的逻辑:
data_ctrl每一次改变都会有一个valid信号拉高一个脉冲,当检测到有valid脉冲时,就拉高flag_qh,检测flag_qh拉高后,cnt_qh开始计数,当cnt_qh计数到13时,flag_qh就拉低
感觉波形图挺正确的,但一仿真就发现问题了,cnt_qh在等于13后,即使有下一个valid信号拉高,cnt_qh也不会发生改变,这是因为cnt_qh的计数规则是:当flag_qh为高时,cnt_qh开始计数,计数到13时就停止计数,停止计数是保持13不变,这样的当他为13时就即使flag_qh为高,cnt_qh也不会计数
但更改也很简单,只需要让他在等于13的时候变为0即可
所以这个波形图在绘制时,没有注意的点是,当下一次开始计数时,cnt_qh是如何归零的,这里的细节没注意到