IC/FPGA面试问题讲解系列——2位宽转换

本文详细讲解了在FPGA设计中如何处理2位宽到4位宽的数据转换问题,涉及上下级间的握手协议和反压情况。通过分析,提出了解决方案,包括输出信号的延迟处理、输入与输出信号的同步策略以及中间寄存器的使用。此外,还提供了相应的代码实现,适用于位宽转换和频率转换场景。
摘要由CSDN通过智能技术生成
  • 题分析
    • 位宽转换,转换比为1:4,上下级用握手方式传输数据,要充分考虑反压情况

  • 输入
    • din_valid, din_ready, din[4:0]

  • 输出
    • dout_valid, dout_ready, dout[19:0]
    • 输出信号寄存1拍,则输出比输入信号延迟1拍

  • 中间寄存器
    • holding[2:0]

  • 过程
    • holding负责计算din握手成功次数,即上级传入多少tick
      • 那么如果位宽拼接是1:4,则希望valid=(holding==4)
      • din_ready:
        • 如果dout_valid拉高时dout_ready拉低,则数据无法传输,为了防止dout数据被冲毁,此时din_ready需拉低,即din_ready=dout_ready;
        • 但是如果dout_valid未拉高,则数据未拼接完成,仍有承载能力,可以继续接收上级数据,即din_ready=!dout_valid;
        • 那么合并即可:din_ready=!dout_valid | dout_ready。

      • holding:
        • holding是上级传输数据数量的计数器ÿ
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值