一、各类存储器简介ROM:只读,只有读接口(读地址、读数据)RAM:可读可写,有读接口(读地址、读数据)和写接口(写使能、写数据、写地址),默认任何时刻都能读,没有读使能,大小和位宽查手册,需要持续供电才能将数据保存在其中(易失性存储器),断电数据丢失单端口RAM:读写共用一个数据通道,读写不能同时进行伪双端口RAM:两个数据通道,一个用来读一个用来写真双端口RAM:两个数据通道,都可以用来读或写DRAM:动态随机存取存储器,数据存储在电容器中,通过保持电荷实现数据存储(比如电容器充电和放电分别为1和0),价格低,消耗功率高,最常用作计算机的主存储器,需要不断刷新(由于电容器内部用于分隔导电板
信号发⽣器的设计与实现1.输出波形:⽅波(占空⽐50%)、锯⻮波、三⻆波、脉冲信号(占空⽐连续可调)、正弦波、任意波等2.输出频率:100KHz3.波形选择:使⽤拨码开关选择思路: 使用FPGA搭建信号发生器DDS,重点是制作能够提前下载进开发板板载ROM的数据文件,这里用到的是mif文件,里面保存了数种波形(正弦波,方波,三角波,锯齿波)的点值,这些点值是由前期采样得来的,然后编写verilog代码,实现功能选择(波形选择等),在quartus中配置所选器件的ROM,将mif文件加载进去,在代码中调用rom中的数据,然后仿真时绘制显示波形,这时显示的是离散的数字信号,可以在仿真端mods
循环语句分为以下4种:for语句——通过三个步骤来决定语句的循环执行:1.给控制循环次数的变量赋初值;2.判定循环执行条件,若为假则跳出循环;若为真,则执行指定语句后,转到第三步3.修改循环变量的值,返回第二步repeat——连续执行一条语句n次;while——执行一条语句,直到循环条件不满足;若一开始条件不满足,则该语句一次也不能执行forever——无限连续的执行语句,可用disable语句中断。for语句形式:for(循环变量赋初值;循环执行条件;循环变量增值)执行语句例:用for语句描述7人投票表决器:超过4人投赞成票,则表决通过modulevote7( outputpass, i
Verilog语法Verilog简介Verilog是一种硬件描述语言,以文本形式来描述数字系统硬件的结构和行为的语言,用它可以表示逻辑电路图、逻辑表达式,还可以表示数字逻辑系统所完成的逻辑功能。Verilog和C的区别:Verilog是硬件描述语言,编译下载到在编译下载到FPGA之后,会生成电路,所以Verilog全部是并行处理与运行的C语言是软件语言,编译下载到单片机/CPU之后,还是软件指令,而不会根据代码生成相应的硬件电路,而单片机/CPU处理软件指令需要取址、译码、执行,是串行执行的。Verilog逻辑值逻辑电路中有四种值,即四种状态逻辑0:表示低电平,对应电路的GND逻辑1:表示高电
目录1.算法描述2.仿真效果预览3.verilog核心程序4.完整verilog1.算法描述 AES,高级加密标准,是采用区块加密的一种标准,又称Rijndael加密法.严格上来讲,AES和Rijndael又不是完全一样,AES的区块长度固定为128比特,秘钥长度可以是128,192或者256.Rijndael加密法可以支持更大范围的区块和密钥长度,Rijndael使用的密钥和区块长度均可以是128,192或256比特.AES是对称加密最流行的算法之一. AES算法在对明文加密的时候,并不是把整个明文一股脑的加密成一整段密文,而是把明文拆分成一个个独立的明文块,每一个明文块长度1
文章目录前言一、便携式数字示波器设计1.1设计原理及思路1.2系统技术指标二、示波器各模块作用2.1LCT2308介绍2.2adc.v模块介绍2.3time_scaler.v模块介绍2.4trigger.v模块介绍2.5vga.v模块介绍三、VGA两种像素数据传递方式四、硬件介绍及结果分析五、工具使用5.1运用逻辑分析仪及Modelism5.2制作嵌入式linux-SD系统启动卡5.3学习HPS和FPGA的地址映射5.4将电脑与开发板通过NFS进行挂载六、设计过程中方向上出现的问题前言 本设计是一个4通道便携式数字示波器,采用DE1-SOC双核心开发板进行设计。示波器的数模转换器采用LCT2
目录前言一、时钟BUFFER使用总结二、普通IO输出时钟信号时的推荐方法使用ODDR前言Xilinx-FPGA开发过程中,关于时钟信号和普通IO信号引入FPGA内部需要遵循一定的使用方法,现在自己一年多使用过的内容做一个总结,也供新手参考。关于BUFFERS原语,主用用于对端口时钟信号及其他重要信号的缓冲和驱动,满足FPGA底层硬件综合布线规则,以正确且充分的利用FPGA全局时钟树资源。一、使用总结1、IBUFG+BUFGIBUFG+BUFG是最常用的使用方法,可以用BUFGP,BUFGP=IBUFG+BUFG。个人经验:如工程设计中使用局时钟树资源,一般使用clockingwizardIP和
写在前面 在自己准备写一些简单的verilog教程之前,参考了许多资料----Asic-World网站的这套verilog教程即是其一。这套教程写得极好,奈何没有中文,在下只好斗胆翻译过来(加了自己的理解)分享给大家。 这是网站原文:VerilogTutorial 这是系列导航:Verilog教程系列文章导航 Verilog语法中有四种基本的循环语句,他们都只能在always和initial块中使用:foeverrepeatwhilefor 这些语句基本都和C语言中的对应语句类似,如果你学过C语言(或者其他变成语言),那么对这4中语句的用法都不
前言在学习Verilog的过程中,相信大家都陷入了一个怪圈,那就是对于写模块相当拿手,但是一到编写仿真激励的时候就开始“抓瞎”,不知从何写起,本人也是一样。发现问题就要积极解决问题,因此,总结一篇博客(今后会不断更新)来介绍常用的一些基础仿真语句,供自己总结,也供大家查用。编译指令编译指令起源于C语言当中的预处理指令,一般写在文件开头,编译器首先处理这些指令,配置仿真的一些相关参数,他们都是以反引号`开头。`timescale指令`timescale1ns/100ps//句法为`timescale延时单位/最小时间粒度;仿真文件往往都是以`timescale开头的,这个指令的作用是设置仿真文件
学习笔记(3):Verilog数字逻辑电路设计方法1.Verilog语言设计思想和可综合特性2.Verilog组合逻辑电路2.1数字加法器2.2数据比较器2.3数据选择器2.4数字编码器2.5数字译码器2.6奇偶校验器3.时序电路3.1触发器3.1.1简单的D触发器3.1.2带复位端(清零端)D触发器:3.1.3复杂功能D触发器3.1.4T触发器3.2计数器3.2.1二进制计数器3.2.2任意模数的计数器3.3移位寄存器3.4序列信号发生器4.有限同步状态机来源:蔡觉平老师的Verilog课程1.Verilog语言设计思想和可综合特性例:用Verilog设计模256(8bits)计数器(a)可