原创 简化的RISCCPU设计

2007-1-15 10:46 4745 10 10 分类: FPGA/CPLD

最近看了夏宇闻的算法设计到硬件的一本书,里面有一章介绍了简化的RISC CPU的设计,感觉对于理解CPU的设计还是很有帮助,当然这个的功能和实际的是相差十万八千里了,自己最近学习也不在状态,忙着论文呢,呵呵,结果学了一个星期,才有大体的了解,代码才刚编完,还没有进行综合仿真,等有时间再把自己综合后的图贴上来,下面这些只是有助于了较简化的CPU的基本组成结构,具体内容可见简化的“RISC CPU的设计”,里面有详细内容,有时间再把代码给贴上来,内容有点多,所以没上传。下述内容完全转自夏宇闻的“算法设计到硬线逻辑的设计”。


RISC_CPU是一个复杂的数字逻辑电路<?xml:namespace prefix = o ns = "urn:schemas-microsoft-com:office:office" />


      1)时钟发生器


      2)指令寄存器


      3)累加器


      4)RISC CPU算术逻辑运算单元


      5)数据控制器


      6)状态控制器


      7)程序计数器


      8)地址多路器


1时钟发生器


时钟发生器clkgen利用外来时钟信号clk 来生成一系列时钟信号clk1fetchalu_clk 送往CPU的其他部件。其中fetch是外来时钟 clk 的八分频信号。利用fetch的上升沿来触发CPU控制器开始执行一条指令,同时fetch信号还将控制地址多路器输出指令地址和数据地址。clk1信号用作指令寄存器、累加器、状态控制器的时钟信号。alu_clk 则用于触发算术逻辑运算单元。


2 指令寄存器


顾名思义,指令寄存器用于寄存指令。


指令寄存器的触发时钟是clk1,在clk1的正沿触发下,寄存器将数据总线送来的指令存入高8位或低8位寄存器中。但并不是每个clk1的上升沿都寄存数据总线的数据,因为数据总线上有时传输指令,有时传输数据。什么时候寄存,什么时候不寄存由CPU状态控制器的load_ir信号控制。load_ir信号通过ena 口输入到指令寄存器。复位后,指令寄存器被清为零。


每条指令为2个字节,即16位。高3位是操作码,低13位是地址。(CPU的地址总线为13位,寻址空间为8K字节。)本设计的数据总线为8位,所以每条指令需取两次。先取高8位,后取低8位。而当前取的是高8位还是低8位,由变量state记录。state为零表示取的高8位,存入高8位寄存器,同时将变量state置为1。下次再寄存时,由于state1,可知取的是低8位,存入低8位寄存器中。


3.累加器


累加器用于存放当前的结果,它也是双目运算其中一个数据来源。复位后,累加器的值是零。当累加器通过ena口收到来自CPU状态控制器load_acc信号时,在clk1时钟正跳沿时就收到来自于数据总线的数据。


4.算术运算器


算术逻辑运算单元 根据输入的8种不同操作码分别实现相应的加、与、异或、跳转等8种基本操作运算。利用这几种基本运算可以实现很多种其它运算以及逻辑判断等操作。


5.数据控制


数据控制器的作用是控制累加器数据输出,由于数据总线是各种操作时传送数据的公共通道,


不同的情况下传送不同的内容。有时要传输指令,有时要传送RAM区或接口的数据。累加器的数据只有在需要往RAM区或端口写时才允许输出,否则应呈现高阻态,以允许其它部件使用数据总线。所以任何部件往总线上输出数据时,都需要一控制信号。而此控制信号的启、停,则由CPU状态控制器输出的各信号控制决定。数据控制器何时输出累加器的数据则由状态控制器输出的控制信号datactl_ena决定。


6.地址多路器


地址多路器用于选择输出的地址是PC(程序计数)地址还是数据/端口地址。每个指令周期的前4个时钟周期用于从ROM中读取指令,输出的应是PC地址。后4个时钟周期用于对RAM或端口的读写,该地址由指令中给出。地址的选择输出信号由时钟信号的8分频信号fetch提供。


7.程序计数器


程序计数器用于提供指令地址。以便读取指令,指令按地址顺序存放在存储器中。有两种途径可形成指令地址:其一是顺序执行的情况,其二是遇到要改变顺序执行程序的情况,例如执行JMP指令后,需要形成新的指令地址。下面就来详细说明PC地址是如何建立的。


复位后,指令指针为零,即每次CPU重新启动将从ROM的零地址开始读取指令并执行。每条指令执行完需2个时钟,这时pc_addr已被增2,指向下一条指令。(因为每条指令占两个字节。)如果正执行的指令是跳转语句,这时CPU状态控制器将会输出load_pc信号,通过load口进入程序计数器。程序计数器(pc_addr)将装入目标地址(ir_addr),而不是增2


8.状态控制器


状态控制器由两部分组成:


1.状态机(上图中的MACHINE部分)


2.状态控制器(上图中的MACHINECTL部分)


状态机控制器接受复位信号RST,当RST有效时通过信号ena使其为0,输入到状态机中停止状态机的工作。


状态机是CPU的控制核心,用于产生一系列的控制信号,启动或停止某些部件。CPU何时进行读指令读写I/O端口,RAM区等操作,都是由状态机来控制的。状态机的当前状态,由变量state记录,state的值就是当前这个指令周期中已经过的时钟数(从零计起)。


指令周期是由8个时钟周期组成,每个时钟周期都要完成固定的操作。


1.0个时钟,因为CPU状态控制器的输出:rdload_ir为高电平,其余均为低电平。指令寄存器寄存由ROM送来的高8位指令代码。


2.1个时钟,与上一时钟相比只是inc_pc0变为1PC1ROM送来低8位指令代码,指令寄存器寄存该8位代码。


3.2个时钟,空操作。


4. 3个时钟,PC1,指向下一条指令。若操作符为HLT,则输出信号HLT为高。如果操作符不为HLT,除了PC增一外(指向下一条指令),其它各控制线输出为零。


5.4个时钟,若操作符为ANDADDXORLDA,读相应地址的数据;若为JMP,将目的地址送给程序计数器;若为STO,输出累加器数据。


6.5个时钟,若操作符为ANDDADDXORR,算术运算器就进行相应的运算;若为LDA,就把数据通过算术运算器送给累加器;若为SKZ,先判断累加器的值是否为0,如果为0PC就增1,否则保持原值;若为JMP,锁存目的地址;若为STO,将数据写入地址处。


7.6个时钟,空操作。


8.7个时钟,若操作符为SKZ且累加器值为0,则PC值再增1,跳过一条指令,否则PC无变化。


9.外围模块


为了对RISC_CPU进行测试,需要有存储测试程序的ROM和装载数据的RAM、地址译码器。下面来简单介绍一下


1.地址译码器


地址译码器用于产生选通信号,选通ROMRAM


FFFFH---1800H RAM


1800H---0000H ROM


2.RAMROM


ROM用于装载测试程序,可读不可写。RAM用于存放数据,可读可写。


点击看大图


 

文章评论0条评论)

登录后参与讨论
我要评论
0
10
关闭 站长推荐上一条 /2 下一条