VHDL基础2
Signals & Variables
VHDL 提供了 signal 和 variable 两种对象来处理非静态数据;提供了 constant 和 generic 来处理静态数据。
constant 和 signal 是全局的,可以在顺序执行的代码中,也可以在并发执行的代码中;variable 是局部的,只能值顺序代码中,并且它们的值是不能向外传递的(如果想传递出去,必须先把这个变量值传递给一个信号,再由这个信号传递出去)。
constant
constant 可以定义在 package, entity, architecture 中,对应的作用域也不同。
定义在 package 中的 constant 是真正的全局的,可以被所有调用该 package 的 entity 使用
定义在 entity 中的 constant 对于该 entity 的所有 architecture 而言是全局的
定义在 architecture 中的 constant 仅在该 architecture 中是全局的
signal
VHDL 中的 signal 代表的是逻辑电路中的 “硬”连线,既可以用于电路的输入输出端口,也可以用于 内部单元之间的连接。
variable
相比于 signal 是局部的,variable 只能在 process,function,procedure 中使用,而且对它的赋值是立即更新的,新的值可以在下一行代码中立即使用。
Packages and Components
package
除了 component, function, procedure 之外,package 中还可以包含 TYPE, CONSTANT 的定义。
PACKAGE package_name IS
(declarations)
END package_name; [PACKAGE BODY package_name IS
(delarations
and conments)
END package_name;]
可以看到,语法包括两部分,PACKAGE 和 PACKAGE BODY。
Component
一个 component 是一段完整的代码(包括 library, entity, architecture 这些组成部分),如果将这些代码声明为一个 component,那么就可以被其他电路调用,从而使代码具有了层次化的结构。
使用 component 必须先声明这个元件,然后再例化这个元件(类似 C++,变量先声明,在定义)。声明和例化都必须在 architecture 中进行。
declaration syntax
COMPONENT component_name IS
--元件端口信息
PORT(
port_name: signa_type;
port_name: signa_type;
...);
END COMPOMENT;
instantiation(例化) syntax
例化名: component_name PORT MAP (port_list);
声明元件时,可以有两种方法:
上面的方法,先声明再例化
使用 package 进行声明,将 component 的声明放在 package 中,则可以避免每次元件例化都要重复声明
Functions and Procedure
function 和 procedure 统称为 子程序,它们和 process 相似,内部包含的都是顺序描述的代码,通常使用相同的顺序描述语句。但是,function 和 procedure 的存在主要是为了建库,以达到代码重用和共享的目的,当然它们也可以直接建立在主代码中。
Function
在写代码的过程中,我们通常会遇到一些有共性的问题,我们希望实现这些功能的代码可以被共享和重用,从而使代码变得简洁,易于理解,function 的建立和使用就能达到这个目睹。 function 中可以使用 if, case, loop 等语句,但是不能有 signal 和 component。
Function Body
FUNCTION function_name [<参数列表>] RETURE 数据类型 IS
[说明部分] BEGIN
(顺序语句)
END function_name;
其中,函数的参数列表:
<parameter list> =[CONSTANT] name : type;
= SIGNAL name : type;
Function Call
函数可以单独构成表达式,也可以作为表达式的一部分
Function Location
函数可以存放在两个地方:
Package 中,这时候,函数声明在 package 中,函数定义在 package body 中
Main Code 中,既可以在 entity 中,也可以在 architecture 中
FUNCTION versus PROCEDURE Summary
function 有任意个输入参数和一个返回值,输入参数只能是 constant, signal
procedure 有任意个输入/输出/双向参数,可以是 signal, variable, constant
function 可以作为表达式的一部分,procedure 直接调用
function 和 procedure 内部,wait 和 component 都不可综合
function 和 procedure 的存放位置相同,经常位于 package 中,也可以在主代码中
VHDL基础2的更多相关文章
- VHDL基础1
Description Structure 一个可综合的VHDL描述中一般由3部分组成:LIBRARY declarations.ENTITY.ARCHITECTURE Library(库)用来设计重 ...
- VHDL基础 学习笔记
最近一直忙着学校里的活动,所以没怎么更新,上周活动忙完了,正好也借着数电实验的机会,重新学习一下VHDL的编程.以下是转自360doc的教程: ———————————————————————————— ...
- vhdl基础---分频
偶数分频 ibrary IEEE; use IEEE.STD_LOGIC_1164.ALL; use ieee.std_logic_arith; use ieee.std_logic_unsigned ...
- VHDL TestBench基础(转)
TestBench的主要目标是: 实例化DUT-Design Under Test 为DUT产生激励波形 产生参考输出,并将DUT的输出与参考输出进行比较 提供测试通过或失败的指示 TestBench ...
- 1.ARM的基础知识
ARM简述 ARM公司既不生产芯片也不销售芯片,它只出售芯片技术授权.ARM技术具有很高的性能和功效,因而容易被厂商接受.同时,合作伙伴的增多,可获得更多的第三方工具.制造和软件支持,这又会使整个系统 ...
- 如何学习FPGA?FPGA学习必备的基础知识
如何学习FPGA?FPGA学习必备的基础知识 时间:2013-08-12 来源:eepw 作者: 关键字:FPGA 基础知识 FPGA已成为现今的技术热点之一,无论学生还是工程师都希望 ...
- 用C写一个web服务器(一) 基础功能
.container { margin-right: auto; margin-left: auto; padding-left: 15px; padding-right: 15px } .conta ...
- FPGA基础知识了解
FPGA学习的一些误区 FPGA入门必看资源 FPGA百度百科 FPGA基础知识及其工作原理 高端设计工具为少有甚是没有硬件设计技术的工程师和科学家提供现场可编程门阵列(FPGA).无论你使用图形化设 ...
- java基础数据类型包装类
*/ .hljs { display: block; overflow-x: auto; padding: 0.5em; color: #333; background: #f8f8f8; } .hl ...
随机推荐
- C#中静态构造函数
静态构造函数用于初始化任何静态数据,或执行仅需执行一次的特定操作. 将在创建第一个实例或引用任何静态成员之前自动调用静态构造函数. 静态构造函数的属性 1. 静态构造函数不使用访问修饰符或不具有参数. ...
- php中时间转换函数
date("Y-m-d H:i",$unixtime) 1.php中获得今天零点的时间戳 要获得零点的unix时间戳,可以使用 $todaytime=strtotime(“tod ...
- Mysql: Specified key was too long; max key length is 1000 bytes
在使用quartz持久化的时候,笔者使用的mysql,为了以后方便迁移数据,笔者的Mysql默认引擎MyISAM 于是顺理成章的执行了quartz-2.2.3\docs\dbTables\tables ...
- Exploring the world of Android :: Part 1
This blog is accidentally find out, it tells the story of one of our friends about the exploration o ...
- CSS-calc 兼容写法
width: 90%;/*写给不支持calc()的浏览器*/ width:-moz-calc(100% - (10px + 5px) * 2); width:-webkit-calc(100% - ( ...
- You have more than one version of ‘org.apache.commons.logging.Log’ visible, which is not allowed问题解决
https://zeroturnaround.com/forums/topic/jrebel-reports-more-than-one-version-of-org-apache-commons-l ...
- 在nodejs里面是用类似配置文件的方法
1.a.js exports.MYSQLIP = '127.0.0.1'; exports.MYSQLPORT = 1336; 2.b.js const C = require('./config/c ...
- 利用七牛存储7天远程自动备份LINUX服务器
受服务器空间制约,我们不可能在VPS上每天都备份一份新的网站数据,一是没必要,二是占空间.我们折中一下,采用星期命名,每次备份将覆盖上星期同一天的文件.从而只备份7份数据,不至于占用特别大的空间. 如 ...
- ksort排序的依据是什么
ksort:升序 asort:降序
- Netty 源码 ChannelHandler(三)概述
Netty 源码 ChannelHandler(三)概述 Netty 系列目录(https://www.cnblogs.com/binarylei/p/10117436.html) 一.Channel ...