- 1、本文档共18页,可阅读全部内容。
- 2、原创力文档(book118)网站文档一经付费(服务费),不意味着购买了该文档的版权,仅供个人/单位学习、研究之用,不得用于商业用途,未经授权,严禁复制、发行、汇编、翻译或者网络传播等,侵权必究。
- 3、本站所有内容均由合作方或网友上传,本站不对文档的完整性、权威性及其观点立场正确性做任何保证或承诺!文档内容仅供研究参考,付费前请自行鉴别。如您付费,意味着您自己接受本站规则且自行承担风险,本站不退款、不进行额外附加服务;查看《如何避免下载的几个坑》。如果您已付费下载过本站文档,您可以点击 这里二次下载。
- 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)