蜂鸟内部通用寄存器为什么不做复位初始化?
如果不做初始化,当 进行 中断断点保护时,一些未用到的寄存器 和 临时寄存器(未被使用)会被压栈进入 SRAM,而这些寄存器的内容都是未知态,SRAM model里面会做写入数据检查,仿真的时候,检查到这些未知态,就会打印很多警告。
蜂鸟内部通用寄存器不做复位初始化 的 原因 有知道的吗?
减小面积,降低功耗
你好,暂且不论面积和功耗,在实际芯片 里面,这种初始未初始化,上电后会是 不确定态,向后级传播,不会导致芯片不能正常工作吗?
你好,我将e203_exu_regfile.v 里面的 81行由如下:
sirv_gnrl_dffl #(`E203_XLEN) rf_dffl (rf_wen[i], wbck_dest_dat, rf_r[i], clk);
改成如下
sirv_gnrl_dfflr #(`E203_XLEN) rf_dffl (rf_wen[i], wbck_dest_dat, rf_r[i], clk, rst_n);
即是用了带复位功能,能够解决我遇到的 问题。因为所有的通用寄存器 在初始时刻 都被复位成 0 值,所以在压栈过程中,作为临时寄存器的 通用寄存器 不是未知态,所以在写入SRAM时,不会再报 未知态检查警告。
你说的 不带复位可以减小面积 我认同,但是 降低功耗不太赞同。因为复位初始化 只会在上电的那一刻 才会产生,后面电路正常工作后,并不会出现复位。