当前位置:文档之家› 简单微处理器的设计

简单微处理器的设计

简单微处理器的设计摘要:本课程设计采用EDA技术设计简单微处理器。

系统设计采用自顶向下的设计方法。

它由数的输入,数的比较,数的交换和结果输出四部分组成。

系统实现采用硬件描述语言VHDL把系统电路按模块化方式进行设计,然后进行编程、时序仿真并分析。

系统结构简单,使用方便,功能齐全,精度高,具有一定的应用价值。

关键词:处理器;输入;比较;交换目录1 引言 (1)1.1课题设计的背景、目的 (1)1.2 课程设计的内容 (1)2 EDA、VHDL简介 (2)2.1 EDA简介 (2)2.2 VHDL简介 (2)VHDL语言的特点 (2)VHDL的设计流程 (3)3 简单微处理器的设计过程 (4)3.1设计规划 (4)3.2 各模块设计及相应程序 (4)4 系统仿真 (8)1.数的输入. (8)2 数的比较。

(8)3 交换两个数。

(9)4 结果输出(从小到大). (9)结束语 (11)致谢 (12)参考文献 (13)附录 (14)1 引言随着社会的发展,科学技术也在不断的进步。

特别是计算机产业,可以说是日新月异,而处理器,作为计算机中的一个重要部分,其性能从很大程度上决定了计算机的性能。

本设计介绍的简单微处理器,要求具有以下验证程序所要求的功能:输入包含10个整数(无符号数)的数组M,按从小到大的顺序输出这10个数。

1.1课题设计的背景、目的微处理器技术的发展是与微电子技术即大规模集成电路技术的发展分不开的。

微电子技术以每18个月集成度提高一倍的速度迅速发展。

20世纪80年代初,主要是16位微处理器8086/8088。

1985年推出了80386微处理器,完成了16位体系结构向32位体系结构的转变。

1989年80486出现了。

80486的设计目标是提高指令执行速度和支持多处理器系统。

80486在芯片内部增加一个8KB的高速缓冲存储器(cache),还增加了相当于80387的浮点部件(FPU),在基本指令的实现上,采用硬布线逻辑而不是微程序技术。

1993年3月,Intel公司推出了第一代“奔腾”微处理器(Pentium),微处理器技术发展进入了一个新的阶段。

到目前为止,“奔腾”已有四代产品。

“奔腾”的设计思想是把如何提高微处理器内部指令执行的并行性作为主导。

指令执行的并行性越好,微处理器的性能就越高。

本次设计的目的就是了解并掌握VHDL硬件描述语言的设计方法和思想,通过学习的VHDL语言结合电子电路的设计知识理论联系实际,掌握所学的课程知识,学习VHDL基本单元电路的综合设计应用。

通过对实用电子称的设计,巩固和综合运用所学课程,理论联系实际,提高IC设计能力,提高分析、解决计算机技术实际问题的独立工作能力。

通过课程设计深入理解VHDL语言的精髓,达到课程设计的目标。

1.2 课程设计的内容本设计主要介绍的设计一台简单微处理器,要求具有以下验证程序所要求的功能:输入包含10个整数(无符号数)的数组M,按从小到大的顺序输出这10个数。

( 1 )程序开始及输入10个数据。

( 2 )数的比较。

( 3 )交换两个数。

( 4 )结果输出(从小到大)。

2 EDA、VHDL简介2.1 EDA简介EDA是Electronic Design Automation(电子设计自动化)的缩写,EDA技术是20世纪90年代初以来迅速发展起来的现代电子工程领域的一门新技术。

它可以编程逻辑器件(PLD)为载体,以计算机为工作平台,以EDA工具软件为开发环境,以硬件描述语言(HDL)作为电子系统功能描述方式,以电子系统设计为应用方向的电子产品自动化设计过程。

2.2VHDL简介VHDL的英文全名是Very-High-Speed Integrated Circuit HardwareDescription Language,诞生于1982年。

