8位高速微控制器IP软核的设计与实现

发布者:科技舞者最新更新时间:2007-04-12 来源: 电子技术应用关键字:指令  周期  寄存  通道 手机看文章 扫描二维码
随时随地手机看文章

引言

随着集成电路设计的不断发展,集成电路的规模越来越大,设计难度日趋复杂,传统的设计方法已越不能适应集成电路设计发展的需要。基于IP复用的数字IC设计方法是有效提高IC设计产能的关键技术,有助于快速实现工艺先进、功能强大的产品。

微控制器MCU是嵌入式系统的核心,8位MCU IP核具有很高的通用性和灵活性,广泛地应用于工业控制、机械设备、家用电器以及汽车电子等各个领域。本文介绍的是基于 RISC体系结构的8位高速MCUIP软核的设计与实现,采用Verilog HDL自上而下地描述了MCUIP软核的硬件结构,并验证了设计的可行性和正确性。在实际硬件电路中,该IP核的运行频率达到75MHz,可应用于高速控制领域。

系统结构设计

本设计的总线采用了哈佛结构,14位指令字长,8位数据字长,指令集与PIC16F676兼容。它具有35条指令,在连续工作的情况下,除了程序跳转指令要用2个指令周期外,其它的所有指令都可以在1个指令周期内完成。由于哈佛结构总线具有独立的指令总线和数据总线,可同时从程序存储器和数据存储器中分别读取数据,大大提高了MCU内部执行的并行性,简化了控制电路的设计。与更深级流水线相比,简单的指令周期避免了深度流水线增加电路结构复杂性和芯片面积。

该微处理器在结构上可以划分为四个子系统,分别为控制单元、数据通道、存储单元、I/O单元。其中数据通道包含ALU和一个W工作寄存器。片内程序存储器ROM的容量是8k×14位;数据存储器由包括专用寄存器在内的256个可寻址的8位寄存器组成,通过数据总线与算术逻辑单元ALU相连,系统可以对数据存储器用直接或间接寻址方式进行访问。I/O单元提供了系统内部的数据总线与外界总线的连接接口,实现数据的输入/输出。控制单元则会根据指令产生相应的指示信号控制系统的协调运行。系统结构如图1所示。


MCU IP核的时序设计

时钟网络的时序设计

本设计的时序设计部分采用内部包含4个节拍时钟的结构,时钟网络模块在复位结束后会利用两级嵌套的D触发器将外部时钟(CLK)分频产生4个非重叠正交的节拍时钟信号q1、q2、q3、q4,一个指令周期分为4个状态。节拍时钟会与译码电路产生的控制信号配合,在不同时钟节拍选通不同的电路操作,进而协调整个系统的运行。

二级流水线时序设计

本设计所采用的二级流水线划分为取指和执行两级。系统运行时,会在前一指令周期的q4节拍从ROM中取出下一条待执行的指令并锁存在指令寄存器中,在下一指令周期的q1节拍从指令寄存器中取出指令,同时程序计数器(PC)加1,q2到q4对所取指令进行译码和执行。因此,一条指令的完整执行过程大概分为取指令、指令锁存、指令译码、取操作数、执行、回写、PC+1等7个步骤。从时序上看,指令取指周期与执行周期是并行执行的,即在取指的同时,上一条指令正在进入执行周期。

程序跳转指令与其它单周期指令一样进入流水线,在执行程序跳转指令时,屏蔽下一条指令进入指令译码单元,用空操作指令NOP代替。这样,控制逻辑不需要做太大修改就能满足流水线的执行。二级指令流水线操作过程如图2所示。

MCU IP核的内部电路实现

指令寄存器

指令寄存器(IR)是为了实现两级指令流水线而设计的。如果没有指令寄存器,那么取指和执行就分别需要占用一个指令周期。但如果利用IR,在上条指令执行的同时把下一条指令从程序存储器ROM中取出来寄存在IR中,这样在每个指令周期内同时有指令的取出和执行,等效来看,一条指令只需要一个指令周期就可以执行完毕,从而提高了效率。

