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

实验6分析与建议.pptx

  1. 1、本文档共18页,可阅读全部内容。
  2. 2、原创力文档(book118)网站文档一经付费(服务费),不意味着购买了该文档的版权,仅供个人/单位学习、研究之用,不得用于商业用途,未经授权,严禁复制、发行、汇编、翻译或者网络传播等,侵权必究。
  3. 3、本站所有内容均由合作方或网友上传,本站不对文档的完整性、权威性及其观点立场正确性做任何保证或承诺!文档内容仅供研究参考,付费前请自行鉴别。如您付费,意味着您自己接受本站规则且自行承担风险,本站不退款、不进行额外附加服务;查看《如何避免下载的几个坑》。如果您已付费下载过本站文档,您可以点击 这里二次下载
  4. 4、如文档侵犯商业秘密、侵犯著作权、侵犯人身权等,请点击“版权申诉”(推荐),也可以打举报电话:400-050-0827(电话支持时间:9:00-18:30)。
查看更多
实验6分析与建议

;我在检查P6时,发现了一些共性问题。 本PPT就是针对这些问题的总结和分析,并试图给出参考样例。 我始终认为本课程在传递给大家的最重要的不是具体的知识,而是构建大系统的方法。因此结合我多年的科研与教学经验,我还给出了若干建议供你参考。;所有内容只对大系统设计有一定意义 如果你认为你今后定位于总师/系统架构师等高端设计人员,请继续阅读后面的slice 如果你认为上学就是为了今后混口饭,那么可以结束阅读,以免浪费时间;设计冗余 赋值语句有不合理值 在存储器模块中实现LB/LH位扩展 较少使用宏 多位控制信号非整体性赋值 模块端口定义过于随意;现象:主要问题出在移位指令的设计上 每条移位指令都设计对应的移位运算,而非设计一个整体性的运算 后果:不存在功能正确性问题,但会导致设计非最优 每条移位指令都会有对应的移位运算组合逻辑 方案:特别是针对右移类指令(算术、逻辑),应该将最高位统一处理后再统一移位 参考样例:下一页 说明:这个设计并非最好的设计,但建议同学们从中体会“什么是好的设计”;module Shifter( Din, Num, Funct, Dout ) ; input [31:0] Din; // source data input [4:0] Num; // number of bits to shift input [4:0] Funct; // shifter function selector output [31:0] Dout; // shift result wire [31:0] wShiftL1, wShiftL2, wShiftL4, wShiftL8, wShiftL16 ; wire [31:0] wShiftR1, wShiftR2, wShiftR4, wShiftR8, wShiftR16 ; wire mask; assign mask = (Funct == `ALU_SRA)? Din[31]: 0; assign wShiftL1 = Num[0] ? {Din[30:0], 1b0} : Din ; assign wShiftL2 = Num[1] ? {wShiftL1[29:0], 2b0} : wShiftL1 ; assign wShiftL4 = Num[2] ? {wShiftL2[27:0], 4b0} : wShiftL2 ; assign wShiftL8 = Num[3] ? {wShiftL4[23:0], 8b0} : wShiftL4 ; assign wShiftL16 = Num[4] ? {wShiftL8[15:0], 16b0} : wShiftL8 ; assign wShiftR1 = Num[0] ? {{1{mask}}, Din[31:1]} : Din ; assign wShiftR2 = Num[1] ? {{2{mask}}, wShiftR1[31:2]} : wShiftR1 ; assign wShiftR4 = Num[2] ? {{4{mask}}, wShiftR2[31:4]} : wShiftR2 ; assign wShiftR8 = Num[3] ? {{8{mask}}, wShiftR4[31:8]} : wShiftR4 ; assign wShiftR16 = Num[4] ? {{16{mask}}, wShiftR8[31:16]} : wShiftR8 ; assign Dout = (Funct==`ALU_SLL) ? wShiftL16 : wShiftR16 ; endmodule;现象:使用’Z’值 如右侧MUX赋值 问题:Z通常只在需要高阻态时才使用 高阻态使用场景:高阻态只能被应用于顶层模块具有inout属性定义的端口。 我们会在P7/P8中介绍 方案:除了上述场景外,不能出现Z值。 样例1:最简设计。只要sel不出错就没有问题 样例2:支持调试。一旦在某个环节出现了特定值,说明sel的控制或编码值出错了。;错误设计 assign out = (sel==2’b00)

文档评论(0)

dajuhyy + 关注
实名认证
内容提供者

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

1亿VIP精品文档

相关文档