VHDL全名Very-High-Speed Integrated Circuit Hardware Description Language ,是一种标准硬件描述语言。下面通过60进制计数器来分析VHDL的语法,以及一些硬件设计的理解。

60进制计数器,顾名思义,是每60个时间单位输出一个脉冲信号。60进制可以利用小于60进制的计数器的累加来达成相应的功能。主要有以下两种思路:

一种是直接其中的一个计数器通过时钟型号累加,另一个则是接受第一个计数器的进位信号,而进行加法计数。他们共用一个时钟信号,为并行进位。

一种是高位计数器的时钟连着低位计数器的进位信号,从而进行增加。

这里取第二种思路,通过一个10进制的计数器和一个6进制的计数器来实现60进制计数器。

顶层图如下



下面我们用VHDL语言来实现。

首先是6进制计数器。

注意!!器件最好不要以数字作为开头

library ieee;
use ieee.std_logic_1164.all;
use ieee.std_logic_unsigned.all;

这部分是库的声明。1164库中包括了大部分标准的类型,器件。

而unsigned中则包括了如加法等器件。

entity counter_6 is
port(
clk,clrn,en:in std_logic;
dout:out std_logic_vector (3 downto 0);
cout:out std_logic);
end counter_6;

这部分为这个文件所描述的总器件端口的声明,类似编程中主函数的声明。

architecture counter_6_arch of counter_6 is

这下面就是器件内部的描述内容、类似编程中的主函数实现。

signal douti:std_logic_vector (3 downto 0);
begin
process(en,clk,clrn,en)
begin
if clrn = '0' then
douti <= "0000";
elsif clk'event and clk = '1' and en = '1' then
if douti < 5 then
douti <= douti+1;
else douti <= "0000";
end if;
end if; if douti = 5 then
cout <= '1';
else cout <= '0';
end if;
dout <= douti;
end process;
end counter_6_arch;

十进制的计数器和六进制的类似,代码如下。

library ieee;
use ieee.std_logic_1164.all;
use ieee.std_logic_unsigned.all; entity counter_10 is
port(
clk,clrn,en:in std_logic;
dout:out std_logic_vector (3 downto 0);
cout:out std_logic);
end counter_10; architecture counter_10_arch of counter_10 is
signal douti:std_logic_vector (3 downto 0);
begin
process(en,clk,clrn,en)
begin
if clrn = '0' then
douti <= "0000";
elsif clk'event and clk = '1' and en = '1' then
if douti < 9 then
douti <= douti+1;
else douti <= "0000";
end if;
end if; if douti = 9 then
cout <= '1';
else cout <= '0';
end if;
dout <= douti;
end process;
end counter_10_arch;

将以上两个进制计数器编写完成后,复制到总工程目录下,开始编写上面顶层图所描述的内容。

这部分代码与之前的类似

library ieee;
use ieee.std_logic_1164.all;
use ieee.std_logic_unsigned.all;
use ieee.std_logic_arith.all; entity counter_60 is
port(
CLK,EN,CLRN:in std_logic;
tens_digit:out std_logic_vector(3 downto 0);
single_digit:out std_logic_vector(3 downto 0);
cout:out std_logic);
end counter_60; architecture rout1 of counter_60 is

这里就是对包含的器件进行声明了。其中包含哪些端口,是那种类型的数据,要和之前的命名的一样。

这里的d触发器直接调用系统提供的了,记得导包。可以自己用VHDL写一个或者定制一个,然后把VHD文件粘贴到本工程下面引用。

类似编程中间对引用的函数的声明。

component counter_10 is
port(
clk,en,clrn:in std_logic;
dout:out std_logic_vector(3 downto 0);
cout:out std_logic);
end component;
component counter_6 is
port(
clk,en,clrn:in std_logic;
dout:out std_logic_vector(3 downto 0);
cout:out std_logic);
end component; component dff is
port(
clk,d,clrn:in std_logic;
q:out std_logic);
end component; signal tens_wire,single_wire: std_logic_vector(3 downto 0);
signal cout_10,cout_6: std_logic;
signal dff_out: std_logic; begin
ctr10 : counter_10 port map(clk=>CLK,en=>EN,clrn=>CLRN,dout=>single_wire,cout=>cout_10);

这里就是对线路的说明了,之前定义了好多线,在这里连上即可。

类似实例化上面引用的函数。格式如下:

实例化后器件的名字:要实现的器件名 port map (port名=>接上的线或端口,port名=>接上的线或端口,…);

    my_dff : dff port map(d=>cout_10,clk=>CLK,clrn=>CLRN,q=>dff_out);
ctr6 : counter_6 port map(clk=>dff_out,en=>EN,clrn=>CLRN,dout=>tens_wire,cout=>cout_6);
tens_digit<=tens_wire;
single_digit<=single_wire;
cout<= cout_10 and cout_6;
end rout1;

可以生成RTL看看对不对



这是总器件的图



这是10进制加法器的图

最后自己愉快的仿真下就好了。

敲了有一阵VHDL的代码了,下面是一些杂七杂八的东西。

首先,所有语言都是通的,VHDL其实和一些面向过程的语言非常类似,而且最后打包成黑箱,还可以直接实例化调用,有些面向对象的感觉了。最先开始比较喜欢利用顶层图直接设计,比较直观,但是当工程复杂起来,VHDL的优势就显现出来了。强逻辑性,无需了解细节上面的电路实现,还有比较灵活的模块关系。

VHDL还有几种实现方式,一种是类似上面,把目标分成模块,一个模块一个模块的实现,最后把东西连起来达到最终目的。另一种就是直接列出真值表,利用when else 直接根据输入,输出相应结果。最后一种是数据流描述,说直白点,就是类似面向过程的编程,有一定的逻辑语句和处理。以上几种方式组合起来,根据不同的设计要求,利用合适的方式完成就好了。

