tvalid寄存器的理解
if(!out_axis_tvalid_reg || m_axis_tready ) beginend
m_axis_tready 是上拍下一级给的ready信号
out_axis_tvalid_reg是上一拍,本级给下级的valid信号
一共有四种组合,然后可以通过这个if语句,在接下来的begin ... end中,用来判断本拍的valid是不是可以拉高。
out_axis_tvalid_reg=0,m_axis_tready=0
上一拍没有拉高有效信号,说明没有有效数据要输出。正好上一拍也没有拉高ready。那么我本拍是可以把valid拉高(如果有数据)或者拉低(如果没有输出)的。
out_axis_tvalid_reg=0,m_axis_tready=1
上一拍没有拉高有效信号,说明没有有效数据要输出。虽然上一拍给了ready,但是我确实是没有数据可以输出的。那么我本拍是可以把valid拉高(如果有数据)或者拉低(如果没有输出)的。
out_axis_tvalid_reg=1,m_axis_tready=0
上一拍有拉高有效信号,说明有有效数据要输出,但是上一拍没有给ready。说明数据没有输出,这一拍自然也就没得选,只能是保持值不变(也就是拉高)。
out_axis_tvalid_reg=1,m_axis_tready=1
上一拍有拉高有效信号,说明有有效数据要输出,并且给到了ready。说明数据输出了,那么我本拍是可以把valid拉高(如果有数据)或者拉低(如果没有输出)的。