可以用verilog描述而不能用VHDL_verilog多次调用同一模块

可以用verilog描述而不能用VHDL_verilog多次调用同一模块今天在编译一个Verilog文件,其中嵌入了VHDL的模块,其VHDL模块如下:entityvhdl_moduleisgeneric(PARA1:boolean:=false;–boolean型PARA2:boolean:=false;–integral型);

大家好,又见面了,我是你们的朋友全栈君。如果您正在找激活码,请点击查看最新教程,关注关注公众号 “全栈程序员社区” 获取激活教程,可能之前旧版本教程已经失效.最新Idea2022.1教程亲测有效,一键激活。

Jetbrains全系列IDE使用 1年只要46元 售后保障 童叟无欺

注意:verilog中不能调用vhdl的parameter package,即vhdl中定义的parameter 不能被顶层verilog调用

今天在编译一个Verilog文件,其中嵌入了VHDL的模块,其VHDL模块如下:

复制代码
entity vhdl_module is
    generic (
        PARA1    : boolean := false;    -- boolean型
        PARA2    : boolean := false;    -- integral型
    );
    port (
        PORT_A: out std_logic;
        PORT_B: in std_logic;
    );
end vhdl_module;

architecture synth of vhdl_module is
    -- 此处省略
end synth;
复制代码

在Verilog文件中做如下调用:

复制代码
module top(
    clock,                        
    res_n,
    test
);
  
input           clock; 
input           res_n;  
output          test;


vhdl_module 
    #(
        .PARA1(1),
        .PRRA2(1)
    ) 
    vhdl_module_ins (    
    .PORT_A(res_n),
    .PORT_B(clock)
);

endmodule

复制代码

Quartus II 编译后报错:

Error: VHDL type mismatch error at <component_name>.vhd: boolean type does not match integer literal

 

经查阅后得知,Quartus II在翻译VHDL中的boolean类型是用false和true传递的,而Synplify和ISE却用的是1和0传递的。故在此处会报错,需要改成如下方式:

复制代码
module top(
    clock,                        
    res_n,
    test
);
  
input           clock; 
input           res_n;  
output          test;


vhdl_module 
    #(
        .PARA1("true"), // 此处修改,若false则填入“false”,需加引号,否则任然会报错!
        .PRRA2(1)
    ) 
    vhdl_module_ins (    
    .PORT_A(res_n),
    .PORT_B(clock)
);

endmodule
复制代码

小小技巧,分享给大家。

 

ps:希望以后不同编译工具能够统一该调用参数的格式。

 


VHDL调用Verilog模块的时候,要在实例化模块前,加上“verilogmodelGM: ”

VHDL调用verlog:

verilog module:

module m(a,b,c);

input a,b;

output c;



endmodule
 
调用如下:

compoent m

port(

                        a: in std_logic;

                        b: in  std_logic;

                        c: out std_logic

                      );

end compoent

begin

verilogmodelGE: m      //我自己实验的不用也可以,用了反而有错误,估计是软件变聪明了~

port map

(…

)



end

在VHDL里调用Verilog的话:例化+映射

在Verilog里调用VHDL的话:只要映射

版权声明:本文内容由互联网用户自发贡献,该文观点仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请联系我们举报,一经查实,本站将立刻删除。

发布者:全栈程序员-站长,转载请注明出处:https://javaforall.net/192824.html原文链接:https://javaforall.net

(0)
全栈程序员-站长的头像全栈程序员-站长


相关推荐

  • Python librosa模块介绍

    Python librosa模块介绍librosa语音信号处理模块参考链接:https://www.cnblogs.com/LXP-Never/p/11561355.html

    2025年5月25日
    3
  • 手游出海必用的三大推广策略

    手游出海必用的三大推广策略不出海 便出局 这是现在游戏行业里最热门的说法之一 如何以高效的方式在海外推广手游 ASOtop1 认为 手游海外推广策略和其他并没有本质上的不同 主要都是通过社交软件 广告 邮件 ASO 优化等方式 但在具体的操作上 则有一定的区别 ASOtop1 根据自己多年的海外 ASO 优化经验 总结了一些海外推广经验 或许可以给想要出海的手游开发商提供一些参考 以下是 ASOtop1 分享的海外 ASO 优

    2025年11月19日
    5
  • vim 语法高亮

    vim 语法高亮

    2022年2月2日
    267
  • RSA加密算法流程图

    RSA加密算法流程图RSA加密算法流程图

    2022年5月15日
    61
  • 通过SaveFileDialog实现保存文件[通俗易懂]

    通过SaveFileDialog实现保存文件[通俗易懂]示例中通过点击按钮实现打开另存为对话框,进行相关的文件保存。在按钮单击触发下代码如下:    SaveFileDialogsaveExcel=newSaveFileDialog();//实例化SaveFileDialog    saveExcel.Filter=”工作表(*.xls)|*.xls|所有文件(*.*)|*.*”;//可用文件类型    if(save

    2022年10月8日
    3
  • 物联网操作系统的体系构架(物联网系统怎么开发)

    1.       物联网的主要特点                       i.             连接所谓连接,指的是各种各样的终端设备,都能够通过某种网络技术,连接到一个统一的网络上。任何终端之间都可以相互访问。下一代的基础通信网络,包括未来的5G,通信网络架构重构等,为物联网提供泛连接网络是核心目标。目前也已经有很多厂商推出解决方案,比如Google的thread/wave,华

    2022年4月12日
    47

发表回复

您的邮箱地址不会被公开。 必填项已用 * 标注

关注全栈程序员社区公众号