VHDL学习记录的更多相关文章

  1. Quartz 学习记录1

    原因 公司有一些批量定时任务可能需要在夜间执行,用的是quartz和spring batch两个框架.quartz是个定时任务框架,spring batch是个批处理框架. 虽然我自己的小玩意儿平时不 ...

  2. Java 静态内部类与非静态内部类 学习记录.

    目的 为什么会有这篇文章呢,是因为我在学习各种框架的时候发现很多框架都用到了这些内部类的小技巧,虽然我平时写代码的时候基本不用,但是看别人代码的话至少要了解基本知识吧,另外到底内部类应该应用在哪些场合 ...

  3. Apache Shiro 学习记录4

    今天看了教程的第三章...是关于授权的......和以前一样.....自己也研究了下....我觉得看那篇教程怎么说呢.....总体上是为数不多的精品教程了吧....但是有些地方确实是讲的太少了.... ...

  4. UWP学习记录12-应用到应用的通信

    UWP学习记录12-应用到应用的通信 1.应用间通信 “共享”合约是用户可以在应用之间快速交换数据的一种方式. 例如,用户可能希望使用社交网络应用与其好友共享网页,或者将链接保存在笔记应用中以供日后参 ...

  5. UWP学习记录11-设计和UI

    UWP学习记录11-设计和UI 1.输入和设备 通用 Windows 平台 (UWP) 中的用户交互组合了输入和输出源(例如鼠标.键盘.笔.触摸.触摸板.语音.Cortana.控制器.手势.注视等)以 ...

  6. UWP学习记录10-设计和UI之控件和模式7

    UWP学习记录10-设计和UI之控件和模式7 1.导航控件 Hub,中心控件,利用它你可以将应用内容整理到不同但又相关的区域或类别中. 中心的各个区域可按首选顺序遍历,并且可用作更具体体验的起始点. ...

  7. UWP学习记录9-设计和UI之控件和模式6

    UWP学习记录9-设计和UI之控件和模式6 1.图形和墨迹 InkCanvas是接收和显示墨迹笔划的控件,是新增的比较复杂的控件,这里先不深入. 而形状(Shape)则是可以显示的各种保留模式图形对象 ...

  8. UWP学习记录8-设计和UI之控件和模式5

    UWP学习记录8-设计和UI之控件和模式5 1.日历.日期和时间控件 日期和时间控件提供了标准的本地化方法,可供用户在应用中查看并设置日期和时间值. 有四个日期和时间控件可供选择,选择的依据如下: 日 ...

  9. UWP学习记录7-设计和UI之控件和模式4

    UWP学习记录7-设计和UI之控件和模式4 1.翻转视图 使用翻转视图浏览集合中的图像或其他项目(例如相册中的照片或产品详细信息页中的项目),一次显示一个项目. 对于触摸设备,轻扫某个项将在整个集合中 ...

随机推荐

  1. matplotlib实现数据可视化

    一篇matplotlib库的学习博文.matplotlib对于数据可视化非常重要,它完全封装了MatLab的所有API,在python的环境下和Python的语法一起使用更是相得益彰. 一.库的安装和 ...

  2. 【我的漫漫跨考路】数据结构之单链表线性存储实现 Beta

    正文之前 昨天晚上阶段性的完成了一部分数学的复习,所以今天打算撸一撸代码,然后发现提电脑忘指针.所以自己磕磕盼盼,对照了一下网上的代码,总算把线性存储单链表的数据类型实现,给自己写出来了. 废话不多说 ...

  3. MySQL 6.0安装图解

    MySQL 6.0安装图解 由于免费,MySQL数据库在项目中用的越来越广泛,而且它的安全性能也特别高,不亚于oracle这样的大型数据库软件.可以简单的说,在一些中小型的项目中,使用MySQL ,P ...

  4. 细说 Java 的深拷贝和浅拷贝

    版权声明: 本账号发布文章均来自公众号,承香墨影(cxmyDev),版权归承香墨影所有. 未经允许,不得转载. 一.前言 任何变成语言中,其实都有浅拷贝和深拷贝的概念,Java 中也不例外.在对一个现 ...

  5. Java String字符串深入详解

    Java中字符串对象创建有两种形式,一种为字面量形式,如String str = "hello";,另一种就是使用new这种标准的构造对象的方法,如String str = new ...

  6. 【IP限制】验证是否限制了境外IP访问权限

    为啥要限制境外IP访问咱们的网站或者服务呢?怕泄漏了"机密"(好像都是我们在山寨别人,哪儿TM有机密,那叫"鸡贼") 好像国外的网站也没有限制咱大陆客去访问,反 ...

  7. $($('.className').html( )选择器的工作原理

    $($('.slot')[0]).html('<img src = "' + images[slotOne-1] + '">');

  8. shell /bin/bash^M: bad interpreter错误解决

      错误原因之一很有可能是你的脚本文件是DOS格式的, 即每一行的行尾以\r\n来标识, 其ASCII码分别是0x0D, 0x0A.可以有很多种办法看这个文件是DOS格式的还是UNIX格式的, 还是M ...

  9. .Net,Dll扫盲篇,如何在VS中调试已经编译好的dll?

    什么是Dll? DLL 是一个包含可由多个程序同时使用的代码和数据的库. 例如,在 Windows 操作系统中,Comdlg32 DLL 执行与对话框有关的常见函数.因此,每个程序都可以使用该Dll中 ...

  10. java多线程系列(八)---CountDownLatch和CyclicBarrie

    CountDownLatch 前言:如有不正确的地方,还望指正. 目录 认识cpu.核心与线程 java多线程系列(一)之java多线程技能 java多线程系列(二)之对象变量的并发访问 java多线 ...