




已阅读5页,还剩14页未读, 继续免费阅读
版权说明:本文档由用户提供并上传,收益归属内容提供方,若内容存在侵权,请进行举报或认领
文档简介
课程设计基于verilog hdl的数字秒表设计系别:物理与电气工程学院专业:微电子学班级:班成员:目录一、前言3二、实验目的.3三、功能设计3四、用verilog描述电路.44.1时钟调校及计时模块44.2整数分频模块.84.3时钟信号选择模块84.4七段显示设置11 4.4.1 bcd码显示模块11 4.4.2二位七段显示模块12 4.4.3一位七段显示模块124.5顶层模块实现14五、模拟与仿真.15六、逻辑综合.16七、下载到硬件电路16八、总结.18九、心得体会.18十、参考文献.19一、前言随着微电子技术的的飞速发展,大规模可编程器件的密度和性能不断提高,数字系统的设计方法、设计过程也发生了重大改变,传统的设计方法已经逐渐被电子设计自动化eda(electronic design automation)工具所取代。可编程器件可以通过硬件描述语言(如verilog hdl)的形式根据实际设计的需要灵活地嵌入规模化的数字单元,大大地缩短了产品的设计周期。以可编程逻辑器件为核心的设计在数字系统设计领域将占据越来越重要的作用,因此,作为硬件设计者掌握eda设计方法和工具是必须的。二、实验目的(1)通过本次课程设计加深对verilog语言课程的全面认识、复习和掌握。(2)掌握定时器、外部中断的设置和编程原理。(3)通过此次课程设计能够将软硬件结合起来,对程序进行编辑、调试。使其能够通过电脑下载到芯片,正常工作。(4)实际操作quartusii软件,复习巩固以前所学知识。三、功能设计数字钟是一个常用的数字系统,其主要功能是计时和显示时间。这里通过一个数字钟表的模块化设计方法,说明自顶向下的模块化设计方法和实现一个项目的设计步骤。这里实现的电子表具有显示和调时的基本功能,可以显示时、分秒和毫秒,并通过按键进行工作模式选择,工作模式有4种,分别是正常计时模式、调时模式、调分模式、调秒模式。构成电子表的基本基本模块有四个,分别是时钟调校及计时模块myclock、整数分频模块int_div、时钟信号选择模块clkgen和七段显示模块disp_dec。四、用verilog实现电路4.1时钟调校及计时模块时钟调校及计时模块myclock实现的功能是根据当前的工作状态进行时、分、秒的调整或正常的计时。代码端口说明如下:输入信号:rstn复位信号clk100hz时钟信号flag1:0工作模式控制信号,模式定义为:00表示正常显示,01表示调时,10表示调分,11表示调秒;up调校模式时以加1方式调节信号;dn调校模式时以减1方式调节信号。输出信号:h7:0“时”数据(十六进制);m7:0“分”数据(十六进制);s7:0“秒”数据(十六进制);ms7:0“百分秒”数据(十六进制)。该模块的设计思路是,当复位信号rstn有效时,时、分、秒信号清零,否则工作模式控制信号flag的值决定当前的工作状态。当flag=2b00时,电子表工作在正常计时状态,对输入的100hz的时钟信号clk进行计数,修改当前的百分秒(ms)、秒(s)、分(m)和时(h)的计数值;当flag信号=2b01时,电子表工作在“时”校正状态,若此时up信号有效则h加1,若此时dn信号有效则h减1,;当flag信号=1b10时,电子表工作在“分”校正状态,若此时up信号有效则m加1,若此时dn信号有效则m减1;当flag=2b11时,电子表工作在“秒”校正状态,其up和dn的控制过程与“时”、“分”类似代码:module myclock(rstn,clk,flag,up,dn,h,m,s,ms);inputrstn,clk,up,dn;output 7:0 h,m,s;output 7:0 ms;input1:0 flag;reg 5:0 m_h,m_m,m_s;reg 6:0 m_ms;assign h=m_h;assign m=m_m;assign s=m_s;assign ms=m_ms;always (posedge clk) if(rstn) /复位状态beginm_h=8d23;m_m=8d52;m_s=8b0;m_ms=8b0;end else if(flag=2b01)/调时状态beginif(up)beginif(m_h=8d23)m_h=8d0;elsem_h=m_h+1b1;endelse if(dn)beginif(m_h=8h00)m_h=8d23;elsem_h=m_h-1b1;endend else if(flag=2b10) /调分状态beginif(up)if(m_m=8d59)m_m=8d0;elsem_m=m_m+1b1;else if(dn)if(m_m=8h00)m_m=8d59;elsem_m=m_m-1b1;end else if(flag=2b11) /调秒状态beginif(up)if(m_s=8d59)m_s=8b0;elsem_s=m_s+1b1;else if(dn)if(m_s=8h00)m_s=8d59;elsem_s=m_s=m_s-1b1;endelse begin /正常计时状态if(m_ms=8d99)beginm_ms=8d0;if(m_s=8d59)beginm_s=8d0;if(m_m=8d59)beginm_m=8d0;if(m_h=8d23)m_h=0;elsem_h=m_h+1b1;endelsem_m=m_m+8d1;endelsem_s=m_s+1b1;endelsem_ms=m_ms+1b1;endendmodule4.2整数分频模块由于数字系统提供的基准时钟信号频率往往较高,因此需要分频模块产生所需频率的失踪信号,例如上面时钟校正及计时模块所需的100hz的时钟信号。整数分频模块int_div可以实现对输入时钟clock进行f_div分频后输出clk_out。f_div分频系数范围为12n(n=f_div_width),若要改变分频系数,改变参数f_div或f_div_width到相应范围即可。若分频系数为偶数,则输出时钟占空比为50%;若分频系数为奇数,则输出的时钟占空比取决于输入的时钟占空比和分频系数(当输入为50%时,输出也是50%)。代码:moduleint_div(clock,clk_out); parameter f_div=48000000; /分频系数 parameter f_div_width=32; /分频计数器宽度 input clock; /输入时钟 output clk_out; /输出时钟regclk_p_r;regclk_n_r;regf_div_width-1:0 count_p;regf_div_width-1:0 count_n; wire full_div_p; /上升沿计数满标志 wire half_div_p; /上升沿计数半满标志 wire full_div_n; /下降沿计数满标志 wire half_div_n; /下降沿计数半满标志/判断计数标志位置位与否assignfull_div_p=(count_pf_div-1);assignhalf_div_p=(count_p1)-1);assignfull_div_n=(count_nf_div-1);assignhalf_div_n=(count_n1)-1); /时钟输出assignclk_out=(f_div=1)?clock:(f_div0?(clk_p_r&clk_n_r):clk_p_r); always (posedge clock) /上升沿脉冲计数beginif(full_div_p)begincount_p=count_p+1b1;if(half_div_p)clk_p_r=1b0;elseclk_p_r=1b1;endelsebegincount_p=0;clk_p_r=1b0;endend always (negedge clock) /下降沿脉冲计数beginif(full_div_n)begincount_n=count_n+1b1;if(half_div_n)clk_n_r=1b0;elseclk_n_r=1b1;endelsebegincount_n=0;clk_n_r=1b0;endendendmodule4.3时钟信号选择模块时钟信号选择模块clkgen实际上时一个二选一电路,用于提供时钟调校及计时时模块所需的时钟脉冲。当电子表工作在正常计时状态时选择100hz时钟信号;当电子表工作在调时、调分、调秒是那种设置模式时,如果采用100hz时钟信号,那么手动一次按键可能引起设置数据的一串跳变,因此为了方便按键时动作对时间的设置,这里采用2hz的时钟信号。其端口说明如下:flag时钟选择输入信号;clk_100hz输入100hz的时钟信号;clk_2hz输入2hz的时钟信号;clkout输出时钟信号。代码:moduleclkgen(flag,clk_100hz,clk_2hz,clkout); input1:0 flag; /若flag=0则clkout=100hz,否则clkout=2hzinput clk_100hz,clk_2hz;outputclkout;assignclkout=(flag=2b00)?clk_100hz:clk_2hz;endmodule4.4七段显示设置为了对时钟时、分、秒和毫秒数据输出显示,需要将时、分、秒和毫秒的二进制转换为十进制数。由于时、分、秒最大到60,毫秒最大到99,所以十进制数选择2位就能满足要求。为了在七段数码管输出时间数据,还需要将显示的十进制数转化为七段段码。以上功能分别由bcd码显示模块和七段译码管模块来实现。4.4.1 bcd码显示模块bcd码显示模块的功能是将8位二进制数转化为2位十进制数后,进行七段段译码显示。为了实现显示功能,在其内部调用了dual_hex2位七段显示模块。其端口说明如下:输入信号:hex2位8421bcd码输入。输出信号:dispout2位8421码对应的七段数码管段码。代码:moduledisp_dec(hex,dispout); input7:0 hex;/八位二进制输入数据 output15:0 dispout; /2位十进制的七段段码显示数据reg7:0 dec;always (hex) begin /8位二进制数转化为2位bcd码dec7:4=hex/4d10;dec3:0=hex%4d10;enddual_hex u1(1b0,dec,dispout); /调用2位共阳极七段显示模块endmodule4.4.2二位七段显示模块二位七段显示模块的功能是将2进制或十六进制数转化为对应的七段段码,内部调用了一位七段译码模块seg_decoder。代码:moduledual_hex(iflag,datain,dispout); input iflag; /共阴或共阳输出选择 input7:0 datain; /2位的十进制或十六进制数据 output15:0 dispout;/2个七段段码数据seg_decoderu1(iflag,datain7:4,dispout15:8);seg_decoderu2(iflag,datain3:0,dispout7:0);endmodule4.4.3 一位七段译码模块一位七段译码模块的功能是将4位二进制数转化为对应的共阴或共阳七段段码。代码:moduleseg_decoder(iflag,ia,oy); input iflag; /共阴或共阳输出选择 input3:0 ia; /4位二进制数据 output reg7:0 oy; /七段段码显示数据always (iflag,ia)begin case(ia)/共阴级七段输出 4b0000:oy=8h3f; 4b0001:oy=8h06; 4b0010:oy=8h5b; 4b0011:oy=8h4f; 4b0100:oy=8h66; 4b0101:oy=8h6d; 4b0110:oy=8h7d; 4b0111:oy=8h27; 4b1000:oy=8h7f; 4b1001:oy=8h6f; 4b1010:oy=8h77; 4b1011:oy=8h7c; 4b1100:oy=8h58; 4b1101:oy=8h5e; 4b1110:oy=8h79; 4b1111:oy=8h71;endcaseif(!iflag)oy=oy; /共阳极七段输出endendmodule4.5、顶层模块的实现顶层模块是将各功能模块连接起来,实现电子表的完整功能。其端口信号说明如下:输入信号:iclk5050mhz时钟信号;rstn复位信号;flag工作模式控制信号,模式定义为:00表示正常显示,01表示调时,10表示调分,11表示调秒;up调校模式时以加1方式调节信号;dn调校模式时以减1方式调节信号。输出信号:h_dis“小时”数据的七段数码管数据;m_dis“分钟”数据的七段数码管数据;s_dis“秒”数据的七段译码管数据;ms_dis“百分秒”数据的七段译码管数据;mode工作模式输出;h“时”数据(十六进制);m“分”数据(十六进制);s“秒”数据(十六进制);ms“百分秒”数据(十六进制)。代码:module clock(iclk_50,rstn,flag,up,dn,h_dis,m_dis,s_dis,ms_dis,mode,h,m,s);input iclk_50;inputrstn,up,dn;input 1:0 flag;output 1:0 mode;output 15:0 h_dis,m_dis,s_dis,ms_dis;output 7:0 h,m,s;wire 7:0 ms;wire clk_100hz,clk_2hz;wireclk;assign mode=flag;int_div#(500000,32) nclk100(iclk_50,clk_100hz);int_div#(50000000,32) nclk2(iclk_50,clk_2hz);clkgen u0(flag,clk_100ha,clk_2hz,clk);myclock u1(rstn,clk,flag,up,dn,h,m,s,ms);disp_dec hour(h,h_dis);disp_dec minute(m,m_dis);disp_dec second(s,s_dis);disp_dec hour(ms,ms_dis);endmodule五、模拟与仿真在quartus ii中利用仿真波形进行功能或时序仿真的基本步骤如下:(1)创建新的矢量波形文件(*.vwf).(2)添加输入、输出节点。(3)编译输入节点的波形。(4)完成矢量波形文件的创建之后,用户即可以对设计进行功能或时序仿真。(5)仿真启动后,状态窗口会同时自动打开,在状态窗口中显示仿真进度及所用时间。(6)默认情况下,仿真器报告窗口内在仿真过程中会显示仿真波形部分,其中还包括当前仿真器的设置信息和仿真信息等。计时状态仿真波形六、逻辑综合完成项目创建和设计输入后,用quartus ii的编译器(compiler)对设计进行检查和逻辑综合,并生成用于配置可编程逻辑器件的下载文件。quartus ii编译器中的analysis & synthesis模块将分析设计文件并建立工程数据库。该模块使用quartus ii内置综合器,综合verilog hdl设计文件(.v)。(1) 编译器件选项设置。(2) 引脚分配。(3) 编译设计。(4) 查看适配结果。七、下载到硬件电路在设计(工程)编译成功后,便可以对所选的(altera)目标器件进行编程和配置。quartus ii编译器的assembler 模块将会对工程的各个组件转换成编程文件,包括编译器对象文件(*.pof)和sram对象文件(.sof)。quartus ii编译器(progrsmmer)可以使用这些编程文件与altera编程硬件配合,对quartus ii软件所支持的altera器件进行编程和配置。秒显示分显示八、总结在quartusii开发环境下,采用自顶向下的设计方法有利于在早期发现结构设计中的错误,避免不必要的重复设计。再结合基于fpga的“在系统”可编程实验板,轻轻松松就能实现各种电子产品的设计,现场观察实验测试结果。大大缩短了产品的设计周期和调试周期,提高了设计的可靠性和成功率,充分体现了可编程逻
温馨提示
- 1. 本站所有资源如无特殊说明,都需要本地电脑安装OFFICE2007和PDF阅读器。图纸软件为CAD,CAXA,PROE,UG,SolidWorks等.压缩文件请下载最新的WinRAR软件解压。
- 2. 本站的文档不包含任何第三方提供的附件图纸等,如果需要附件,请联系上传者。文件的所有权益归上传用户所有。
- 3. 本站RAR压缩包中若带图纸,网页内容里面会有图纸预览,若没有图纸预览就没有图纸。
- 4. 未经权益所有人同意不得将文件中的内容挪作商业或盈利用途。
- 5. 人人文库网仅提供信息存储空间,仅对用户上传内容的表现方式做保护处理,对用户上传分享的文档内容本身不做任何修改或编辑,并不能对任何下载内容负责。
- 6. 下载文件中如有侵权或不适当内容,请与我们联系,我们立即纠正。
- 7. 本站不保证下载资源的准确性、安全性和完整性, 同时也不承担用户因使用这些下载资源对自己和他人造成任何形式的伤害或损失。
评论
0/150
提交评论