- 16
- 0
- 约1.85千字
- 约 4页
- 2018-11-24 发布于河南
- 举报
学习FPGA verilog的心得--编程技巧--如何写代码减少逻辑单元的使用数量
一....尽量不要使用大于小于这样的判断语句, 这样会明显增加使用的逻辑单元数量 .看一下报告,资源使用差别很大.
???? 例程:always@(posedge clk)?? begin??? count1=count1+1;?? if(count1=???? feng=1;??? //no_ring??? else if(count1=???? begin????? feng=0;?? //ring????? count1=0;??? endend??????????? //这么写会用107个逻辑单元
// 如果把这句话if(count1=改成大于小于,报告中用了135个逻辑单元
二.....一定要想尽办法减少reg寄存器的长度
???? 上次把[30:0]改到[50:0],报告里逻辑单元从100多直升到2000多!!!太吓人了,至于为什么我就不知道了哈!
三....case语句里一定要加default??? if一定要加else
????? 如果是组合逻辑的设计,不加default或else的话,不能保证所有的情况都有赋值,就会在内部形成一个锁存器,不再是一个纯粹的组合逻辑了,电路性能就会下降.
???? 例如:case({a,b})
????????????????? 2b11 e=b;
???????????????? 2b10?? e=a;???
???????????? endcase
??????????? //不加default,虽然只关心a=1时的结果,但是a=0的时候,e就会保存原来的值,直到a变为1
?????????? //那么e要保存原来的值,就要在内部生成锁存器了.
?
四....尽量使用Case语句?? 而不是if--else语句
????? 复杂的if--else语句通常会生成优先级译码逻辑,这将会增加这些路径上的组合时延 用来产生复杂逻辑的Case语句通常会生成不会有太多时延的并行逻辑
五...组合逻辑的always块中,要注意所有的输入全部放入敏感变量表里
????? 比如:always@(a or b)
???????????????????????? begin
?????????????????????????????????????? out=(abc);
???????????????????????? end
此时生成的不是纯的组合逻辑,因为当C变化时,??? out不会立刻发生变化(需要等到a或b变化,c的变化才会显现),??? 所以需要生成一个寄存器来保存C的值.
连续赋值语句的综合:从赋值语句右边提取出逻辑,用于驱动赋值语句左边的net
过程赋值语句的综合:从赋值语句右边提取出的逻辑,用于驱动赋值语句左边的reg型变量。注意:initia语句仅用于仿真,不综合。只有在always中才能被综合。
建议组合逻辑用阻塞语句,时序逻辑用非阻塞语句,任何延时控制(如#5)都被综合工具器忽略。一个模块中同一个变量不能既有阻塞赋值,又有非阻塞赋值。
always语句的综合
1对于组合逻辑,事件列表必须包括所有always语句中引用的变量,否则会造成综合的结果与设计功能不匹配。
2临时变量可以不用在事件列表中列出。
if语句的综合
特别要注意综合出锁存器。always中,某个变量没有在所有的条件分支中被赋值,就会综合出锁存器。
case语句综合
和if语句一样,不完整的case分支语句也会导致锁存器的综合。
避免方法:
1)在case语句前,对要赋值的变量赋予初值
always @ (state or a or b) begin
q =0;
case(state)
?3b000: q =? A B;
……
2)使用default分支语句
3)使用综合指令,具体用法在case关键字行的注释中插入”synthesis full_case“
并行CASE语句
通常情况下case语句和if语句一样会综合出代有优先权解码的硬件电路,从上大侠选项优先级逐渐降低。但如果设计者知道case语句中的所有项是互斥的,这时候就使用”parallel_case综合指令。
always @(key)
?case(key)???? //synthesis parallel_case
??? 4b0001: a? = 0;
?endcase
您可能关注的文档
- 如何合理进行压力管理.doc
- 如何在化学教学中落实“四问、两精、三查”.doc
- 如何向国外期刊投稿.doc
- 如何在在教学中落实.doc
- 如何命制中考试题.ppt
- 如何在班主任工作中对学生进行心理健康教育.doc
- 如何在长途通信光缆接续中.doc
- 如何培养学生的化学实验技能与创新能力.doc
- 如何在淡季查漏补缺和操作市场?.doc
- 如何加强班级安全教育.doc
- 2025年全国演出经纪人员资格认定考试试卷带答案(研优卷).docx
- 2025年全国演出经纪人员资格认定考试试卷完整版.docx
- 2025年全国演出经纪人员资格认定考试试题库及完整答案.docx
- 2025年全国演出经纪人员资格认定考试试卷完美版.docx
- 2025年全国演出经纪人员资格认定考试试卷含答案(实用).docx
- 2025年全国演出经纪人员资格认定考试试卷及答案(各地真题).docx
- 2025年下半年内江市部分事业单位公开考试招聘工作人员(240人)备考题库附答案.docx
- 2025年全国演出经纪人员资格认定考试试卷及答案1套.docx
- 2025年下半年四川成都市郫都区面向社会引进公共类事业单位人员2人备考题库最新.docx
- 2025年下半年内江市部分事业单位公开考试招聘工作人员(240人)备考题库附答案.docx
最近下载
- 《肖申克救赎》与《人性污点》对比评析.doc VIP
- 陕晋青宁四省2025-2026学年高三上学期(1月)第二次联考数学试卷(含答案详解).pdf
- 2025年AWS认证DynamoDB全局表数据不一致性问题的诊断与解决专题试卷及解析.pdf VIP
- 2025年房地产经纪人高级谈判策略模拟与实战演练专题试卷及解析.pdf VIP
- 2025年公共营养师不同食物类别中碘的分布规律专题试卷及解析.pdf VIP
- 2025年无人机驾驶员执照飞行操作责任归属法律依据专题试卷及解析.pdf VIP
- 2025年招标师招标采购从业人员接受礼品、宴请与旅游的禁止性规定专题试卷及解析.pdf VIP
- 文旅创意产业商业计划书.docx VIP
- 2025年MK 袋鼠数学竞赛Level-D (7-8年级) 真题+解析.pdf
- 【数学卷+解析】苏州零模2601.pdf
原创力文档

文档评论(0)