VHDL 实体

本文详细介绍了VHDL中的实体(Entity)定义,重点关注GENERIC通用属性和端口的使用。GENERIC用于定义静态参数,提供代码的灵活性和重用性,而端口则定义了电路的输入输出信号类型和模式。关键词包括:GENERIC、端口、参数、信号类型、VHDL、硬件描述语言。
摘要由CSDN通过智能技术生成

实体

描述电路所有输入输出引脚

定义

实体关键字  实体名  IS
通用属性关键字(
               参数名 : 参数类型 := 参数值;
               );
端口关键字(
           端口名:端口信号模式:数据类型;
           …
           …
          )
END 实体名;

代码说明:

ENTITY entity_name IS

GENERIC(
           parameter_name: parameter_type :=  parameter_value;;
             
PORT  (
        port_name: signal_mode   signal_type;
      )
END entity_name;

举例:

entity tp_test_single is

GENERIC
       (
           DATA_LEN :  integer  :=  10;
           RD_LEN   :  integer  :=  16;
           VECTOR   :  bit_vector := "11110101";
           WR_LEN   :  integer  :=  16  
         );--代码声明的最后一行不能加分号,不然编译会报错

   port(
       tp_0  :in  std_logic;
       tp_1  :in  std_logic;   
       tp_out  :out  std_logic_vector(7 downto 0)
       )
end tp_test_single;

注意:

1. 关键字可以用大写也可以用小写
2. 代码声明的最后一行不能加分号,不然编译会报错

GENERIC 通用属性

GENERIC 通用属性 类似于C语言中的宏定义。
它提供了在fpga中一种定义常规(常量)参数的方法,指定的参数是静态的。

GENERIC 必须在实体中进行声明,参数是全局的,不仅可以在实体内部使用,还可以在后面整个文件中使用。

使用GENERIC 通用属性定义参数,修改参数方便,增强代码的灵活性和可重用性。 既然类似于宏定义,参数名一般也用大写。
通用属性在实体中不是必须包含的。

端口

端口名由自己确定,不能使用保留关键字。

端口信号模式包括四种:

 	in 
    out 
    inout
    buffer

in 和 out 是单向引脚;
out 的端口(输出信号)不能供电路内部使用;
inout 是双向引脚;
buffer 的引脚首先是一个输出引脚,该输出信号可以供本电路(本文件内)使用。

信号的类型

信号的类型包括:

bit 
std_logic  
integer

将在博客《数据类型》中详细介绍。

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

xiawucha159

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值