led闪烁(时序输入输出,自定义变量,时钟仿真,执行顺序)
1.设计定义
设计一个以200ms亮,200ms暗交替闪烁的led灯,并且有一个复位按钮可以停止工作。
2.设计输入
2.1端口
以固定周期交替闪烁说明由时钟控制,需要一个时钟控制端口clk,要求复位按钮,则需要一个复位端口reset,输出为led灯,则有一个输出端口led。
2.2变量
每个开发板的时钟频率是固定的,本次用的开发板时钟周期为20ns。而led闪烁的周期为400ms,我们需要每200ms让led改变一次状态,这时便需要一个计数的变量counter,当counter达到(200ms/20ns)-1时让led取反便可实现目标。注意,counter不属于端口,故不写在led模块里面。且counter是个比较大的数,应该先计算一下位宽,这里用程序员计算器输入十进制数,便可自动转换为二进制,得到位宽。
1 module led_flash( //2输入1输出
2 clk,
3 reset,
4 led
5 );
6 input clk;
7 input reset;
8 output reg led;
9
10 reg [23:0]counter; //定义计数器,在module内,led外
11
12 always@( posedge clk or negedge reset ) begin //时序仿真,clk上升沿触发,reset下降沿触发。满足任一条件就进入always执行
13 if(reset == 1'd1 )begin //复位端有效,计数置零
14 counter <= 0;
15 end
16 else if( counter == 9999999 ) begin //计数到200ms,计数器置零
17 counter <= 0;
18 end
19 else
20 counter <= counter + 1'd1; //计数
21 end
22
23 always@( posedge clk or negedge reset ) begin
24 if(reset == 1'd1 )begin //复位端有效,led熄灭
25 led <= 0;
26 end
27 else if( counter == 9999999 ) begin //led翻转状态
28 led <= !led;
29 end
30 end
31
32
33
34 endmodule
3.综合
4.综合后功能仿真
1 `timescale 1ns/1ns
2
3 module led_flash_tb();
4
5 reg s_clk;
6 reg s_reset;
7 wire s_led;
8
9 led_flash led_flash_sim(
10 .clk(s_clk),
11 .reset(s_reset),
12 .led(s_led)
13 );
14
15 initial s_clk = 1; //模拟时钟信号
16 always #10 s_clk = !s_clk; //每10ns时钟便翻转一次,模拟开发板的时钟
17
18 initial begin
19 s_reset = 1; //模拟复位端有效,持续101ns
20 #101;
21 s_reset = 0;
22 #400000000; //复位端无效,持续400ms
23 $stop;
24 end
25
26 endmodule
5.布局布线
6.时序仿真,性能分析
7.板级调试,设置i/o口,std,pin,下载到板子上。
- 注意
1.在设计模块中,output reg xx可以,但input reg xx不可以。删了reg,否则报错。
2.一般只有端口放在你定义的模块部件里,其他变量放在模块外,module内。如果变量不是简单的0和1,则要定义它的位宽,用程序员计算器转为2进制即可快速写出。
3.计算中+1最好写出 + 1'd1(或其他进制的1)比较规范。
4.有括号和赋值等语句,加个空格比较美观。
5.时序电路最好用非阻塞赋值 <=。
6.模拟仿真时时钟要翻转很多次,不能再写成之前的:
s_a=0; s_b=0; s_sel=0;
#100;
s_a=0; s_b=1; s_sel=0;
#100;
s_a=1; s_b=0; s_sel=0;
要写99999次不现实。因为只有两个状态在翻转且周期固定,直接写成:
initial s_clk = 1; //模拟时钟信号
always #10 s_clk = !s_clk; //每10ns时钟便翻转一次,模拟开发板的时钟
7.当一个判断条件语句(或其他语句)接着有多个操作时,用begin和end括起来才不会报错。
8.学习复位信号的仿真
initial begin
s_reset = 1; //模拟复位端有效,持续101ns
#101;
s_reset = 0;
#400000000; //复位端无效,持续400ms
$stop;
9.由于fpga是并行执行,而非按顺序从上往下执行代码,故可以把多个操作分成几个always进行,这样有利于软件综合成较为简单的电路,也方便我们修改代码。如下:
always@( posedge clk or negedge reset ) begin
if(reset == 1'd1 )begin
counter <= 0;
end
else if( counter == 9999999 ) begin
counter <= 0;
end
else
counter <= counter + 1'd1;
end always@( posedge clk or negedge reset ) begin
if(reset == 1'd1 )begin
led <= 0;
end
else if( counter == 9999999 ) begin
led <= !led;
end
end
always@( posedge clk or negedge reset ) begin
if(reset == 1'd1 )begin
counter <= 0;
led<=0;
end
else if( counter == 9999999 ) begin
counter <= 0;
led<=!led;
end
else
counter <= counter + 1'd1;
end
两者等价,但第一种更好。
10.看时序仿真的时候可以进行标记,create market,以便观察时间间隔。
led闪烁(时序输入输出,自定义变量,时钟仿真,执行顺序)的更多相关文章
- C#类、静态类、静态变量,初始化执行顺序
执行顺序: 类的静态变量 ↓ 类的静态构造函数 ↓ 类的普通变量 ↓ 基类的静态变量 ↓ 基类的静态构造函数 ↓ 基类的普通变量 ↓ 基类的构造函数 ↓ 类的构造函数
- java代码块,静态代码块,静态变量,构造方法执行顺序
一个类中执行顺序: 静态变量静态代码块代码块构造方法 子类和父类执行顺序: 父类静态变量父类静态代码块子类静态变量子类静态代码块父类代码块父类构造方法子类代码块子类构造方法 直接看代码,一目了然. p ...
- MySQL 查询排除指定字段、自定义变量、动态执行SQL
今天在项目中,要查询一个表.这个表中有几十个字段.但是要把其中的一个特殊处理. 这个该怎么办呢?查来查去,SQL 中没有排除某一些字段的语句,只能单独写一些语句来处理: 基本思路:对于MySQL数据库 ...
- Linux中环境变量中文件执行顺序
Linux 的变量可分为两类:环境变量和本地变量 环境变量:或者称为全局变量,存在于所有的shell 中,在你登陆系统的时候就已经有了相应的系统定义的环境变量了.Linux 的环境变量具有 ...
- js函数和变量的声明与执行顺序
一.函数执行顺序 1.正常顺序 function f(){ alert(2); } f(); //alert 2 所有浏览器都能测试通过. 2.倒序调用 f(); //alert 2 function ...
- js函数和变量的执行顺序【易错】
js函数和变量的声明与执行顺序 一.函数执行顺序 1.正常顺序 function f(){ alert(2); } f(); //alert 2 所有浏览器都能测试通过. 2.倒序调用 f(); // ...
- 【Java】成员变量赋值执行顺序
程序中成员变量赋值的执行顺序
- STM32入门系列-STM32时钟系统,自定义系统时钟
在时钟树的讲解中我们知道,通过修改PLLMUL中的倍系数值(2-16)可以改变系统的时钟频率.在库函数中也有对时钟倍频因子配置的函数,如下: void RCC_PLLConfig(uint32_t R ...
- [stm32][ucos][ucgui] 2、LED闪烁、串口、滑块、文本编辑框简单例程
上一篇:[stm32][ucos] 1.基于ucos操作系统的LED闪烁.串口通信简单例程 * 内容简述: 本例程操作系统采用ucos2.86a版本, 建立了7个任务 任务名 ...
随机推荐
- 一文读懂 Kubernetes 容器网络
点击上方"开源Linux",选择"设为星标" 回复"学习"获取独家整理的学习资料! 在Kubernetes中要保证容器之间网络互通,网络至关 ...
- 4┃音视频直播系统之浏览器中通过 WebRTC 进行桌面共享
一.共享桌面原理 共享桌面在直播系统中是一个必备功能 共享者:每秒钟抓取多次屏幕,每次抓取的屏幕都与上一次抓取的屏幕做比较,取它们的差值,然后对差值进行压缩:如果是第一次抓屏或切幕的情况,即本次抓取的 ...
- 145_Power BI Report Server自定义Form登录
博客:www.jiaopengzi.com 焦棚子的文章目录 请点击下载附件 1.背景 很久没有更新Power BI Report Server了,发现自己机器还是2021年1月版本的,现在更新了20 ...
- Fail2ban 命令详解 fail2ban-regex
fail2ban-regex是fail2ban提供的用来测试正则表达式的一个小工具,我们可以用它来测试正则表达式是否能够匹配到日志文件中的要禁止的IP行. fail2ban-regex默认情况下自动匹 ...
- 基于SqlSugar的开发框架循序渐进介绍(5)-- 在服务层使用接口注入方式实现IOC控制反转
在前面随笔,我们介绍过这个基于SqlSugar的开发框架,我们区分Interface.Modal.Service三个目录来放置不同的内容,其中Modal是SqlSugar的映射实体,Interface ...
- 第06组Alpha冲刺总结
目录 1. 基本情况 2. 思考与总结 2.1. 设想和目标 2. 计划 3. 资源 4. 变更管理 5. 设计/实现 6. 测试/发布 7. 团队的角色,管理,合作 8. 总结 3. 敏捷开发 1. ...
- 第06组 Alpha冲刺 (2/6)
目录 1.1 基本情况 1.2 冲刺概况汇报 1.郝雷明 2. 方梓涵 3. 黄少丹 4. 董翔云 5.曾丽莉 6. 詹鑫冰 7.鲍凌函 8.杜筱 9.曹兰英 10. 吴沅静 1.3 冲刺成果展示 1 ...
- Java开发学习(一)----初识Spring及其核心概念
一. Spring系统架构 1.1 系统架构图 Spring Framework是Spring生态圈中最基础的项目,是其他项目的根基. Spring Framework的发展也经历了很多版本的变更,每 ...
- [react] 什么是虚拟dom?虚拟dom比操作原生dom要快吗?虚拟dom是如何转变成真实dom并渲染到页面的?
壹 ❀ 引 虚拟DOM(Virtual DOM)在前端领域也算是老生常谈的话题了,若你了解过vue或者react一定避不开这个话题,因此虚拟DOM也算是面试中常问的一个点,那么通过本文,你将了解到如下 ...
- Acwing 1927 自动补全(知识点:hash,二分,排序)
读完题目第一想法是trie树 ,不过好像没怎么做过trie树的题,看y总给的知识点是二分排序,所以就有了如下思路: 但是但是,看完其他题解之后才坚定了我的想法,原来真的是这样排序,暴力啊! 具体步骤 ...