5178|2

7219

帖子

192

TA的资源

五彩晶圆(高级)

楼主
 

【Espier FPGA VHDL学习帖】第15帖 Integer学习 [复制链接]

【Espier FPGA VHDL学习帖】第15帖 Integer学习

1.integer 的取值可用符号的32位2进制数表示。



2.需要注意的是,VHDL仿真器将integer类型作为有符号数处理,而VHDL综合器则将integer作为无符号数处理。而且VHDL综合器要求必须使用rang子句为所定义的数限定范围,然后根据所限定的范围来确定此信号或变量的2进制的位数,因为VHDL综合器无法综合未限定范围的恶整数类型的信号和变量。
VHLD綜合器要求對具體的整數作出範圍限定,否則無法綜合成硬件電路。
如:signal s: integer range 0 to 15;
信號S的取值範圍0-15,可用4位二進制數表示,因此s將被綜合成由四條信號線構成的信號。



3.整数在表达式中不加引号,而逻辑数必须加引号,一位的加单引号,一位以上的加双引号。



4.natural,positive为integer的子类型


實例:
這裡用一個分頻器來做integer例子的分析。
程序如下:
  1. LIBRARY IEEE;
  2. USE IEEE.STD_LOGIC_1164.ALL;
  3. USE IEEE.STD_LOGIC_UNSIGNED.ALL;
  4. ENTITY LESSON2_WAIT IS
  5.          PORT(clk        : IN STD_LOGIC;
  6.              clk_div6    : OUT STD_LOGIC);
  7. END LESSON2_WAIT;
  8. ARCHITECTURE rtl OF LESSON2_WAIT IS
  9.       --SIGNAL count     : integer range 0 to 2;
  10.       --SIGNAL count: integer;
  11.       SIGNAL clk_temp : STD_LOGIC;
  12. BEGIN
  13.       PROCESS(clk)
  14.            variable count : integer range 0 to 2;
  15.       BEGIN        
  16.       IF (clk'event AND clk= '1')THEN
  17.          IF(count= 2 )THEN
  18.          count := 0;
  19.         clk_temp <=NOT clk_temp;
  20.             ELSE
  21.               count := count +1;
  22.             END IF;  
  23.              END IF;  
  24. END PROCESS;
  25.       clk_div6 <= clk_temp;
  26. END rtl;
复制代码
下面開始分析
(1)     SIGNALcount: integer;
用Quartus9.0進行仿真分析,自帶波形仿真軟件,用起來很方便~


(2)     SIGNALcount     : integer range 0 to 2;



可以看出:
       Integer如果不對具體的整數作出範圍限定,沒有輸出,可能就是上面所說的無法綜合成硬件電路。


Signal與Variable:
VARIABLE 是局部变量只能在进程和子程序中使用。不存在延时行为(仿真过程中共享变量例外)
SIGNAL类似连接线,SIGNAL做为一种数值容器,不但能容纳当前值,还能容纳历史值。这一点与触发器的记忆功能有很好的对应关系。除了没有方向以外,SIGNAL和实体的端口(PORT)概念是一致的。信号可以看成实体内部的端口
格式:
SIGNAL 信号名:数据类型:=初始值

(3)variable count : integer ;(注意放的位置)



(4)variable count : integer range 0 to 2;



[ 本帖最后由 常见泽1 于 2013-12-7 16:09 编辑 ]
此帖出自FPGA/CPLD论坛

最新回复

加油,常大哥,我一直在收看您的帖子,一起学习!!~  详情 回复 发表于 2013-12-17 22:31
点赞 关注
 

回复
举报

1

帖子

1

TA的资源

一粒金砂(初级)

沙发
 
加油,常大哥,我一直在收看您的帖子,一起学习!!~
此帖出自FPGA/CPLD论坛

点评

我也只是初学而已哦 可能会有很多讲错的地方 欢迎指正  详情 回复 发表于 2013-12-18 18:33
 
 

回复

7219

帖子

192

TA的资源

五彩晶圆(高级)

板凳
 

回复 沙发ironmax 的帖子

我也只是初学而已哦 可能会有很多讲错的地方 欢迎指正
此帖出自FPGA/CPLD论坛
 
 
 

回复
您需要登录后才可以回帖 登录 | 注册

查找数据手册?

EEWorld Datasheet 技术支持

相关文章 更多>>
关闭
站长推荐上一条 1/9 下一条

 
EEWorld订阅号

 
EEWorld服务号

 
汽车开发圈

About Us 关于我们 客户服务 联系方式 器件索引 网站地图 最新更新 手机版

站点相关: 国产芯 安防电子 汽车电子 手机便携 工业控制 家用电子 医疗电子 测试测量 网络通信 物联网

北京市海淀区中关村大街18号B座15层1530室 电话:(010)82350740 邮编:100190

电子工程世界版权所有 京B2-20211791 京ICP备10001474号-1 电信业务审批[2006]字第258号函 京公网安备 11010802033920号 Copyright © 2005-2025 EEWORLD.com.cn, Inc. All rights reserved
快速回复 返回顶部 返回列表