6系列FPGA中使用块RAM的心得(4)

调试过程中的一点小问题
生成IP核的调用之后,然后对其进行例化,格式是
rrra YourInstanceName (
.clka(clka),
.addra(addra), // Bus [9 : 0]
.douta(douta)); // Bus [43 : 0]
然后调用sinplify,对其进行综合,结果很不顺利。首先是synplify报不支持器件,才发现synplify 9.6.2是2008年的产品,比Spartan6器件还要老。更新到Synplify Pro D-2010.03之后,器件是支持了,但是一综合就报错停止了,却不提示有什么错误。查看工程文件夹下面的.log和.srr文件,里面也是啥信息都没给。没办法,只好切换会使用XST进行综合。这回能给出信息了:因为例化了28次,所以有28个错误,全部提示ERROR:HDLCompilers:26 - "f7.v" line 49 unexpected token: 'rrra'。
HDLCompilers:26这个错误,一般情况下是把wire类型的值赋给了reg型的变量才提示的,但是仔细检查了程序没有发现有不对的类型声明,非常纳闷。思考了好久才发现,问题竟然就出在IP调用的身上。原来,我在使用rrra ROM0(start,addr0,temp0);调用之后,对应的douta它是一个端口,自然是wire类型的,而程序声明中temp0是一个reg型的,用来传递参数时因为类型不匹配自然提示错误了。
这里也发现了在ISE中调用synplify进行综合的一个不足之处,就是如果源程序中如果有错误的话,在直接调用synplify时,并不给出错误的具体信息,而是直接终止综合;没办法还得使用XST点击“check syntax”进行程序的语法检查,而在synplify环境下点击“syntax check”一样也能给出错误信息。看来二者的接口还不是非常完善吧。

6系列FPGA中使用块RAM的心得(4)_设计制作_处理器/DSP
12
34
0
24

相关资讯

  1. 1、从专员到资深:做一名60分的运营负责人3424
  2. 2、【人人晚报】112期:投资人变“小气”-中国科技公司怎么办?2907
  3. 3、平凡中的不平凡:共享单车的终极“宿命”3547
  4. 4、突破传统BI:应用“数据发现”的五项准则1830
  5. 5、为何整治标题党这么难?2197
  6. 6、三个问题,解答如何进行网站流量管理5019
  7. 7、陈春花:如何认识企业的目标市场与竞争对手?2830
  8. 8、产品经理周报第114期|各互联网公司,对“地摊经济”做了哪些措施3834
  9. 9、7个职场信号暗示你可能会被炒366
  10. 10、下沉市场掘金成功的十个互联网商业案例和产品运营管理模式(上篇)4198
全部评论(0)
我也有话说
0
收藏
点赞
顶部