网站大量收购闲置独家精品文档,联系QQ:2885784924

一款简单的RICCPU.docVIP

  1. 1、本文档共2页,可阅读全部内容。
  2. 2、原创力文档(book118)网站文档一经付费(服务费),不意味着购买了该文档的版权,仅供个人/单位学习、研究之用,不得用于商业用途,未经授权,严禁复制、发行、汇编、翻译或者网络传播等,侵权必究。
  3. 3、本站所有内容均由合作方或网友上传,本站不对文档的完整性、权威性及其观点立场正确性做任何保证或承诺!文档内容仅供研究参考,付费前请自行鉴别。如您付费,意味着您自己接受本站规则且自行承担风险,本站不退款、不进行额外附加服务;查看《如何避免下载的几个坑》。如果您已付费下载过本站文档,您可以点击 这里二次下载
  4. 4、如文档侵犯商业秘密、侵犯著作权、侵犯人身权等,请点击“版权申诉”(推荐),也可以打举报电话:400-050-0827(电话支持时间:9:00-18:30)。
  5. 5、该文档为VIP文档,如果想要下载,成为VIP会员后,下载免费。
  6. 6、成为VIP后,下载本文档将扣除1次下载权益。下载后,不支持退款、换文档。如有疑问请联系我们
  7. 7、成为VIP后,您将拥有八大权益,权益包括:VIP文档下载权益、阅读免打扰、文档格式转换、高级专利检索、专属身份标志、高级客服、多端互通、版权登记。
  8. 8、VIP文档为合作方或网友上传,每下载1次, 网站将根据用户上传文档的质量评分、类型等,对文档贡献者给予高额补贴、流量扶持。如果你也想贡献VIP文档。上传文档
查看更多
一款简单的RISCCPU 声明:本文并非本人设计的MCU,而是对一本教材中的代码进行了调试,将调试过程中的心得拿来与像我一样的新手一起分享。 参考教材:《Verilog数字系统设计教程》 夏宇闻著 北京航空航天大学出版社 第九讲 简化的RISC_CPU设计。 心得:这款CPU很简单,不能用于实际,但是这款CPU的工作原理,设计思想,指令的分配都与能应用于实际的CPU设计一样,以此为基础,我想通过努力我们任何一个人都可以设计一个能用于实际的RISC_CPU,我曾见过一个款PIC单片机,其指令格式与寻址方式与其都大同小异,只是略为复杂一点而已。这款CPU虽不能用于实际,但对于我们新手来说,直接拿一款很是复杂的CPU来调试可能比较困难,很难掌握CPU的工作原理,有时会打击自信心,而这款MCU很简单,却有着任何一款MCU都存在的工作原理,让我们有一个从简单到复杂的缓冲。 下面说来说一下MCU中的各个部分: 指令系统: 14 13 12 11 10 9 8 7 6 5 4 3 2 1 0 (指 令) ( 地 址 ) 我们可以做一下修改,将指令改为4位的,这样我们就可以做出一个有16个指令的CPU了,但是这样做就会使CPU的寻址范围变为4K。为什么?指令的格式是16位的,指令用去4位,只剩下12位地址了。 指令设置: 000 HLT 空操作,相当于其它单片机中的NOP指令。 001 SKZ 条件跳转指令,如果ALU的结果为0就跳过一条指令再执行代码。 010 ADD 加法操作,指令中指出的地址内容与A寄存器中的内容相加,结果存回A寄存器。 011 AND 按位与操作。 100 XOR 异或操作。 101 LDA 读数操作,将指令指出地址的内容读入A寄存器。 110 STO 存数操作,将数据存入指令中指向的地址。 111 JMP 无条件跳转指令,程序跳转到指令指出的地址中去执行代码。 程序代码的核心是machine.v,这里是CPU设计的精华部分,希望大家能够理解原作者的思路,如果有什么地方有疑问, HYPERLINK mailto:可以发信到vongy@126.com 可以发信到vongy@126.com我会及时回复。另外,程序内容放在rom_data中,读者可以用记事本打修改,里面的内容是逐次验证了CPU支持的八条指令。 所有指令均仿真通过,但在仿真过程中对原程序略作修改,使之工作过程更符合新手的理解(但我不知道这样改动之后会不会降低执行效率)。 我将整个工程打包上传,仿真环境为ModelSim SE PLUS 6.1b ,读者直接用MODELSIM打开工程和WAVE.DO即可看到仿真结果。希望大家能找到这本书,与之对比,更好的理解其工作原理。 祝君学习愉快! By VON 2006 光棍节

文档评论(0)

ldj215323 + 关注
实名认证
文档贡献者

该用户很懒,什么也没介绍

1亿VIP精品文档

相关文档