1987年底,VHDL被IEEE和美国国防部确认为标准硬件描述语言。

自IEEE公布了VHDL的标准版本,IEEE-1076(简称87版)之后,各EDA公司相继推出了自己的VHDL设计环境,或宣布自己的设计工具可以和VHDL接口。

此后VHDL 在电子设计领域得到了广泛的接受,并逐步取代了原有的非标准的硬件描述语言。

1993年,IEEE对VHDL进行了修订,从更高的抽象层次和系统描述能力上扩展VHDL的内容,公布了新版本的VHDL,即IEEE标准的1076-1993版本,(简称93版)。

现在,VHDL和Verilog作为IEEE的工业标准硬件描述语言,又得到众多EDA公司的支持,在电子工程领域,已成为事实上的通用硬件描述语言。

有专家认为,在新的世纪中,VHDL于Verilog 语言将承担起大部分的数字系统设计任务。

2.3VHDL语言的特点VHDL的程序结构特点是将一项工程设计,或称设计实体(可以是一个元件,一个电路模块或一个系统)分成外部(或称可是部分,及端口)和内部(或称不可视部分),既涉及实体的内部功能和算法完成部分。

在对一个设计实体定义了外部界面后,一旦其内部开发完成后,其他的设计就可以直接调用这个实体。

这种将设计实体分成内外部分的概念是VHDL系统设计的基本点。

应用VHDL进行工程设计的优点是多方面的。

(1)与其他的硬件描述语言相比,VHDL具有更强的行为描述能力,从而决定了他成为系统设计领域最佳的硬件描述语言。

强大的行为描述能力是避开具体的器件结构,从逻辑行为上描述和设计大规模电子系统的重要保证。

(2)VHDL丰富的仿真语句和库函数,使得在任何大系统的设计早期就能查验设计系统的功能可行性,随时可对设计进行仿真模拟。

(3)VHDL语句的行为描述能力和程序结构决定了他具有支持大规模设计的分解和已有设计的再利用功能。

符合市场需求的大规模系统高效,高速的完成必须有多人甚至多个代发组共同并行工作才能实现。

(4)对于用VHDL完成的一个确定的设计,可以利用EDA工具进行逻辑综合和优化,并自动的把VHDL描述设计转变成门级网表。

(5)VHDL对设计的描述具有相对独立性,设计者可以不懂硬件的结构,也不必管理最终设计实现的目标器件是什么,而进行独立的设计。

2.4VHDL的设计流程它主要包括以下几个步骤:1.设计规范的定义这个有点象系统的设计的总体规划,就是要明确这个系统有哪些设计要求,和你要想到达的目标。

2.采用VHDL进行设计描述这部分包括设计规划和程序的编写。

设计规划主要包括设计方式的选择及是否进行模块划分。

设计方式一般包括直接设计,自顶向下和自底向下设计,这个和其他软件语言差不多。

最重要还是模块划分,这个和设计者的设计水平有很大关系。

完成规划设计后,就可以编写个模块的VHDL程序了,最后将各模块的VHDL程序综合起来就完成了整个设计的VHDL描述.3.VHDL程序仿真这个过程和其他软件语言没什么区别。

4.综合、优化和布局布线综合指的是将设计描述转化成底层电路的表示形式,其结果是一个网表或者是一组逻辑方程;优化,这个主要是为了提高程序的执行效率及减少资源的利用;布局布线,指的是将逻辑关系转化成电路连接的方式。

5.后仿真。

这个与VHDL程序仿真不同,这个不仅是对逻辑方面的验证,还要进行时序功能验证。

6.器件编程3 简单微处理器的设计过程3.1设计规划计算器通过简单的数字键盘输入操作数,其中所键入的数据将被暂存在移位寄存器中,然后根据运算符执行产生不同的操作结果,所获得的运算结果再通过译码电路转移到七段显示器输出。

整个微处理器的工作原理图如图3.11所示。

