- 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)
您可能关注的文档
- 定价和定价策略.ppt
- 宗教改革习题.ppt
- 安徽省界首市崇文中学七年级英语下册 Unit 4 Don’t eat in class Section A 1课件 (新版)人教新目标版.ppt
- 完整第二节可持续发展的基本内涵.ppt
- 定稿课件议论文之对症下药.ppt
- 安踏场外策划执行案-深圳.ppt
- 定稿 告别依赖走向自立1.ppt
- 定语从句提升(关系副词).ppt
- 定语从句与并列句,强调句,宾语从句,同位语从句的区别.ppt
- 定位(特劳特主要作品读书笔记).doc
- 2025年安徽省宿州市单招职业倾向性测试题库及参考答案1套.docx
- “沿海优品购” 沿海地区电商平台商业计划书.docx
- 挖机检测报告 模板.docx
- 2025年安徽审计职业学院单招职业技能测试题库附答案(完整版).docx
- 铅笔盒项目可行性研究报告评审方案设计(2025年发改委标准案例范文).docx
- 2025年安徽现代信息工程职业学院单招职业技能测试题库精选答案.docx
- 2025年安徽广播影视职业技术学院单招职业适应性测试题库(综合题).docx
- 危重孕产妇救治体系评估自查报告.docx
- 2025年安徽省巢湖市单招职业适应性测试题库精编答案.docx
- 2025年廊坊职业技术学院单招职业技能测试题库完整版.docx
文档评论(0)