版权说明:本文档由用户提供并上传,收益归属内容提供方,若内容存在侵权,请进行举报或认领
文档简介
1、HDL编码风格/VHDL指导原则1内容HDL编码风格VHDL指导原则2HDL编码风格文件头和修订列表联机注释命名规则3文件头模块名文件名需要的库模块描述使用的仿真器及器运行平台和版本使用的综合工具及其运行平台和版本作者名字和e-mail4文件头例子- Module : MAC (Multiply Accumulate Unit) - File : mac.vhd - Library : ieee,. - Description : It is a general Purpose Multiply - Accumulate Unit capable of - Simulator : Models
2、im 5.2 / Windows 95- Synthesizer : Synplify / Windows95 - Author / Designer : Harish Y S () -5修订列表修订版本号改动的数据修订者名字和e-mail改动的详细描述6修订列表例子- Revision Number : 1- Date of Change : 20th March 2000- Modifier : Harish Y S ()- Description : Initial Design - - Revision Number : 2 - Date of Change : dd mm yyyy
3、- Modifier : XYZ (email) - Description : Modified the ?.to improve ?. -7文件头标准模式- Title :- Project :- File : - Author : name - Organization: - Created : - Last update :- Platform :- Simulators : - Synthesizers: - Targets : - Dependency :- Description: - - Copyright (c) notice - - Revisions : - Revisi
4、on Number : - Version : - Date : - Modifier : name - Description : -8联机注释每一个重要的操作和定义后都要加注释描述操作和声明的使用9注释注意事项不要去注释明明白白的事不要让注释干扰读者不要与代码矛盾Entity (.) -实体声明IF() .- .THEN .- .语句IF(!reset) reset高电平有效.10命名规则实体和结构端口结构体元件配置包/函数和过程常量和类属说明枚举信号和变量进程和块TestBench11实体和结构规则:实体名要确切描述其功能; 实体名只能用小写字母,不超过10个字符;推荐:每个实体最好有一
5、个3-4个字母的缩略名可以将其应用在其内部的构造模块和信号名中。12端口规则:端口名应和信号相对应以大写字母开头; 若端口是标准设备可包含标准名,不超过15个字符端口声明后要有详细注释。13结构体规则:构造体名可用“behavioral” 表示行为描述,“structural”表示结构描述,“RTL”表示寄存器描述等; 由综合出来的结构体要有“_syn”后缀,并且在开始和结束出要注明采用的技术; 在“ARCHITECTURE”语句前要有一行注释,说明其功能,并说明是否可综合,或仅可仿真。 推荐:当一个设计中包含多个文件时,通过加“_arch”后缀来加以区分。14元件规则:其名称以包或实体的缩略
6、名作开头;可取有实际意义的单词,大小写可混用,最好不要超过8个字符。15配置规则:配置名中要包含顶层设计名;以大写字母开头,不超过15个字符。 推荐:加“_cfg”后缀区分多个文件。16包规则:包中要包含系统所需定义的所有常量,数据类型,模块,过程和函数;包名以大写字母开头,不超过15个字符。 推荐:加“_pkg”后缀区分多个文件为包定义一个3-4个字符的缩略名,加在其中的常量,过程和函数名中,用以区分不同包中的内容。17函数和过程规则:以大写字母开头,不超过10个字母;要体现其功能,用前缀“l_”表示局部变量;局部信号应有其特征域。推荐:加入包的缩略名于其中。18常量和类属说明规则:用大写字
7、母要明确描述常量的用法。 推荐:加入包的缩略名于其中。19枚举/数据类型/记录和数组规则:用大写字母新数据类型要加后缀“_typ”。20信号规则:第一个符号必须是字母信号名要描述其功能,不超过15个字符; 头三个字母要显示说明驱动模块的类型,要把其驱动实体,模块或进程缩略名加在前面:如控制单元“ctl”,算术逻辑运算单元“alu”,乘法器“mac”,数据地址发生器“dag”;如果信号只是在仅有时钟的进程中获得其值的,则加“_q”,若是总线则加“_reg” 信号定义语句后要有一行注释描述其功能; 信号名要表明信号的极性:高电平有效/正逻辑(P),低电平有效/负逻辑(N) 全局信号“G”,局部信号
8、“L”;若是三态信号,加Z; 后续字符要说明信号的内容。21变量规则:要简单并能描述其功能;可包含各种格式的字母、数字和下划线; 要确切的表示其行为。22进程规则:所有进程必须有进程名,用以描述其功能;注释要包含以下内容:组合、时序进程,组合进程要定义所有敏感信号时序进程要定义时钟和其边沿(上升沿或下降沿)时序进程还要定义复位信号如果有的话,其有效与否与时钟有关。23Test Bench规则:其名称要与实体名一致,且加后缀“_TB”; 结构体、进程、变量和信号同样遵循上述规则; 内存组织和仿真生成由过程和函数来实现;出错报告要提供下述信息:实体或模块名,信号或变量名,过程或函数名,当前时间点,
9、错误号或错误名,可能的出错原因,出错位置;24VHDL代码指导原则一般规则可综合编码以仿真和调试为目的的编码25一般规则外部端口用std_logic类型;不要赋未知值“x”或检查验证无效的“-”;这些值在仿真和综合时会产生不可预测的行为。 不要使用信号和变量的默认值(或初始值),用复位脉冲初始化信号和变量。 会在仿真和综合时出现不匹配。26一般规则(续)在整个VHDL工程中不要混用编码准则(i.e. VHDL 87 and VHDL 93);尽量在一个VHDL文件中做一个设计,文件名要和结构名一致;尽量在模块例化中使用名称符号,不要用位置符号; 有利于调试和增加代码的易读性。27一般规则(续2
10、)在不同的层级上使用统一的信号名; 容易跟踪信号,网表调试也容易。 尽量用配置映射实体、结构体和模块;改变不同的结构体只要简单改动一个文件就可以了,这在仿真上很有用,能从高层上改变低层结构体。 尽量在分开的库中编译每个块;使用常量和类属说明定义缓冲大小,总线宽度和其它单元参数。 这可增强可读性和代码复用性。28一般规则(续3)在一个最小化的包中定义模块和常量。不要在代码中使用buffer类型的端口读取输出数据;要使用out类型,再增加另外变量或信号,以获取输出值。 这是因为buffer类型的端口不能连接到其他类型的端口上,因此buffer类型就会在整个设计的端口中传播下去。29可综合代码尽量使用FSM,一个在时序逻辑中,一个在组合逻辑中。 这可增加可读性和预测组合逻辑的大小尽量在一个单独的时钟进程中写时钟使能,而不要在两个不同的进程中使用,一个是时钟驱动的,一个是组合逻辑。这是因为有些综合工具检查CE操作,若存在,就将其映射到触发器的CE端,否则,CE管脚不被使用,隐含使用外部逻辑。这是fpga设计的一般习惯。30可综合代码(2)在组合逻辑进程中,其敏感向量表中要包含所有要读取得信号; 这是为了防止出现不必要的锁存器。 避免使用长的if-then-else语句,而使用case语
温馨提示
- 1. 本站所有资源如无特殊说明,都需要本地电脑安装OFFICE2007和PDF阅读器。图纸软件为CAD,CAXA,PROE,UG,SolidWorks等.压缩文件请下载最新的WinRAR软件解压。
- 2. 本站的文档不包含任何第三方提供的附件图纸等,如果需要附件,请联系上传者。文件的所有权益归上传用户所有。
- 3. 本站RAR压缩包中若带图纸,网页内容里面会有图纸预览,若没有图纸预览就没有图纸。
- 4. 未经权益所有人同意不得将文件中的内容挪作商业或盈利用途。
- 5. 人人文库网仅提供信息存储空间,仅对用户上传内容的表现方式做保护处理,对用户上传分享的文档内容本身不做任何修改或编辑,并不能对任何下载内容负责。
- 6. 下载文件中如有侵权或不适当内容,请与我们联系,我们立即纠正。
- 7. 本站不保证下载资源的准确性、安全性和完整性, 同时也不承担用户因使用这些下载资源对自己和他人造成任何形式的伤害或损失。
最新文档
- 心肺复苏知识竞赛试题与答案集
- 紫外线消毒技术在医疗领域的应用情景紫外线测试题及答案
- 职业规划与职业发展道路选择测试题及答案
- 2025贵州第二批次安顺市重点人才“蓄水池”需求岗位专项简化程序招聘7人考试笔试备考题库及答案解析
- 中国烟草人才招聘平台中国烟草2026校园招聘笔试考试备考试题及答案解析
- 2025年宝鸡阜丰生物科技有限公司招聘(26人)考试笔试模拟试题及答案解析
- 2026天津市气象部门事业单位招聘应届毕业生1人(第2号)笔试考试备考试题及答案解析
- 2025年永丰县自然资源局面向社会公开招聘编外工作人员笔试考试参考题库及答案解析
- 2025四川成都市新都区中医医院编外人员招聘18人笔试考试备考题库及答案解析
- 2025四川凉山德昌县人民医院招聘皮肤科医师5人考试笔试备考试题及答案解析
- GB/T 5169.23-2024电工电子产品着火危险试验第23部分:试验火焰聚合物管形材料500 W垂直火焰试验方法
- MOOC 概率论与数理统计-南京邮电大学 中国大学慕课答案
- 招标代理服务服务方案
- 2023年大庆杜尔伯特蒙古族自治县事业单位人才引进考试真题及答案
- 2024届高考现代文阅读之小说叙事的对话性(含答案)
- 原子弹设计方案(巴基斯坦,1992)
- 高危新生儿的护理
- 免疫抑制剂药物临床应用指南
- 2024年高中语文小说阅读专题之海明威《桥边的老人》原文+真题+答案+解析
- 青岛科技大学油气储存与装卸期末复习题
- 【高中语文】《逻辑的力量》教学设计+统编版+选择性必修上册
评论
0/150
提交评论