图3.1 微处理器的工作原理图3.2 各模块设计及相应程序本系统设计了10条指令:IN1(输入到目的寄存器),MOV(将一个数送入目的寄存器),MOV1(将源寄存器中的数据存储到目的寄存器所指向的地址单元),MOV2(将源寄存器所指向的地址单元中的数送入目的寄存器), OUT1(输出),CMP(将目的寄存器和源寄存器所指向的地址单元中的数据进行比较),DEC(将目的寄存器中的数据自减一),INC(将目的寄存器中的数据自加一),JMP(无条件跳转),JB(小于跳转),下表列出了每条指令的格式、汇编符号和指令功能。

关键程序数的选择模块LIBRARY IEEE;USE IEEE.STD_LOGIC_1164.ALL;ENTITY MUX5 ISPORT(R0_B,R1_B,R2_B,R3_B,ALU_B:IN STD_LOGIC;R0_IN,R1_IN,R2_IN,R3_IN,ALU_IN:IN STD_LOGIC_VECTOR(7 DOWNTO 0);MUX5OUT:OUT STD_LOGIC_VECTOR(7 DOWNTO 0));END MUX5;ARCHITECTURE A OF MUX5 ISBEGINPROCESS(ALU_B,R3_B,R2_B,R1_B,R0_B)BEGINIF(ALU_B='1' AND R3_B='1' AND R2_B='1' AND R1_B='1' AND R0_B='0') THENMUX5OUT<=R0_IN;ELSIF(ALU_B='1' AND R3_B='1' AND R2_B='1' AND R1_B='0' AND R0_B='1') THEN MUX5OUT<=R1_IN;ELSIF(ALU_B='1' AND R3_B='1' AND R2_B='0' AND R1_B='1' AND R0_B='1') THEN MUX5OUT<=R2_IN;ELSIF(ALU_B='1' AND R3_B='0' AND R2_B='1' AND R1_B='1' AND R0_B='1') THEN MUX5OUT<=R3_IN;ELSIF(ALU_B='0' AND R3_B='1' AND R2_B='1' AND R1_B='1' AND R0_B='1') THEN MUX5OUT<=ALU_IN;ELSE MUX5OUT<=ALU_IN;END IF;END PROCESS;END A;LIBRARY IEEE;USE IEEE.STD_LOGIC_1164.ALL;ENTITY FEN2 ISPORT(MUX5_IN:IN STD_LOGIC_VECTOR(7 DOWNTO 0);LED_B,WR: IN STD_LOGIC;OUT_MUX3,OUT_PUT:OUT STD_LOGIC_VECTOR(7 DOWNTO 0));END FEN2;ARCHITECTURE A OF FEN2 ISBEGINPROCESS(LED_B)BEGINIF(LED_B='0' AND WR='0') THENOUT_PUT<=MUX5_IN;OUT_MUX3<="00000000";ELSEOUT_MUX3<=MUX5_IN;END IF;END PROCESS;END A;LIBRARY IEEE;USE IEEE.STD_LOGIC_1164.ALL;ENTITY MUX3 ISPORT(SW_B,CS:IN STD_LOGIC;FEN2_IN,MUX2_2IN,SW_IN:IN STD_LOGIC_VECTOR(7 DOWNTO 0);MUX3OUT:OUT STD_LOGIC_VECTOR(7 DOWNTO 0));END MUX3;ARCHITECTURE A OF MUX3 ISBEGINPROCESS(SW_B,CS)BEGINIF(SW_B='0' AND CS='1') THENMUX3OUT<=SW_IN;ELSIF(SW_B='1' AND CS='0') THENMUX3OUT<=MUX2_2IN;ELSIF(SW_B='0' AND CS='0') THENMUX3OUT<=FEN2_IN;ELSEMUX3OUT<="11101110";END IF;END PROCESS;END A;4 系统仿真4.1数的输入以下仿真波形图的测试输入为(34,15,25,92,17,06,83,68,72,87)。

相关主题