关于verilog的学习经验简单分享

时间:2025-09-11  作者:Diven  阅读:0

我学verilog语言进行FPGA设计也就半年时间,很多的东西就是在网上学到的,现在想说说自己对使用verilog进行FPGA设计的一些体会,我水平不高,主要是为新手朋友们介绍自己的一点经验少走点弯路。

关于verilog的学习经验简单分享

1、verilog语言

学习verilog最重要的不是语法,“因为10%的语法就能完成90%的工作”,verilog语言常用语言就是always@(),if~else,case,assign这几个了,不用去专研繁杂的语法,有些问题等你碰到了查查书就好了。这里推荐夏雨闻老师的《verilog数字系统设计教程》,一本很适合新手的好书。

2、硬件原则

虽然verilog语言很象c语言,但和c语言还是有本质的区别的,因为verilog进行的是硬件设计,你写出来的东西是实实在在电路,所以要有数字电路的知识是肯定的。数字电路就是由时序电路(触发器)和组合逻辑电路(各种逻辑门)构成的,用verilog写的程序在FPGA实现就是触发器逻辑门,所以最重要的就是“你对你写的语言生成的电路心中有数”,做到这一点你就不会有写出来的程序不能综合的麻烦,电路的冗余逻辑肯定也是最少的。还要注意一点就是verilog程序是并行的,不是象c那样是顺序执行的,这是因为fpga硬件可配置,可形成不同的任务单元同时工作;而单片机这种基于通用目的,硬件结构也固定了,处理任务只能一件一件顺序的进行。

3、同步原则

在进行FPGA设计的时候,同步原则应该是最重要的原则了,因为异步电路的不可控性,很可能有毛刺产生,而在芯片内部的任何一点毛刺都会一级一级的传递下去,最终影响系统的稳定性。同步原则用一句话来就是“不要试图产生自己的时钟”,最好一个设计或者一个模块只使用同一个时钟,这样所有的触发器都在同一个时钟沿跳变,当然最稳定了,系统也能跑到很高的速度。一个小技巧就是多使用触发器的使能端和取沿电路。

4、养成好的代码习惯

很多的细节,比如缩进、命名、参数化、组合逻辑和时序逻辑分离、注释等等,也就是大家说的代码风格。这个其实很重要,最好在一开始就养成好的习惯,这样会为你以后的工作节省很多时间,也会大大提高工作的质量。不注意这个将很吃很多的苦头 ,细节决定成败啊。

5、工具

工具永远就是工具,最重要的是学会怎么使用,不用去研究,用的多了自然就熟练了,遇到那个问题了自然就会去找到问题的答案,不用开始就抱着工具的手册狂看,问问别人很简单的。

猜您喜欢

据麦姆斯咨询报道,近日,新加坡国立大学(National University of Singapore)和新加坡科技研究局(A*STAR)微电子研究所的研究人...
2023-08-03 09:38:00

热敏电阻作为重要的温度检测和保护元件,应用于各类电子设备中。科达嘉(CODACA)作为国内知名的电子元器件品牌,其PTC热敏电阻凭借优异的性能和可靠的品质,受到...
2020-08-30 05:36:44

贴片电阻上的E22并非直接代表电阻值,而是代表电阻值代码。表示该电阻的阻值为2.2欧姆。贴片电阻通常使用数字字母组合来标记阻值,这种标记方式更加简洁,方便印刷在...
2024-11-29 10:25:29

在现代电子设备中,时钟消抖是确保信号稳定性的重要技术。那么,时钟消抖的规格尺寸到底是多少呢?时钟消抖的规格通常取决于具体的应用需求和设备类型。常见的时钟消抖模块...
2010-02-19 00:00:00


防硫化电阻因其优异的防硫化性能和稳定的电气特性,应用于各种工业和消费电子产品中。丽景电子作为国内知名的电子元件制造商,其防硫化电阻系列产品受到市场青睐。本文将围...
2020-11-29 07:09:15

12角套筒是常见的工具,应用于机械维修和汽车保养等领域。与传统的6角套筒相比,12角套筒在设计和功能上存在一些显著区别。12角套筒的接触面更多,这意味着能够更好...
2018-06-20 00:00:00

电容和电池是两种常见的电能储存设备。很多人会问,电容能否替代电池使用?这个问题值得探讨。本文将详细分析电容和电池的不同之处,以及电容在某些情况下的应用。电容和电...
2025-03-24 15:01:41

你是否想过,是什么让电子设备如此精准地工作?答案之一就是:贴片电阻。这些不起眼的小元件,如同电路中的精密阀门,精准地控制着电流的大小,确保电子设备稳定运行。贴片...
2025-04-14 15:03:22

硬度块是用于测量材料硬度的重要工具,其规格尺寸直接影响测试的准确性和适用性。常见的硬度块规格包括多个标准尺寸,如25mm x 25mm x 10mm、50mm ...
2023-12-26 00:00:00