指令寄存器IR的另外一个功能是当执行分支指令的时候产生空操作,这是采用指令流水线结构所必需的。例如在执行程序跳转指令GOTO的时候,由于GOTO指令会改变程序计数器PC的值,跳转到另外的地址,那么在执行GOTO指令时取得的紧接GOTO的下一条指令就不是要执行的下一条指令,这个已经取得的指令就必须被屏蔽。具体的操作是在执行GOTO指令的时候,指令译码单元产生清零信号使得指令寄存器内部14位寄存单元被清零,那么下一指令周期的输出就变为NOP指令。在执行该空操作的同时把GOTO指令跳转后指向地址对应的指令取出来,在下个指令周期执行。

指令译码单元

指令译码单元在每个时钟周期的q1节拍接收来自IR的14位执行指令,并对指令进行译码工作,给出其它各单元的操作控制信号,包括算术逻辑单元(ALU)的运算控制信号、RAM的读写控制、总线控制器的选择信号、PC寻址等。

算术逻辑单元

算术逻辑单元(ALU)是微控制器运算电路的核心部分,主要功能是按照指令译码器输出的控制信号,实现算术运算、逻辑运算、循环移位等操作。ALU的字宽是8位,在ALU中做运算的2个操作数分别来自W寄存器和数据总线,最后运算的结果由指令译码后的控制信号决定是存放在W寄存器中,还是通用寄存器RAM中。本文通过将加、减操作复用到一个8位超前进位加法器,大大缩短了ALU算术运算的时间,进而提高了整个系统的运行速度。

程序计数器和堆栈

13位的PC对8k×14bit的ROM进行寻址,八级堆栈存储的是ROM的地址,即在主程序中调用的子程序最多允许嵌套8次。当系统复位后PC从0000h地址开始执行,然后在每个指令周期q1节拍,PC自动加1。当执行GOTO指令时,就从指令中获取地址来改变PC的值,然后PC再在此基础上自动加1,顺序执行指令。当执行调用子程序指令CALL指令时,把取指的地址送到堆栈保护起来,然后PC装载子程序入口的地址,接着顺序执行子程序指令直到子程序执行完,程序返回时把堆栈中的地址装载到PC,PC继续自动加1顺序执行指令。

在每个时钟周期,PC会检测是否有来自中断处理单元的中断请求信号发生,一旦有中断响应,PC就会进入中断处理模式,把中断现场的地址送入堆栈保护起来,并在下一指令周期PC指向中断向量地址0004h,这是中断服务程序的入口地址,系统执行中断服务程序直到中断返回,再把保护在堆栈的中断现场地址加载到PC中,然后又顺序执行指令。

定时器/计数器

TIMER0为8位可读写的定时器/计数器单元,其内部有一个分频器,可以通过寄存器配置选择定时或计数工作方式,以及分频器的分频比,分频比最高可达l:128。当TIMER0从FFh到00h计数溢出时,将产生TIMER0中断。

中断处理单元

中断处理单元会响应各个中断源的中断,并向系统的控制电路发出总中断请求信号。该单元设置有8位中断控制寄存器和外设中断寄存器,使用标志位来记录各种中断请求。中断控制寄存器还包括各中断的使能控制位以及全局中断使能位。全局中断使能位将使能(置1时)所有未被屏蔽的中断,或禁止(清零时)所有中断。一旦进入中断服务程序,可通过查询中断标志位确定中断源。

双向I/O

PORTA和PORTC为2个6位双向I/O端口,每个端口有2个物理寄存器,分别是方向寄存器和数据寄存器。方向寄存器控制对应端口的输入/输出属性,数据寄存器负责锁存输入/输出数据。

MCU IP核的硬件仿真

