实验6分析和建议.pptx

实验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)

1亿VIP精品文档

相关文档