FPGA实验报告实验

上传人:zou****hua 文档编号:185587580 上传时间:2023-02-04 格式:DOCX 页数:15 大小:21.26KB
返回 下载 相关 举报
FPGA实验报告实验_第1页
第1页 / 共15页
FPGA实验报告实验_第2页
第2页 / 共15页
FPGA实验报告实验_第3页
第3页 / 共15页
点击查看更多>>
资源描述
西南科技大学实验报告课程名称:基于FPGA的现代数字系统设计实验名称:基于HDL十进制计数、显示系统设计姓名:学号:班级:通信1301指导教师:刘桂华西南科技大学信息工程学院制基于HDL十进制计数、显示系统设计一、实验目的1、掌握基于语言的ISE设计全流程;2、熟悉、应用VerilogHDL描述数字电路;3、掌握基于Verilog的组合和时序逻辑电路的设计方法;4、掌握chipscope片内逻辑分析仪的使用与调试方法。二、实验原理1、实验内容:设计具有异步复位、同步使能的十进制计数器,其计数结 果可以通过七段数码管、发光二极管等进行显示。2、模块端口信号说明:输入信号:Clk_50m -系统采样时钟clk 待计数的时钟clr 异步清零信号,当 c l r=0 ,输出复位为 0,当clr=1,正常计数ena使能控制信号,当ena=1,电路正常累加计数,否则电路不工作输出信号:q6:0驱动数码管,显示计数值的个位cout1bit数据,显示计数值向十位的进位COM共阳级数码管,公共端(接地,参考开发板原理图3、 以自顶向下的设计思路进行模块划分:整个系统主要设计的模块是:十进制计数模块和数码管驱动模块,由于实验板的按 键为实现硬件防抖,则需要将按键输入的时钟elk,先通 过消抖模块消抖后,再输出至后续使用。1) 十进制计数器模块设计输入: CLK 待计数的时钟CLR 异步清零信号,当 CLR =0,输出复位为0,当 CLR =1,正常计数 。EN使能控制信号,当EN=1,电路正常累加计数,否则电路不工作输出: SUM3:0 计数值的个位。即,在 CLK 上升沿检测到SUM=9时,SUM将被置0,开始新一轮的计数。te 计数值的十位进位,即:只有在时钟 CLK 上升沿检测到SUM=9时,TC将被置1,其余情况下TC=0;在设计中可以使用always, if-else-if语句实现,设计中注意不要在两 个以上的always模块中对同一个变量进行赋值,否则会产生多重赋值源 (mul ti-souree )的问题。2)数码管显示驱动模块()输入:input43:0 待显示的数值 输出:out76:0驱动数码管的七位数值(注意下表中out的对应位)输入sum输出out数码3210iioiino1111n CQOocur+2iiout000000000100011001200100010300110000401001001501010100601100100701110001810000000910010000A10100001b10111100C11000110d11011000E11100110F111101113)消抖模块 (1)按键抖动的产生原因: 通常的按键所用开关为机 械弹性开关,当机械触点断开、闭合时,由于机械触点的弹性 作用,一 个按键开关在闭合时不会马上稳定地接通,在断开时也不会一下子断开。因而在闭 合及断开的瞬间均伴随有一连串的抖动,为了不产生这种现象而作的措施就是按键消抖。(2)本次实验提供的消抖模块简介电平检查模块:检测输入的按键是否被按下或者释放,并分别将H2L_Sig,L2H_Sig拉高,并随后拉低,给出按键的操作信息。延时模块:对输入的信号变化时刻进行计时并观察信号的变换情况,对输出端口进行 恰 当地赋值 实验资料中将给出消抖模块设计源代码。对模块的具体设计 细节不需理解,消抖模块不要求仿真三、实验步骤1、创建工程。为工程,为工程命名、指定存储路径个文件夹。2、计数器及数码管驱动模块设计创建VHD模块文件,对各个模块进行设计(1)计数器模块代码编写module cnt10(clk,clr,en,sum,tc);input clk,clr,en;output reg 3:0 sum;output tc;assign tc=(sum=4b1111);always (posedge clk ,negedge clr)begin if(clr) sum=4b0000;else if(en) begin sum=sum+1b1; if(sum=4b1010) sum=4b0000; endelse sum=sum;endendmodule2)数码管驱动模块代码编写module led(input 3:0 input4,output reg 6:0 out7);always (input4)begincase(input4)4d0:out7=7h01;4d1:out7=7h4f;4d2:out7=7h12;4d3:out7=7h06;4d4:out7=7h46;4d5:out7=7h24;4d6:out7=7h20;4d7:out7=7h0f;4d8:out7=7h00;4d9:out7=7h04;default out7=7h0;endcaseendendmodule(3) cntl0与led模块的组合module top_2(clk,clr,ena,tc,out7);input clk,clr,ena;output tc;output 6:0 out7;wire 3:0 sum;cnt10 cnt(clk,clr,ena,sum,tc);led led1(sum,out7);endmodule4)综合仿真首先对计数器和数码管驱动两个模块进行综合,无误后编写测试激励文件,进行仿真。激励文件及仿真结果如下:得到正确的仿真图形后进行这两个模块组合的综合,创建激励文件,进行仿真。激励文件与仿真结果如下:3、拷贝消抖模块代码:,组合完成消抖模块。4、将消抖模块,十进制计数器,数码管驱动模块组合为一个系统。编写代码如下:module seg_top(clk_50M,clk,clr,ena,out,cout,com);input clk_50M,clk,clr,ena;output com,cout;output 6:0 out;wire clk_out;assign com=0;debounce_module u3(clk_50M,clr,clk,clk_out);top_2 top2(clk_out, clr,ena,cout,out);endmodule然后进行顶层综合。5、引脚锁定根据引脚锁定表,编写约束文件,如下:6、综合报告阅读综合结果报告,记录其中关于时钟频率、资源消耗等关键数据如下:7、 顶层模块完成后,双击 Implement Design ,进行布局布线,双击Generate Programming File 生成下载文件,双击 Configure TargetDevice,按照提示完成下载。8、下载后,改变拨动开关和按键,观察结果。9、使用chipscope片内逻辑分析仪对设计进行硬件调试,验证设计是否 正确。掌握该调试方法和调试步骤。四、实验结果及分析1、对计数器时序图分析:当clr为低电平时(复位信号采用低电平有效),计数器输出0000, 当elk, en (高电平有效)为高电平时,计数器开始正常计数,时钟 信号每来一个上升沿,sum输出端口从0000增加到1001,进位tc变 为为1,再来一个上升沿后,tc变为0, sum又从0000开始计时。显 然时序图符合预期功能,故功能仿真正确。2、对数码管驱动时序图分析:当输入信号从0000变化到1001时,输出信号对应于数码管真值 表中输出的变化。显然功能仿真正确。3、对数码管驱动与计数器的组合模块时序图分析:当输入复位信号en为高电平,clr为高电平时,每来一个时钟信号, 输出out7也变化一次,且变化与数码管驱动真值表中输入从一到十变化 时的输出变化一致。功能仿真真确。五、实验思考题解答(实验指导书要求的思考题)1、如何用两个或一个always实现十进制计数模块?写出相应代码。module cnt10(clk,clr,en,sum,tc );input clk,clr,en;output reg 3:0 sum;output tc;assign tc=(sum=4b1111);always (posedge clk ,negedge clr)beginif(clr) sum=4b0000;else if(en) begin sum=sum+1b1;if(sum=4b1010) sum=4b0000; endelse sum=sum;endendmodule2、如何用always,或assign实现数码管的驱动设计?写出相应代码。module led(input 3:0 input4,output reg 6:0 out7);always (input4)begincase(input4)4d0:out7=7h01;4d1:out7=7h4f;4d2:out7=7h12;4d3:out7=7h06;4d4:out7=7h46;4d5:out7=7h24;4d6:out7=7h20;4d7:out7=7h0f;4d8:out7=7h00;4d9:out7=7h04;default out7=7h0;endcaseendendmodule3、比较实验一与实验二的实验过程,说明原理图输入法与 HDL 输入法 的不同的应用环境。实验一中应用的是原理图完成十进制计数器的数显,工作量相对 较大,需要绘制8张原理图,其中还不包扩消抖模块。所以原理图设 计适合相对简单的电路,门电路较少的电路。而实验二应用HDL语言 描述要完成的功能,对于较复杂的电路设计起来相对简单,所以HDL 语言设计比较复杂的电路。门电路很多的电路。4、 CHIPSCOPE调试和仿真有何区别?modelsim是写好代码后,对设计的功能进行全面的仿真,检查设计中 的问题,不涉及FPGA硬件chipscope 是个调试阶段的调试工具,只能检查局部,部分出问题“的地方的检验,必须涉及FPGA硬件六、体会1、 实验过程中对 verrilog 语言有了进一步的熟悉,对 ISE 设计流程有了 更深入的理解与认识。2、Verilog 硬件描述语言和 c 语言或其他编程语言有着一些相似的地 方,但是也存在很大差异。在实验过程中,由于把其他编程语言的语句或 习惯也写进了设计中,导致多次出错。所以还需要多做练习来很好地区分 和熟悉 verilog 语言。3、通过实验,对时序电路的编写设计有了初步认知,对其基本步步骤有 了基本的掌握,同时也感受到了流程级建模和行为级建模的综合使用的灵 活性。比如,将进位信号写在 always 语句之外显得很方便。4、对于功能仿真要考虑到仿真的完备性,比如在设计时钟周期与仿真时 间长度时,至少应该让设计进行一个完整的功能周期(考虑到所有情况), 这样才能避免没有检查出存在的错误。
展开阅读全文
相关资源
正为您匹配相似的精品文档
相关搜索

最新文档


当前位置:首页 > 建筑环境 > 机械电气


copyright@ 2023-2025  zhuangpeitu.com 装配图网版权所有   联系电话:18123376007

备案号:ICP2024067431-1 川公网安备51140202000466号


本站为文档C2C交易模式,即用户上传的文档直接被用户下载,本站只是中间服务平台,本站所有文档下载所得的收益归上传人(含作者)所有。装配图网仅提供信息存储空间,仅对用户上传内容的表现方式做保护处理,对上载内容本身不做任何修改或编辑。若文档所含内容侵犯了您的版权或隐私,请立即通知装配图网,我们立即给予删除!