计算机组成原理课程设计报告(江苏大学适用于软件工程).doc
《计算机组成原理课程设计报告(江苏大学适用于软件工程).doc》由会员分享,可在线阅读,更多相关《计算机组成原理课程设计报告(江苏大学适用于软件工程).doc(25页珍藏版)》请在三一办公上搜索。
1、 江苏大学 计算机组成原理课程设计报告 专业名称: 软件工程班级学号:软件1001 学生姓名: 张建彬指导教师: 杨旭东 设计时间: 2012年6月 11 日 2012年6月20日第一天 取操作数微程序的设计和调试一、 设计目标 设计并调试取操作数的微程序 二、取操作数微流程三、测试程序、数据及运行结果1、测试内容:立即寻址,直接寻址运行数据:内存地址(H)机器码(H)汇编指令0000077A 5678 0010MOV #5678H,0010H运行结果及分析:从微地址可以看出,先是取指令001-002-003-004,再是取源操作数,004-00B-00F-016-006,是立即数寻址方式,再
2、是取目的操作数,006-01B01F-024-025-026-007,是直接寻址方式,最后是执行阶段,007-044-047-072-000,将结果mov到内存里。2、测试内容:立即寻址,寄存器运行数据:内存地址(H)机器码(H)汇编指令00000761 5678 MOV #5678H,R1运行结果及分析:从微地址可以看出,先是取指令001-002-003-004,再是取源操作数,004-00B-00F-016-006,是立即数寻址方式,再是取目的操作数,006-018-007,是寄存器寻址方式,最后是执行阶段,007-044-046-000,将结果mov到寄存器里。由GRS可以看出最终结果由
3、0000变成了5678。四、 设计中遇到的问题及解决办法 才开始的时候,对软件的应用不是很熟悉,遇到一些麻烦,在同学的帮助下,解决了软件应用问题。第二天 运算指令的微程序设计与调试一、 设计目标 设计并调试运算指令的微程序。二、运算指令微程序入口地址指令助记符指 令 编 码入口地址(H)FEDCBA9876543210MOVsrc, dst000001源地址码目的地址码044ADDsrc, dst000010源地址码目的地址码048ADDCsrc, dst000011源地址码目的地址码04CSUB src, dst000100源地址码目的地址码050SUBBsrc, dst000101源地址码
4、目的地址码054CMPsrc, dst000110源地址码目的地址码058ANDsrc, dst000111源地址码目的地址码05COR src, dst001000源地址码目的地址码060XOR src, dst001001源地址码目的地址码064TESTsrc, dst001010源地址码目的地址码068INC dst00000010001目的地址码0A4DEC dst00000010010目的地址码0A8NOT dst00000010011目的地址码0AC三、运算类指令微程序微地址(H)微指令(H)微命令BMNA注释00700000800OP4XXX指令执行入口0489870006FTR
5、oe, ADD, Sce, PSWce006FADD04C98B0006FTRoe,ADDC,SV,PSWce006FADDC05098F0006FTRoe,SUB,SV,PSWce006FSUB06F00000E707070存结果07068000000Soe,GRSce0000ALU运算,结果送寄存器07160030072Soe,DRce0072结果送存储器07200052000DRoe,ARoe,WR0000四、测试程序、数据及运行结果1、测试内容:ADD运算运行数据:内存地址(H)机器码(H)汇编指令000000020761 56780B61 F000MOV #5678H,R1ADD #
6、F000, R1运行结果及分析: 从微地址可以看出,第一阶段先是取第一条指令(MOV #5678H,R1)001-002-003-004,再是取源操作数,004-00B-00F-016-006,是立即数寻址方式,再是取目的操作数,006-018-007,是寄存器寻址方式,最后是执行阶段,007-044-046-000,将结果mov到寄存器里。在GRS可以看出由0000变成了5678。第二阶段先是取第二条指令(ADD #F000, R1)001-002-003-004,再是取源操作数,004-00B-00F-016-006,是立即数寻址方式,再是取目的操作数,006-018-007,是寄存器寻址
7、方式,最后是执行阶段,007-048-04F-070-000,是ADD运算,结果存放在寄存器GRS中,可以看出结果为4678,并且产生进位,SZOC=0001,正确。五、设计中遇到的问题及解决办法 指令的入口地址开始时没看懂,在同学的点拨下明白了。再是写微程序阶段,完成微程序的输入后,输入时由于不太仔细有一些错误,经过调试发现并改正了错误。经过对每条运算的测试,一些结果不对,在自己的一步一步的查找中,通过和同学的微程序的对照,一一弄懂并改正了。第三天 CPU硬件的初级设计与验证一、设计目标 在运算器实验的基础上对硬件进行扩充,建立初级CPU的数据通路,构造一个只支持运算指令的初级CPU。二、硬
8、件设计1、PC模块设计(加上适当注释)module PC(d,q,n_reset,clk,ce,PCinc); input 15:0 d; input n_reset,clk,ce; input PCinc; output 15:0 q; reg 15:0 data;always (posedge clk or negedge n_reset) begin if (!n_reset)data = 0; else if (ce)data = d;else if(PCinc)data = data+1; endassign q = data;endmodule2、IR模块设计module IR #
9、(parameter DATAWIDTH=16)(input wire DATAWIDTH-1:0 d, input wire clk, input wire ce, input n_reset, output reg DATAWIDTH-1:0 q);always(posedge clk or negedge n_reset) begin if (!n_reset)q = 0; else if (ce)q = d;endDR:module DR #(parameter DATAWIDTH=16)(input wire DATAWIDTH-1:0 data_IB, input wire DAT
10、AWIDTH-1:0 data_DB, input wire clk, input wire DRce_IB, input wire DRce_DB, input n_reset, output reg DATAWIDTH-1:0 q);always(posedge clk or negedge n_reset) begin if(!n_reset)q=0;else if(DRce_IB)q=data_IB;else if(DRce_DB)q=data_DB; endendmodule3、顶层模块设计(自己增加的设计部分)/TR/TR寄存器的实例化R #(DATAWIDTH) TR(.q(TR
11、_out),.d(IB),.clk(clock),.ce(TRce),.n_reset(n_reset);buffer #(DATAWIDTH) reg_buffer(.q(IB), .d(TR_out), .oe(TRoe);/ AR/AR寄存器的实例化R #(DATAWIDTH) AR(.q(AR_out),.d(IB),.clk(clock),.ce(ARce),.n_reset(n_reset);buffer #(ADDRWIDTH) AR_AB(.q(AB), .d(AR_out), .oe(ARoe_AB);buffer #(ADDRWIDTH) AR_IB(.q(IB), .d(
12、AR_out), .oe(ARoe_IB);/IR/IR寄存器的实例化R #(DATAWIDTH) IR(.q(IR_out),.d(IB),.clk(clock),.ce(IRce),.n_reset(n_reset);/PCPC PC(.d(IB), .q(PC_out), .n_reset(n_reset), .clk(clock), .ce(PCce), .PCinc(PCinc);buffer #(DATAWIDTH) PC_buffer(.q(IB), .d(PC_out), .oe(PCoe);/DRDR #(DATAWIDTH) DR(.q(DR_out), .data_IB(
13、IB), .data_DB(DB), .clk(clock), .DRce_IB(DRce_IB), .DRce_DB(DRce_DB), .n_reset(n_reset);buffer #(DATAWIDTH) DR_DB(.q(DB), .d(DR_out), .oe(DRoe_DB);buffer #(DATAWIDTH) DR_IB(.q(IB), .d(DR_out), .oe(DRoe_IB);三、验证1、测试内容:ADD运算运行数据:内存地址(H)机器码(H)汇编指令000000020761 56780B61 F000MOV #5678H,R1ADD #F000, R1结果和第
14、二天的一样,说明硬件扩充正确。四、设计中遇到的问题及解决办法 在写TR,AR,IR的实例化代码时,没注意是用寄存器模块R实例化得到的,经过报错和仔细看书后,发现了问题,成功改正过来了。完成程序运行出了问题,经过查找发现是DR模块出了问题,if(!n_reset)q=0;else if(DRce_IB)q=data_IB;else if(DRce_DB)q=data_DB;这一句被我写成了if(!n_reset)q=0;else if(DRce_IB)q=data_IB;else q=data_DB。第四天 为CPU扩充转移指令一、设计要求 在初级CPU的基础上进行功能扩充,使其支持转移类指令二
15、、硬件uAG模块设计(自己修改的设计部分,加上适当注释)3d3:uAGout = NA8:1,BM3_uAR0; /3,根据条件转移指令操作码PSW的ZF,OF,SF,CF状态标志决定微地址/第四天always(SZOC, IR) begin case(IR7:6)/ 条件转移类指令 2b00: Flag_MUX=SZOC0; 2b01: Flag_MUX=SZOC1; 2b10: Flag_MUX=SZOC2; 2b11: Flag_MUX=SZOC3; default:Flag_MUX002-003-004,再是取源操作数,004-00B-00F-016-006,是立即数寻址方式,再是取目
16、的操作数,006-018-007,是寄存器寻址方式,最后是执行阶段,007-044-046-000,将结果mov到寄存器里。在GRS可以看出由0000变成了5678。第二阶段先是取第二条指令(ADD #F000, R1)001-002-003-004,再是取源操作数,004-00B-00F-016-006,是立即数寻址方式,再是取目的操作数,006-018-007,是寄存器寻址方式,最后是执行阶段,007-048-04F-070-000,是ADD运算,结果存放在寄存器GRS中,可以看出结果为4678,并且产生进位,SZOC=0001,正确。第三阶段,进入JC指令,因为C=1,有进位,所以条件满
- 配套讲稿:
如PPT文件的首页显示word图标,表示该PPT已包含配套word讲稿。双击word图标可打开word文档。
- 特殊限制:
部分文档作品中含有的国旗、国徽等图片,仅作为作品整体效果示例展示,禁止商用。设计者仅对作品中独创性部分享有著作权。
- 关 键 词:
- 计算机 组成 原理 课程设计 报告 江苏 大学 适用于 软件工程
链接地址:https://www.31ppt.com/p-2882338.html