欢迎来到冰点文库! | 帮助中心 分享价值,成长自我!
冰点文库
全部分类
  • 临时分类>
  • IT计算机>
  • 经管营销>
  • 医药卫生>
  • 自然科学>
  • 农林牧渔>
  • 人文社科>
  • 工程科技>
  • PPT模板>
  • 求职职场>
  • 解决方案>
  • 总结汇报>
  • ImageVerifierCode 换一换
    首页 冰点文库 > 资源分类 > DOCX文档下载
    分享到微信 分享到微博 分享到QQ空间

    精品计算机组成原理毕业论文报告40江苏大学软件工程41.docx

    • 资源ID:15868141       资源大小:1.72MB        全文页数:28页
    • 资源格式: DOCX        下载积分:6金币
    快捷下载 游客一键下载
    账号登录下载
    微信登录下载
    三方登录下载: 微信开放平台登录 QQ登录
    二维码
    微信扫一扫登录
    下载资源需要6金币
    邮箱/手机:
    温馨提示:
    快捷下载时,用户名和密码都是您填写的邮箱或者手机号,方便查询和重复下载(系统自动生成)。
    如填写123,账号就是123,密码也是123。
    支付方式: 支付宝    微信支付   
    验证码:   换一换

    加入VIP,免费下载
     
    账号:
    密码:
    验证码:   换一换
      忘记密码?
        
    友情提示
    2、PDF文件下载后,可能会被浏览器默认打开,此种情况可以点击浏览器菜单,保存网页到桌面,就可以正常下载了。
    3、本站不支持迅雷下载,请使用电脑自带的IE浏览器,或者360浏览器、谷歌浏览器下载即可。
    4、本站资源下载后的文档和图纸-无水印,预览文档经过压缩,下载后原文更清晰。
    5、试题试卷类文档,如果标题没有明确说明有答案则都视为没有答案,请知晓。

    精品计算机组成原理毕业论文报告40江苏大学软件工程41.docx

    1、精品计算机组成原理毕业论文报告40江苏大学软件工程41 江苏大学 计算机组成原理课程设计报告 专业名称: 软件工程班级学号:软件1001 第一天 取操作数微程序的设计和调试1、设计目标 设计并调试取操作数的微程序 二、取操作数微流程三、测试程序、数据及运行结果1、测试内容:立即寻址,直接寻址运行数据:内存地址(H)机器码(H)汇编指令0000077A 5678 0010MOV #5678H,0010H运行结果及分析:从微地址可以看出,先是取指令001-002-003-004,再是取源操作数,004-00B-00F-016-006,是立即数寻址方式,再是取目的操作数,006-01B01F-024

    2、-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可以看出最终结果由0000变成了5678。4、设计中遇到的问题

    3、及解决办法 才开始的时候,对软件的应用不是很熟悉,遇到一些麻烦,在同学的帮助下,解决了软件应用问题。第二天 运算指令的微程序设计与调试1、设计目标 设计并调试运算指令的微程序。二、运算指令微程序入口地址指令助记符指 令 编 码入口地址(H)FEDCBA9876543210MOV src, dst000001源地址码目的地址码044ADD src, dst000010源地址码目的地址码048ADDC src, dst000011源地址码目的地址码04CSUB src, dst000100源地址码目的地址码050SUBB src, dst000101源地址码目的地址码054CMP src, dst

    4、000110源地址码目的地址码058AND src, dst000111源地址码目的地址码05COR src, dst001000源地址码目的地址码060XOR src, dst001001源地址码目的地址码064TEST src, dst001010源地址码目的地址码068INC dst00000010001目的地址码0A4DEC dst00000010010目的地址码0A8NOT dst00000010011目的地址码0AC三、运算类指令微程序微地址(H)微指令(H)微命令BMNA注释007OP4XXX指令执行入口048TRoe, ADD, Sce, PSWce006FADD04C98B0

    5、006FTRoe,ADDC,SV,PSWce006FADDC05098F0006FTRoe,SUB,SV,PSWce006FSUB06F00000E707070存结果070Soe,GRSce0000ALU运算,结果送寄存器071Soe,DRce0072结果送存储器072DRoe,ARoe,WR0000四、测试程序、数据及运行结果1、测试内容:ADD运算运行数据:内存地址(H)机器码(H)汇编指令000000020761 56780B61 F000MOV #5678H,R1ADD #F000, R1运行结果及分析: 从微地址可以看出,第一阶段先是取第一条指令(MOV #5678H,R1)001-

    6、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,是寄存器寻址方式,最后是执行阶段,007-048-04F-070-000,是ADD运算,结果存放在寄存器GRS中,可以看出结果

    7、为4678,并且产生进位,SZOC=0001,正确。五、设计中遇到的问题及解决办法 指令的入口地址开始时没看懂,在同学的点拨下明白了。再是写微程序阶段,完成微程序的输入后,输入时由于不太仔细有一些错误,经过调试发现并改正了错误。经过对每条运算的测试,一些结果不对,在自己的一步一步的查找中,通过和同学的微程序的对照,一一弄懂并改正了。第三天 CPU硬件的初级设计与验证一、设计目标 在运算器实验的基础上对硬件进行扩充,建立初级CPU的数据通路,构造一个只支持运算指令的初级CPU。二、硬件设计1、PC模块设计(加上适当注释)module PC(d,q,n_reset,clk,ce,PCinc); i

    8、nput 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; end assign q = data;endmodule2、IR模块设计module IR #( parameter DATAWIDTH=16) (input wire DATAWIDTH-1:0

    9、 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 DATAWIDTH-1:0 data_DB, input wire clk, input wir

    10、e 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、顶层模块设计(自己增加的设计部分)TRTR寄存器的实例化R #(DATAWIDTH) TR(.q(TR_out),.d(IB),.clk(clock),.ce(TRce),.n_rese

    11、t(n_reset);buffer #(DATAWIDTH) reg_buffer(.q(IB), .d(TR_out), .oe(TRoe); ARAR寄存器的实例化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(AR_out), .oe(ARoe_IB);IRIR寄存器的实例化R #(DATAWID

    12、TH) 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(IB), .data_DB(DB), .clk(clock), .DRce_IB(DRce_IB

    13、), .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结果和第二天的一样,说明硬件扩充正确。四、设计中遇到的问题及解决办法 在写TR,AR,IR的实例化代码时

    14、,没注意是用寄存器模块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的基础上进行功能扩充,使其支持转移类指令二、硬件uAG模块设计(自己修改的设计部分,加上适当注释)3d3:uAGout = NA8:1,B

    15、M3_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,是立即数寻址方式,再是取目的操作数,006-018-007,是寄存器寻址方式,最后是执行阶段,007-044-046-000,

    16、将结果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,有进位,所以条件满足,执行的是075-077-000,正确。五、设计中遇到的问题及解决办法 程序中误将赋值符号=写成了

    17、=, 被同学发现,及时修改,并成功得到解决。第五天 为CPU扩充移位指令一、设计目标 在前面的CPU的基础上扩充硬件,使其支持移位指令。二、硬件设计1、SHIFTER模块设计(加上适当注释)wire data_lsb; wire data_ data_lsb = 1b0 ; assign data_ case (SL, SR) 3b01: q = d0; 3b10: q = d15; default:q = Cout; endcaseendendmodule3、IR_DECODE模块设计(自己增加修改的设计部分)2b00:BM4_uA002-003再是取目的操作数,006-01B-01F-02

    18、4-025-026-007,是直接寻址方式,最后是执行阶段,007-092-06F-070,执行SAR指令。由下一条指令可以看出结果变成了03B0,为右移后的结果,正确。四、设计中遇到的问题及解决办法 在实例化两个四选一多路器时,给data_lsb,data_reset); parameter DATAWIDTH=16; output DATAWIDTH-1:0 q; input DATAWIDTH-1:0 d; input clk,ce,n_reset; reg DATAWIDTH-1:0 q;always (posedge clk or negedge n_reset)beginif (!

    19、n_reset) q =16 h003F; 当复位信号有效时,SP的输出为03Felse if (ce) 当使能信号有效时,输出就是输入的内容q = d; endendmodule2、顶层模块设计(自己增加修改的设计部分)SP #(DATAWIDTH) SP(.d(IB), .q(SP_out), .clk(clock), .ce(SPce), .n_reset(n_reset);buffer #(DATAWIDTH) SP_IB(.q(IB),.d(SP_out),.oe(SPoe);三、PUSH、POP、CALL、RET指令微程序的设计PUSH(堆栈指令)微地址(H)微指令(H)微命令BM

    20、NA注释0C0F43000C1SPoe,Ace,SV00C1取sp0C162B300C2Soe,DEC,SV,DRce00C2Sp-10C27C0800C3Soe, SPce, ARce00C3Sp-1后的地址0C3DRoe, ARoe, WR0000将内容写入sp-1所指向的内存中POP(压栈指令)微地址(H)微指令(H)微命令BMNA注释0C8B00000C9ARoe, TRce00C9将目标地址先存放在暂存器中0C9F40800CASPoe, ARce, Ace00CA取sp 0CA027610CBRD, ARoe, DRce, INC,SV00CB读出sp所指向的内容,sp-10CB8

    21、00800CCTRoe, ARce00CC取目标地址0CC7C052000ARoe,DRoe,WR,Soe,SPce0000将sp中的内容写入目标地址CALL(子程序调用指令)微地址(H)微指令(H)微命令BMNA注释0D0F40000D1SPoe, Ace00D1栈顶单元减一,并保存原PC内容0D1B2B000D2DEC,SV, ARoe, TRce00D20D27C0800D3Soe,ARce,SPce00D3将sp-1送入SP和AR中0D3200300D4PCoe,DRce00D4将PC内容放入DR0D4ARoe,DRoe,WR,TRoe,PCce0000写入栈顶单元RET(返回指令)微

    22、地址(H)微指令(H)微命令BMNA注释03CF408003DSPoe, ARce, Ace003D03DRD, ARoe, DRce, INC,SV003F03FDRoe, PCce00400407C000000Soe, SPce0000四、测试程序、数据及运行结果1、测试内容:PUSH(堆栈指令)运行数据:内存地址(H)机器码(H)汇编指令0000031A 0004PUSH 0004H运行结果及分析:从微地址可以看出,第一阶段先是取指令001-002-003再是取目的操作数,006-01B-01F-024-025-026-007,是直接寻址方式,最后是执行阶段,0C0-0C1-0C2-0C

    23、3-000,执行PUSH指令。DR中为0004H里的内容5EE2。同时可以看出SP始终为3F。PUSH指令正确。2、测试内容:POP(压栈指令) 运行数据:内存地址(H)机器码(H)汇编指令0002033A 0008HPOP 0004H运行结果及分析:从微地址可以看出,第一阶段先是取指令001-002-003再是取目的操作数,006-01B-01F-024-025-026-007,是直接寻址方式,最后是执行阶段,0C8-0C9-0CA-0CB-0CC-000,执行POP指令。SP减一变为3E。在内存中可以看出,0008H中的内容变成了0004H中的内容5EE2。POP指令执行正确。3、测试内容:CALL(子程序调用指令) 运行数据:内存地址(H)机器码(H)汇编指令00000010035A 00100760 55


    注意事项

    本文(精品计算机组成原理毕业论文报告40江苏大学软件工程41.docx)为本站会员主动上传,冰点文库仅提供信息存储空间,仅对用户上传内容的表现方式做保护处理,对上载内容本身不做任何修改或编辑。 若此文所含内容侵犯了您的版权或隐私,请立即通知冰点文库(点击联系客服),我们立即给予删除!

    温馨提示:如果因为网速或其他原因下载失败请重新下载,重复下载不扣分。




    关于我们 - 网站声明 - 网站地图 - 资源地图 - 友情链接 - 网站客服 - 联系我们

    copyright@ 2008-2023 冰点文库 网站版权所有

    经营许可证编号:鄂ICP备19020893号-2


    收起
    展开