Xilinx FPGA错误、调试记录

1.Verilog语法错误

FATAL_ERROR: Vivado Simulator kernel has discovered an exceptional condition
 from which it cannot recover. Process will terminate. For technical support 
 on this issue, please open a WebCase with this project attached at 
 http://www.xilinx.com/support.
Time: 5 ns  Iteration: 2  Process: 
/JPEGLS_Compress_tb/JPEGLS_Compress_tb/Pixel_Rebuild_inst/Always376_55

错误原因:在generate for中的几个并行电路,always@(*)块中的组合逻辑,使用过程赋值语句,将变量多次赋值给相同的寄存器,如下:

genvar i;
generate
for(i=0; i<`MaxNear; i=i+1) begin:Pr_Loop
always@(*)
   begin
      PX[i] = (Qs_sign_d1[i])?(Px_pre_d3[i] - C_pre[i] ):((Px_pre_d3[i] + C_pre[i] ));
      if( PX[i][16] == 1'b1) PX[i] =0;
      else if(PX[i] > `MaxValue) PX[i]  = `MaxValue;
      else PX[i] = PX[i];
   end
......
end 
endgenerate

添加中间寄存器,该为:

genvar i;
generate
for(i=0; i<`MaxNear; i=i+1) begin:Pr_Loop
always@(*)
   begin
      PX_temp[i] = (Qs_sign_d1[i])?(Px_pre_d3[i] - C_pre[i] ):((Px_pre_d3[i] + C_pre[i] ));
      if( PX_temp[i][16] == 1'b1) PX[i] =0;
      else if(PX_temp[i] > `MaxValue) PX[i]  = `MaxValue;
      else PX[i] = PX_temp[i];
   end
......
end 
endgenerate

2. vivado 仿真时闪退

vivado在进行仿真时,尤其是仿真波形信号过多时,会产生大量的临时文件。默认存储在C盘,具体位置:

C:\users\Administrator\AppData\Local\Temp

当磁盘容量不足时,导致vivado闪退。
解决办法:
通过修改用户的环境变量,可以将系统产生的TEMP文件存放在较大的盘上。如下:


在这里插入图片描述

  • 0
    点赞
  • 2
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值