IP软核的仿真测试是设计过程中非常重要的环节,通过自主建立的测试向量库,编写了覆盖所有指令的测试文件,对软核的多种指令、地址和数据组合进行了仿真测试,提高了软核功能仿真的测试覆盖率,保证了设计的正确性。由PORTA和PORTC的输出来验证设计正确性。部分信号波形如图3所示,在正常情况下,地址是在每个指令周期进行加1取指的;当中断信号int_req=1时,地址在下一指令周期跳到中断向量地址0004h,同时屏蔽下一条指令进入指令译码单元,用NOP指令代替。

结语

本文介绍了一个8位RISC结构的高速微控制器IP软核的设计,其指令集与PIC16F676兼容,采用模块化结构,面向硬件映射,保证可综合性。该核使用VerilogHDL为RTL级描述语言,通过了ActiveHDL仿真验证后,用Quartus II 5.0进行综合,并在Altera的EP1C12Q24C08器件上实现了布局布线。经测试,时钟频率达到了75MHz,验证了设计的正确性,为今后的设计积累了大量有益的经验。

关键字:指令  周期  寄存  通道 引用地址:8位高速微控制器IP软核的设计与实现

上一篇:使用MAXQ3210作为微处理器监控电路
下一篇:基于NiosII的SOPC多处理器系统设计方法

推荐阅读最新更新时间:2024-05-13 18:35

凌力尔特推出具内部基准的16位4通道SPI接口DAC
    凌力尔特公司 (Linear Technology Corporation) 推出 4 通道电压输出 16 位和 12 位数模转换器 (DAC) 系列 LTC2654,该器件具内部基准和 SPI 接口。在整个温度范围内,LTC2654 DAC 实现了 INL 最大值为 ±4LSB 的 16 位性能,该性能比最接近和具内部基准的同类 16 位 4 通道产品好两倍。LTC2654 具有 ±2mV (最大值) 的最低失调误差和 0.1% (最大值) 的最低增益误差,二者结合可确保 LTC2654 在靠近电源轨时保持准确,并为用户提供更宽的有效输出范围。LTC2654 准确的性能规格使其非常适用于多通道、开环和闭环系统。应用包括移
