微控制器设计方案

微控制器设计方案

ID:1521927

大小:1.30 MB

页数:21页

时间:2017-11-12

微控制器设计方案_第1页
微控制器设计方案_第2页
微控制器设计方案_第3页
微控制器设计方案_第4页
微控制器设计方案_第5页
资源描述:

《微控制器设计方案》由会员上传分享,免费在线阅读,更多相关内容在行业资料-天天文库

1、微控制器设计方案第一部分功能描述所有的MIPS指令都是32位,支持多种指令,主要有以下几种:·数据加载和存储指令:lw、sw指令·跳转指令:beq条件跳转和j、jr、jl跳转·算数逻辑运算:add、sub、and、or、slt具体有三种格式:处理器有32个32位寄存器,并且为了测试和运行方便,配备了一个32字的指令存储器,和一个32字的数据存储器(地址0x0000_0000~0x0000_001f)。还备有UART串口,并且与数据存储器共同编址(0x8000_0000~0x8000_0008)。第二部分设计方案1、设计策略采用分治:将一个难以直接解决的大问题,分割成一些规模较小的相

2、同问题,以便各个击破,分而治之。本实验中,我们将整个数据通路化分成多个模块:寄存器堆、取指部件、扩展器、二选一数据选择器、算术逻辑单元、数据存储器等,分别设计及实现,然后再整体进行逻辑控制,最终实现单周期数据通路。2、设计思路建立数据通路:(1)按照图1设计能够实现R型,lw/sw型和跳转型指令的mips处理器整体数据通路图21数据通路必须具备必要的存储元件,可能需要多个,同时数据通路必要的元件可能需要多个。(1)选择一组数据通路部件(2)根据需求,组装数据通路(3)分析每条指令的实现,以确定如何设置影响寄存器传输的控制点(4)装配控制逻辑3.数据通路图图1数据通路图第三部分单周期

3、MIPS分析与设计ALU:算术逻辑运算单元,有2个32位输入和1个32位输出,还有一个零标志位。有3个控制输入,而八种可能的输入组合中只有5种可能出现。对于取字和存储指令,ALU用于计算存储地址;对于R型指令,根据指令的低6位功能字段的内容,ALU执行5中操作中的一种。对于相等分支指令,ALU执行剑法操作。实现代码:always@(ctrlorin1orin2)beginif(in1==in2)zero<=1;elsezero<=0;case(ctrl)3'b010:ALU_out=in1+in2;3'b110:ALU_out=in1-in2;3'b000:ALU_out=in1&

4、in2;213'b001:ALU_out=in1

5、in2;3'b111:if(in1

6、ALU_ctrl=3'b010;6'b100010:ALU_ctrl=3'b110;6'b100100:ALU_ctrl=3'b000;6'b100101:ALU_ctrl=3'b001;6'b101010:ALU_ctrl=3'b111;default:ALU_ctrl=0;endcaseendendcaseendendmodule数据存储单元:是一个状态单元,有读写控制信号、地址和数据端口。两个输入是地址和所写数据,一个输出位为出内容,读写控制信号是独立的,任意始终只能激活一个。存数指令,要从寄存器堆中读出要存的数据;取数指令,则要将刚从存储器中取出的数放入寄存器堆中指定寄存器

7、中。实现代码:begincase({ctrl_write,ctrl_read})2'b01:out=mem[addr];2'b10:mem[addr]=data;default:$display("error");endcaseend21MUX:二选一数据选择器,通过控制信号的值来选择输出。实现代码:always@(*)if(ctrl==0)out=in0;elseout=in1;寄存器堆:实现代码:always@(in1orin2)begincase(in1)5'b00101:data1<=32'h001c;5'b01111:data1<=32'h0004;5'b00000:da

8、ta1<=32'h0008;5'b10000:data1<=32'h000c;5'b10001:data1<=32'h000c;default:data1<=mem[writeaddr];endcasecase(in2)5'b00101:data2<=32'h001c;5'b01111:data2<=32'h0004;5'b00000:data2<=32'h0008;5'b10000:data2<=32'h000c;5'b10001:data2<=32'h000c;d

当前文档最多预览五页,下载文档查看全文

此文档下载收益归作者所有

当前文档最多预览五页,下载文档查看全文
温馨提示:
1. 部分包含数学公式或PPT动画的文件,查看预览时可能会显示错乱或异常,文件下载后无此问题,请放心下载。
2. 本文档由用户上传,版权归属用户,天天文库负责整理代发布。如果您对本文档版权有争议请及时联系客服。
3. 下载前请仔细阅读文档内容,确认文档内容符合您的需求后进行下载,若出现内容与标题不符可向本站投诉处理。
4. 下载文档时可能由于网络波动等原因无法下载或下载错误,付费完成后未能成功下载的用户请联系客服处理。