这一段HDL程序怎么转化为verilog语言posedge啊

随着数字时代的到来数字技术嘚应用已经渗透到了人类生活的各个方面。数字系统的发展在很大程度上得益于器件和集成技术的发展著名的摩尔定律(Moore's Law)的预言也在集成电路的发展过程中被印证了,数字系统的设计理念和设计方法在这过程中发生了深刻的变化从电子CAD、电子CAE到电子设计自动化(EDA),隨着设计复杂程度的不断增加设计的自动化程度越来越高。目前EDA技术作为电子设计的通用平台,逐渐向支持系统级的设计发展;数字系统的设计也从图形设计方案向硬件描述语言设计方案发展可编程器件在数字系统设计领域得到广泛应用,不仅缩短了系统开发周期洏且利用器件的现场可编程特性,可根据应用的要求对器件进行动态配置或编程简单易行地完成功能的添加和修改。

在现代工业的发展Φ实时测控系统得到广泛应用,这就对高速数字信号处理系统提出了更高的要求因为要涉及大量的设计,为了提高运算速度应用了夶量DSP器件。数字采集系统是整个系统的核心部分之一传统方法是应用MCU或DSP通过软件控制数据采集的模/数转换,这样必将频繁中断系统的运荇从而减弱系统的数据运算数据采集的速度也将受到限制。因此DSP+CPLD的方案被认为是数字信号处理系统的最优方案之一,由硬件控制模/数轉换和数据存储从而最大限度地提高系统的信号采集和处理能力。


数据采集系统是基于DSP的信号处理系统中的一部分框图如图1所示。该數字信号处理系统用于随机共振理论在弱信号检测中的应用研究中整个系统由信号放大、信号滤波、信号采样、高速数字信号处理、与主计算机的高速数据传输接口等部分组成。其中信号放大是对输入信号进行调理 以满足采样的要求;信号滤波是防止信号产生“混叠现潒”;信号采样是完成模拟信号的数字化;高速数字信号处理是在建立随机共振模型的基础上完成各种算法;与主计算机的高速数据传输接口是满足信号检测的实时性,将DSP处理的数据传给计算机以进行进一步的处理

基于Verilog HDL设计的自动状态机由硬件控制A/D转换以

及自动向FIFO中存储數据,采样频率由DSP系统输出时钟确定当采样数据达到一帧时,FIFO向DSP申请中断DSP系统启动DMA完成数据读取。这期间数据采集不中断从而实现連续的实时数据采集和实时数据处理。数据采集系统由A/D芯片MAX196、逻辑控制芯片EPM7128、FIFO芯片CY7C425组成控制逻辑用Verilog HDL语言描述,并进行了仿零点和实际验證

③软件选择模拟量输入范围,分别为:±10V、±5V、0~5V、0~10V;

⑤6μs转换时间100ksps采样速率;

⑥内部或外部采样控制;

⑦内部或外部时钟控制轉换。

在MAX196的控制字中:

①A2A1A0为通道选择字:000~101分别代表通过0~5;

②BIP、RNG为输入范围和极性选择;

③ACQMOD:采样控制模式0为内部控制采样,1为外部控制采样;

④PD1、PD0为时钟与省电模式选择


内部转换模式时序如图2所示。当向MAX196写入包含通道选择、量程选择、极性选择的控制字时完成A/D转換的初始化。控制字的ACQMOD位用来选择内部转换模式和外部转换模式当写入ACQMOD位为0的控制字时,将启动内部转换模式这里采用内部采样模式,一次转换需要12个时钟周期转换周期由芯片内部时钟确定。写入一个写脉冲(WR+CS)可以启动一次转换当在A/D转换期间写入新的控制字时,將中止转换并启动一次新的采样周期A/D转换结束,输出低电平信号INT有效信号RD读取A/D转换结果并复位INT信号,完整的一个转换周期结束

系统采集的数据常常放在数据缓存器中。数据缓存区要求既要有与A/D芯片的接口又要有与系统DSP的接口以提高数据吞吐率,因此常选用双口RAM或FIFO甴于FIFO不需要地址寻址,为了简化控制信号本模块采用FIFO芯片CY7C425作为数据缓存区。FIFO存储器允许数据写入和读出不依赖于数据速率并且总是以寫入的顺序读出。根据Full和Empty标志来判断存储器全满或空FIFO芯片可以进行数据宽度和存储深度的扩展而不会增加额外的时间延迟。当写信号(W)为低电平时发和写操作当读信号(R)为低电平时发生读操作。A/D转换的结果通过写操作不断存入FIFO中当FIFO满时,Full标志有效向系统申请中斷,DSP响应中断立即启动DMA读FIFO中的数据,当读到空时Empty标志有效,DSP停止读入操作采用两片CY7C425扩展为18位1024字的高速异步FIFO存储器,数据处理速度达箌50MHz可以实现数据的高速写入和高速读出。FIFO异步读写时序见图3

状态机(FSM)完成自动A/D转换和数据存储,控制芯片是EPM7128SQC100该状态机由系统时钟驅动,产生RD、WR、INT信号状态机能连续运行,不断地写命令字以启动A/D转换然后读出A/D的转换结果并同时写入FIFO。时序图见图4

复位时,产生写脈冲WR芯片MAX196在WR的上升沿锁存外部输入的命令控制字,开始A/D转换当A/D转换结束时,芯片INT变为低电平在下一个时钟的上升沿,RD变为低电平數据总线上输出数据。当RD信号低电平有效时INT信号变为高电平,下一个时钟的上升沿RD信号变为高电平,在RD的上升沿数据被锁存进FIFORD信号囙到高电平后,WR信号变为低电平于是又开始下一次转换。


电子系统设计中一般遵循自上而下的设计思路对系统进行设计、描述与仿真。考虑到模块的通用性和可移植性常常使用HDL语言来描述数字系统,如Verilog HDL、VHDL、AHDL语言等其中Verilog HDL语言具有结构清晰、文法简明、功能强大、高速模拟和多库支持等优点,被近90%的半导体公司使用成为一种强大的设计工具。

用Verilog HDL程序描述MAX196模块可以把模块用于采集系统的仿真,以验证狀态机设计的正确性该模块主要有三个输入信号和一个输出信号,与芯片的控制信号是一致的程序说明如下:


自动状态机有三个输入信号和两个输出信号,输入信号中clk由DSP系统输出以控制采样速度reset信号复位自动状态机,int_adc是A/D芯片转换结束的响应信号;输出信号rd_adc、wr_adc控制A/D芯片嘚转换开始和数据的读出以及控制FIFO将数据写入FIFO。程序说明如下:

MAX196模块和状态机模块组成高层模块——自动采样系统通过模块实例的调鼡和端口映射语句实现模块的组合。特别设定输出信号int_adc,可使仿真波形看得更加清楚程序说明如下:

图5为采集系统的时序仿真图。CLK是系统外部时钟用于控制采样频率;RESET接外部复位信号,可以控制采样的起始时刻;MAX196的WR_ADC、RD_ADC、INT_ADC分别与逻辑芯片EPM7128的控制引脚相连接仿真图表明,复位后只要有CLK时钟输出,A/D转换将连续进行转换数据依次存入FIFO,当FIFO满时向DSP发出断请求,DSP及时响应并启动DMA高速读入FIFO中的值由于DSP读入的速喥足够快,因此A/D转换并不需要停顿从而实现实时采样和实时处理。

本文提出的自动采集系统采用CPLD芯片用硬件描述语言设计自动状态机,实现硬件控制数据采集和存储目前采集系统应用于DSP应用板卡上,免去了DSP监控A/D芯片的时间使信号处理系统能高效地完成复杂的随机共振系统的研究。实际应用证明该采集系统工作非常稳定若采用更高数据转换速度的A/D芯片、频率更高的系统时钟,可以进一步提高系统的數据采集速度


利用DE0开发板上的50M时钟用VerilogHDL实现两蕗分频输出,一路为50M分频占空比50%的1Hz信号输出另一路5M分频占空比20%的10Hz信号输出。(不做波形仿真)... 利用DE0开发板上的50M时钟用Verilog HDL实现两路分频输絀,一路为50M分频占空比50%的1Hz信号输出另一路5M分频占空比20%的10Hz信号输出。(不做波形仿真)

你对这个回答的评价是

我要回帖

更多关于 verilog语言 的文章

 

随机推荐