搜索
bottom↓
回复: 2

EDK 调用ISE生成的IP

[复制链接]

出0入0汤圆

发表于 2011-11-13 13:20:38 | 显示全部楼层 |阅读模式
在EDK定制用户IP需要调用ISE生成的IP,在网上搜索了解决方案如下,
在ISE中封装HDL,并使用IP,设计分三大步:
第一步:像通常建立工程设计一样,先编写一个模块,如:
module add(a,b,c)
   Input a,b;
   output[1:0]
   assign c=a+b;
endmodule

设置综合选项,综合过程中不能加入IO buf和iob(考虑到跟外部模块接口问题):

在综合设置中,-iobuf不要勾选,-iob选 NO,综合,生成网表add.ngc;

第二步:制作一个blackbox模块(就是一个IP的wrapper封装设计),如下:
   module add(a,b,c)
   input a,b;
   output[1:0]
endmodule
只申明端口。
第三步:使用此IP,需要先把第二步的blackbox以v文件形式加入到工程,再调用这个模块,再把add.ngc文件加入到工程文件夹下即可(注意此过程在综合实现时候,要把第一步的两个选项选上)。

按照以上的步骤建立工程,然后在modelsim测试发现输出C一直是高阻态,感觉像是第一步生成的网表没有加进去,斑竹知道这里面哪一步有问题吗
testbench.v
module testbench;

    // Inputs
    reg a;
    reg b;

    // Outputs
    wire [1:0] c;

    // Instantiate the Unit Under Test (UUT)
    ip_test uut (
        .a(a),
        .b(b),
        .c(c)
    );

    initial begin
        // Initialize Inputs
        a = 0;
        b = 0;

        // Wait 100 ns for global reset to finish
        #10 a=1;
            b=0;
       #20 a=1;
            b=1;
        #30 a=0;
          b=1;
      #200 $stop;            
        
        // Add stimulus here

    end
      
endmodule

(原文件名:QQ截图20111113131821.png)

阿莫论坛20周年了!感谢大家的支持与爱护!!

知道什么是神吗?其实神本来也是人,只不过神做了人做不到的事情 所以才成了神。 (头文字D, 杜汶泽)

出0入0汤圆

 楼主| 发表于 2011-11-13 13:21:45 | 显示全部楼层
希望各位大侠不吝指教

出0入0汤圆

 楼主| 发表于 2011-11-13 15:21:41 | 显示全部楼层
我将上面的程序下载到板子发现是正确的,不知道怎么解释,难道调用的IP不能用modelsim仿真……
回帖提示: 反政府言论将被立即封锁ID 在按“提交”前,请自问一下:我这样表达会给举报吗,会给自己惹麻烦吗? 另外:尽量不要使用Mark、顶等没有意义的回复。不得大量使用大字体和彩色字。【本论坛不允许直接上传手机拍摄图片,浪费大家下载带宽和论坛服务器空间,请压缩后(图片小于1兆)才上传。压缩方法可以在微信里面发给自己(不要勾选“原图),然后下载,就能得到压缩后的图片。注意:要连续压缩2次才能满足要求!!】。另外,手机版只能上传图片,要上传附件需要切换到电脑版(不需要使用电脑,手机上切换到电脑版就行,页面底部)。
您需要登录后才可以回帖 登录 | 注册

本版积分规则

手机版|Archiver|amobbs.com 阿莫电子技术论坛 ( 粤ICP备2022115958号, 版权所有:东莞阿莫电子贸易商行 创办于2004年 (公安交互式论坛备案:44190002001997 ) )

GMT+8, 2024-7-24 11:20

© Since 2004 www.amobbs.com, 原www.ourdev.cn, 原www.ouravr.com

快速回复 返回顶部 返回列表