当前位置: 首页 > news >正文

verilog状态机思想编程流水灯

目录

    • 一、状态机
      • 1. 状态机基本概念
      • 2. 状态机类型
      • 3. Verilog 状态机设计要点
    • 二、状态机实现一个1s流水灯
    • 三、DE2-115实物演示

一、状态机

1. 状态机基本概念

状态机(Finite State Machine, FSM)是数字电路设计中用于描述系统状态转换的核心组件,由以下要素组成:
状态寄存器:存储当前状态
下一状态逻辑:根据输入和当前状态确定下一状态
输出逻辑:生成与当前状态相关的输出

2. 状态机类型

类型特点
Moore输出仅取决于当前状态
Mealy输出取决于当前状态和输入
混合型结合 Moore 和 Mealy 的特点

3. Verilog 状态机设计要点

推荐使用三段式状态机结构:

  1. 状态寄存器(时序逻辑)
  2. 下一状态逻辑(组合逻辑)
  3. 输出逻辑(组合逻辑或时序逻辑)

优点:结构清晰、避免组合逻辑环路、便于综合和调试。

二、状态机实现一个1s流水灯

代码:
主模块:

module flowLed (
    input  wire clk,        // 系统时钟
    input  wire rst_n,      // 复位信号
    output reg  [7:0] led   // 8位LED输出
);

// 时钟分频信号连线
wire clk_1s_en;

// 实例化时钟分频模块
clk_divider u_clk_divider (
    .clk(clk),
    .rst_n(rst_n),
    .clk_1s_en(clk_1s_en)
);

// ========== 三段式状态机设计 ========== //
// 第一阶段:状态寄存器定义
reg [7:0] state;

// 第二阶段:状态转移逻辑
always @(posedge clk or negedge rst_n) begin
    if (!rst_n) begin
        state <= 8'b0000_0001;  // 复位时第一个LED亮
    end else if (clk_1s_en) begin  // 每秒更新一次状态
        state <= {state[6:0], state[7]};  // 循环左移
    end
end

// 第三阶段:输出逻辑(直接驱动LED)
always @(posedge clk or negedge rst_n) begin
    if (!rst_n) begin
        led <= 8'b0000_0001;  // 初始状态
    end else begin
        led <= state;  // 状态直接映射到LED输出
    end
end

endmodule

分频模块:

module clk_divider (
    input  wire clk,        // 系统时钟(如50MHz)
    input  wire rst_n,      // 复位信号(低有效)
    output reg  clk_1s_en   // 1秒使能信号(高脉冲)
);

// 50MHz -> 1Hz,需要计数50,000,000次(根据实际时钟调整)
parameter MAX_COUNT = 50_000_000 - 1; 
reg [25:0] counter;  // 足够覆盖50MHz分频的位宽

always @(posedge clk or negedge rst_n) begin
    if (!rst_n) begin
        counter <= 0;
        clk_1s_en <= 0;
    end else begin
        if (counter == MAX_COUNT) begin
            clk_1s_en <= 1;      // 产生1Hz使能脉冲
            counter <= 0;
        end else begin
            counter <= counter + 1;
            clk_1s_en <= 0;      // 保持单周期高脉冲
        end
    end
end

endmodule

三、DE2-115实物演示

引脚配置:
在这里插入图片描述
实物效果:

流水灯

http://www.dtcms.com/a/113662.html

相关文章:

  • VMware 安装 Ubuntu 全流程实战指南:从零搭建到深度优化
  • 医药档案区块链系统
  • 强引用,弱引用,软引用,虚引用,自旋锁,读写锁
  • 基于springboot放松音乐在线播放系统(源码+lw+部署文档+讲解),源码可白嫖!
  • Linux驱动-①电容屏触摸屏②音频③CAN通信
  • client-go如何监听自定义资源
  • 2011-2019年各省地方财政资源勘探电力信息等事务支出数据
  • Jetpack Compose 自定义标题栏终极指南:从基础到高级实战
  • 蓝桥杯2024年第十五届省赛真题-宝石组合
  • BGP路由协议之特殊配置
  • Linux内核slab分配器
  • Linux 系统安装与优化全攻略:打造高效开发环境
  • Airflow量化入门系列:第四章 A股数据处理与存储优化
  • 浅谈StarRocks 常见问题解析
  • (5)模拟后——Leonardo的可视化操作
  • 探秘叁仟智盒设备:智慧城市的智能枢纽
  • Django4.0 快速集成jwt
  • ASP.NET Core Web API 参数传递方式
  • NLP简介及其发展历史
  • docker stack常用命令
  • C#结构体(Struct)深度解析:轻量数据容器与游戏开发应用 (Day 20)
  • pinia-plugin-persist、vuex
  • Spring Boot项目连接MySQL数据库及CRUD操作示例
  • Java Timer:老派但好用的“定时任务小闹钟“
  • 【Linux】进程间通信、匿名管道、进程池
  • 将OpenFOAM中的lduMatrix数据转换为CSC稀疏矩阵格式
  • 混合编程的架构
  • Java EE期末总结(第三章)
  • Leedcode刷题 | 回溯算法小总结01
  • kali——masscan