完善资料让更多小伙伴认识你,还能领取20积分哦, 立即完善>
可综合的语法子集1 本文节选自特权同学的图书《FPGA设计实战演练(逻辑篇)》 配套例程下载链接:http://pan.baidu.com/s/1pJ5bCtt 所谓可综合的语法,是指硬件能够实现的一些语法,这些语法能够被EDA工具所支持,能够通过编译最终生成用于烧录到FPGA器件中的配置数据流。无论是Verilog语言还是VHDL语言,可综合的子集都很小。但是如何用好这些语法,什么样的代码风格更适合于硬件实现,是每一位初学者都需要下功夫好好掌握的。(特权同学,版权所有) 下面是常用的RTL级的Verilog语法及其简单的用法描述。Verilog和C语言的语法上确实有很多相似相通之处,学习语法时相互类比进行记忆也未尝不可,但是笔者担心一旦过多的混淆C语言和Verilog,会让初学者误入歧途,毕竟Verilog和C语言在本质上存在着很大的差异,尤其是他们的设计思想和实现载体存在着很大的差异,所以希望大家在语法的学习过程中,尽可能多去了解和比对相关语法最终实现的硬件电路,从而尽快的从软件式的顺序思维中解脱出来,更好的理解硬件式的并行处理。(特权同学,版权所有) (1) 模块声明类语法:module…endmodule。(特权同学,版权所有) 在每个verilog文件中都会出现该语法,它是一个固定的用法,所有的功能实现语法最终都应该包括在“…”中。Module的语法如下所示,module后的my_first_prj为该module的命名,取名没有任何限制(默认数字、下划线和字母的组合均可),随后一个“()”内罗列出该模块所有的输入输出端口信号名。(特权同学,版权所有) module my_first_prj(<端口信号列表> … ); <逻辑代码> … endmodule (2) 端口声明:input, output,inout(inout的用法比较特殊,需要注意)。(特权同学,版权所有) 每个module都会有输入输出的信号用于和外部器件或其他module通信衔接。对于本地module而言,这些信号无非可以归为三类,即输入(input)信号,输出(output)信号和双向(inout)信号。通常在module语法后紧接着就要申明该模块的所有用于与外部接口的信号。语法上来讲,这些信号名也都要在module名后的“()”内列出。(特权同学,版权所有) 最常见的三种端口申明实例如下: input clk; input wire rst_n; input [7:0] data_in; 第1个申明表示1bit的名称为clk的输入信号端口,第2个申明表示wire类型的1bit的名称为rst_n的输入信号,第3个申明则表示8bit的名称为data_in的输入信号。(特权同学,版权所有) |
|
相关推荐
1 个讨论
|
|
只有小组成员才能发言,加入小组>>
885个成员聚集在这个小组
加入小组4533 浏览 0 评论
特权同学 Verilog边码边学 Lesson01 Vivado下载与安装
2647 浏览 1 评论
玩转Zynq连载50——[ex69] FIR滤波器IP仿真实例
4332 浏览 2 评论
玩转Zynq连载49——[ex68] MT9V034摄像头的图像FFT滤波处理
5269 浏览 1 评论
玩转Zynq连载48——[ex67] Vivado FFT和IFFT IP核应用实例
5315 浏览 0 评论
1943浏览 0评论
小黑屋| 手机版| Archiver| 电子发烧友 ( 湘ICP备2023018690号 )
GMT+8, 2024-12-22 21:11 , Processed in 0.667593 second(s), Total 68, Slave 52 queries .
Powered by 电子发烧友网
© 2015 bbs.elecfans.com
关注我们的微信
下载发烧友APP
电子发烧友观察
版权所有 © 湖南华秋数字科技有限公司
电子发烧友 (电路图) 湘公网安备 43011202000918 号 电信与信息服务业务经营许可证:合字B2-20210191 工商网监 湘ICP备2023018690号