[模拟电子]
STM32F10X ADC多通道读取小教程(包含DMA)
前沿: ADC采样,说白了就是采集电压,这个功能是极其重要的,通常的我们的都是对各种传感器采集电压,来进行判断,开环闭环控制,今天,向大家介绍ADC的多通道采样,和DMA的采样方式。DMA的采样方式,可有效节省CMU在ADC的运行时间,提高效率,尤其是在系统构建的时候,必须要考虑好,你的效率问题。 这里我用的开发板时正点原子的MiniSTM32,芯片型号为STM32F103RCT6. This is easy, so you can do that very easily! view plain copy ***REMENBER STM32 is you! :) 我们在这里进行通俗的讲解,详细的内容,可以在以后再去看
[单片机]
STM32F10X ADC多<font color='red'>通道</font>读取小教程(包含DMA)
通道控制设计的双余度DSP解决方案
通道控制设计的双余度DSP解决方案 具有自动控制功能的电子设备已广泛应用于我国多型机上,用于飞机上各机载设备的控制、调节等功能。如图1所示,其控制系统主要由传感器信号输入、核心控制板及经过处理驱动后的控制信号输出,最后输出到机上的具体应用。本文将主要介绍如何利用通道复用技术设计实现具有双余度DSP的控制板部件,重点描述如何实现系统的双余度DSP设计、双DSP间如何通讯以及DSP的故障判定法则等。   控制板硬件设计   控制板的硬件框图如图2所示,主要由外部信息采集单元、双余度DSP模块、应用处理及其输出单元等组成。其中,双余度单元的CPU选用16位定点DSP TMS320LF2407A,其运行最高速率可达40
[嵌入式]
<font color='red'>通道</font>控制设计的双余度DSP解决方案
LPC2148的ADC多通道数据采集程序
#include config.h #include stdio.h #define GPIOSET(PIN) IO0SET = PIN // 方便修改置位端口 #define GPIOCLR(PIN) IO0CLR = PIN // 方便修改清位端口 #define LCD_CON 0x00000250 // 液晶显示控制字 #define E_CLK (1 4) //clock input 同步时钟输入端 P0.4 const uint32 RW_SID= (1 6); //data input/output 串行数据输入、输出端 P0.6
[单片机]
ARM GNU 汇编伪指令简介
一.什么是汇编伪指令 汇编指令语句 每一条指令语句在源程序汇编时都要产生可供计算机执行的指令代码(即目标代码),所以这种语句又叫可执行语句。每一条指令语句表示计算机具有的一个基本能力,如数据传送,两数相加或相减,移位等,而这种能力是在目标程序(指令代码的有序集合)运行时完成的,是依赖于汁算机内的中央处理器(CPU)、存储器、I/O接口等硬件设备来实现的。 汇编伪指令语句 伪指令语句是用于指示汇编程序如何汇编源程序,所以这种语句又叫命令语句。例如源程序中的伪指令语句告诉汇编程序:该源程序如何分段,有哪些逻辑段在程序段中哪些是当前段,它们分别由哪个段寄存器指向;定义了哪些数据,存储单元是如何分配的等等。伪指令语句除定义的具体数
[单片机]
吉时利最新系统开关提供高通道数信号、符合LXI B和集成DMM
美国俄亥俄州克利夫兰市2007年9月17日讯 ——新兴测量需求解决方案的领导者吉时利仪器公司(NYSE:KEI),今日发布了其3700系列系统开关/万用表和插卡系列产品,这是吉时利基于新一代平台的开关和集成数字万用表(DMM)测试解决方案。该产品实现了高品质、仪器级的开关功能,适用于包括需要大量通道的高性能应用在内的多种应用领域,可控制多达576个多路复用通道,外形尺寸采用业界领先的六槽、2U风格。其高性能的集成DMM选件具有快速、低噪声的测量能力,分辨率高达七位半,而价格却低于普通六位半的DMM设备。若想了解关于3700系列产品更详细的信息并观看产品演示短片,敬请点击 www.keithley.com/pr/076 . 3700
[新品]
风河以安全设备生命周期管理推进工业物联网
电子网消息,工业物联网(IIoT)要为客户带来价值,就必须实现设备互联,并且将其置于严格的监控与管理之下。为了确保这些设备的安全性、功能性以及性能都处于尽可能高的水平上,设备管理功能应该从一开始就被当作物联网系统体系结构设计中的内在组成部分,因为它既是当今物联网部署中的关键性推动要素,又是性命攸关的组件。 据IDC统计,目前85%的嵌入式工业设备尚不具备互联性。可见,目前只有一小部分的市场从工业物联网中受益。为了推进工业物联网,在整个生态系统中还有大量的工作要做。其中,有些设备已经在应用系统中工作了很长一段时间,而当初并没有包含支持物联网方面的设计。为这些从传统中继承下来的设备赋予互联性,本身就是一项巨大的工程,同时也意味着他
[网络通信]
80C51单片机实现专用寄存器位寻址的设计方案
80C51单片机有位处理功能,可以对数据位进行操作,因此就有相应的位寻址方式。所谓位寻址,就是对内部RAM或可位寻址的特殊功能寄存器SFR内的某个位,直接加以置位为1或复位为0。 位寻址的范围,也就是哪些部份可以进行位寻址: 1、我们在第十二课学习51单片机的存储器结构时,我们已知道在单片机的内部数据存储器RAM的低128单元中有一个区域叫位寻址区。它的单元地址是20H-2FH。共有16个单元,一个单元是8位,所以位寻址区共有128位。这128位都单独有一个位地址,其位地址的名字就是00H-7FH。 这里就有一个比较麻烦的问题需要大家理解清楚了。我们在前面的学习中00H、01H。。。。7FH等等,所表示的都是一个字节(或者
[单片机]
80C51单片机实现专用<font color='red'>寄存</font>器位寻址的设计方案
小广播
最新应用文章
换一换 更多 相关热搜器件

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

站点相关: 安防电子 医疗电子 工业控制

词云: 1 2 3 4 5 6 7 8 9 10

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

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