- 1、原创力文档(book118)网站文档一经付费(服务费),不意味着购买了该文档的版权,仅供个人/单位学习、研究之用,不得用于商业用途,未经授权,严禁复制、发行、汇编、翻译或者网络传播等,侵权必究。。
- 2、本站所有内容均由合作方或网友上传,本站不对文档的完整性、权威性及其观点立场正确性做任何保证或承诺!文档内容仅供研究参考,付费前请自行鉴别。如您付费,意味着您自己接受本站规则且自行承担风险,本站不退款、不进行额外附加服务;查看《如何避免下载的几个坑》。如果您已付费下载过本站文档,您可以点击 这里二次下载。
- 3、如文档侵犯商业秘密、侵犯著作权、侵犯人身权等,请点击“版权申诉”(推荐),也可以打举报电话:400-050-0827(电话支持时间:9:00-18:30)。
- 4、该文档为VIP文档,如果想要下载,成为VIP会员后,下载免费。
- 5、成为VIP后,下载本文档将扣除1次下载权益。下载后,不支持退款、换文档。如有疑问请联系我们。
- 6、成为VIP后,您将拥有八大权益,权益包括:VIP文档下载权益、阅读免打扰、文档格式转换、高级专利检索、专属身份标志、高级客服、多端互通、版权登记。
- 7、VIP文档为合作方或网友上传,每下载1次, 网站将根据用户上传文档的质量评分、类型等,对文档贡献者给予高额补贴、流量扶持。如果你也想贡献VIP文档。上传文档
查看更多
體系结构实验手册
实验1 简单CPU设计
实验目的
设计实现简单CPU,熟悉并掌握指令结构,利用verilog编写各个子模块。
实验原理
.CPU设计
CPU概念设计如图1所示:
图1
指令集
设计4条指令简单CPU指令格式:opcode(2)+ addr(6)表1 指令结构
Inst Op Addr Operation ADD 00 XXXXXX 加 法: AC-AC+M[Addr] AND 01 XXXXXX 逻辑与: AC-ACM[Addr] INC 10 XXXXXX 加 1: AC-AC+1 JMP 11 XXXXXX 跳 转: PC-Addr 3寄存器组织
(1)累加器(AC)
a.提供ADD,AND操作的一个操作数
b.存放ADD,AND操作的结果
(2)用户不可见寄存器
a.地址寄存器(AR):6bit,提供访问存储器单元地址
b.程序计数器(PC):6bit,存放下一条指令在存储器单元中的地址
c.数据寄存器(DR):8bit,存放从访问存储器单元的内容
d.指令寄存器(IR):2bit,存放当前取出的指令的操作码部分
4指令的执行
指令的执行过程如图2:
图2
(1)取指 FETCH1: AR- PC
FETCH2: DR- M,PC- PC+1
FECTH3: IR- DR[7..6],AR- DR[5..0]
(2)执行
ADD1: DR- M
ADD2: AC- AC + DR
AND1: DR- M
AND2: AC- AC ^ DR
INC1: AC- AC + 1
JMP1: PC- DR[5..0]
(3)寄存器AR: AR-PC; AR-DR[5..0]
PC: PC-PC+1; PC-DR[5..0]
DR: DR-M
IR: IR-DR [7..6]
AC: AC-AC+DR; AC-AC^ DR; AC -AC+1
5.CPU数据通路CPU数据通路设计如图3所示:
图3是已经过简化的数据通路,它反映了CPU内部各单元的功能特点:
(1)AR只向存储器提供数据
(2)IR不向其他单元提供数据
(3)AC不向其他单元提供数据
(4)AC需保存ALU运算结果
(5)8bit BUS
1、取指令(fetch)
2、分析指令(decode)
3、执行指令(Execute)
4、其他功能:控制程序数据的输入输出、异常处理、中断等
(2)控制信号
控制器中有9条信号线,分别是:
PCLOAD :允许PC置值
PCINC :允许PC自加1
DRLOAD :允许DR置值
ACLOAD :允许AC置值
ACINC :允许AC自加1
IRLOAD :允许IR置值
MEMBUS :控制存储器是否输出
PCBUS :控制PC是否输出
READ :读存储器
(3)信号生成逻辑
1.控制信号的线性表达:
PCLOAD = JMP1
PCINC = FETCH2
DRLOAD = FETCH1 v ADD1 v AND1
ACLOAD = ADD2 v AND2
ACINC = INC1
IRLOAD = FETCH3
MEMBUS = FETCH2 v ADD1 v AND1
PCBUS = FETCH1
READ = FETCH2 v ADD1 v AND1
2.控制信号的生成逻辑,如图4:
图4
三.实验环境
软件:QuartusII 6,ModelSim
硬件平台:GW48-SOPC/DSP EP1C6Q240
实验步骤
各个子模块的Verilog实现module alu(op,a,b,c);
input op;
input [7:0] a,b;
output [7:0] c;
assign c = (op==0)?(a+b):(ab);
endmodule
(2)IR模块
module ir(clk,load,din,dout);
input clk,load;
input [1:0] din;
output [1:0] dout;
reg [1:0] dout;
always @(posedge clk)
begin
if(load)
dout = din;
end
endmodule
(3)DR模块
module dr(clk,load,din,dout);
input clk,load;
input [7:0] din;
output [7:0] dout;
reg [7:0] dout;
always @(posedge clk)
begin
if(load)
dout = din;
end
endmodule
(4)PC模块
module pc(clk,rst,
您可能关注的文档
- 駐外办事处管理制度.doc
- 駐外办事处管理规定.doc
- 駐外办事处管理办法1.doc
- 馳骋工作流引擎-用户手册(管理员).doc
- 駐外投资企业管理人员培训.doc
- 駐村干部事迹材料.docx
- 駐美国台北经济文化代表处与美国在台协会间气象预报系统发展技术合作协议(译).doc
- 駐店人员管理办法.doc
- 駐马店产业集聚区战略合作框架协议20110.doc
- 駕校各类管理制度.doc
- 未来教育模式构建与智能化教育发展研究论文.docx
- 多模态语篇在高中英语教学中的跨学科融合研究论文.docx
- 智能助力扶手在老旧小区楼梯改造中的安全性分析论文.docx
- 初中物理实验:传统发酵食品制作过程中的热传导效率研究论文.docx
- 小学英语教学中社会舆情传播动力学与跨文化素养提升研究论文.docx
- 小学语文教学中学生经典名著阅读与人文素养培养研究论文.docx
- 历史文化教育在高中的实施现状与对策探讨论文.docx
- 小学科学教育中垃圾分类实践活动的设计与实施策略论文.docx
- 高中生物教学中德育教育与学生生态意识培养研究论文.docx
- 高中物理:六边形蜂窝结构纸桥承重实验的物理实验数据分析与结论论文.docx
原创力文档


文档评论(0)